9740 lines
		
	
	
		
			232 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			9740 lines
		
	
	
		
			232 KiB
		
	
	
	
		
			JavaScript
		
	
	
/*
 | 
						|
Name: 			Theme Base
 | 
						|
Written by: 	Okler Themes - (https://www.okler.net)
 | 
						|
Theme Version:	9.9.2
 | 
						|
*/
 | 
						|
 | 
						|
// Theme
 | 
						|
window.theme = {};
 | 
						|
 | 
						|
// Theme Common Functions
 | 
						|
window.theme.fn = {
 | 
						|
 | 
						|
	getOptions: function(opts) {
 | 
						|
 | 
						|
		if (typeof(opts) == 'object') {
 | 
						|
 | 
						|
			return opts;
 | 
						|
 | 
						|
		} else if (typeof(opts) == 'string') {
 | 
						|
 | 
						|
			try {
 | 
						|
				return JSON.parse(opts.replace(/'/g, '"').replace(';', ''));
 | 
						|
			} catch (e) {
 | 
						|
				return {};
 | 
						|
			}
 | 
						|
 | 
						|
		} else {
 | 
						|
 | 
						|
			return {};
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
	},
 | 
						|
 | 
						|
	execPluginFunction: function(functionName, context) {
 | 
						|
		var args = Array.prototype.slice.call(arguments, 2);
 | 
						|
		var namespaces = functionName.split(".");
 | 
						|
		var func = namespaces.pop();
 | 
						|
 | 
						|
		for (var i = 0; i < namespaces.length; i++) {
 | 
						|
			context = context[namespaces[i]];
 | 
						|
		}
 | 
						|
 | 
						|
		return context[func].apply(context, args);
 | 
						|
	},
 | 
						|
 | 
						|
	intObs: function(selector, functionName, intObsOptions, alwaysObserve) {
 | 
						|
		var $el = document.querySelectorAll(selector);
 | 
						|
		var intersectionObserverOptions = {
 | 
						|
			rootMargin: '0px 0px 200px 0px'
 | 
						|
		}
 | 
						|
 | 
						|
		if (Object.keys(intObsOptions).length) {
 | 
						|
			intersectionObserverOptions = $.extend(intersectionObserverOptions, intObsOptions);
 | 
						|
		}
 | 
						|
 | 
						|
		var observer = new IntersectionObserver(function(entries) {
 | 
						|
			for (var i = 0; i < entries.length; i++) {
 | 
						|
				var entry = entries[i];
 | 
						|
 | 
						|
				if (entry.intersectionRatio > 0) {
 | 
						|
					if (typeof functionName === 'string') {
 | 
						|
						var func = Function('return ' + functionName)();
 | 
						|
					} else {
 | 
						|
						var callback = functionName;
 | 
						|
 | 
						|
						callback.call($(entry.target));
 | 
						|
					}
 | 
						|
 | 
						|
					// Unobserve
 | 
						|
					if (!alwaysObserve) {
 | 
						|
						observer.unobserve(entry.target);
 | 
						|
					}
 | 
						|
 | 
						|
				}
 | 
						|
			}
 | 
						|
		}, intersectionObserverOptions);
 | 
						|
 | 
						|
		$($el).each(function() {
 | 
						|
			observer.observe($(this)[0]);
 | 
						|
		});
 | 
						|
	},
 | 
						|
 | 
						|
	intObsInit: function(selector, functionName) {
 | 
						|
		var $el = document.querySelectorAll(selector);
 | 
						|
		var intersectionObserverOptions = {
 | 
						|
			rootMargin: '200px'
 | 
						|
		}
 | 
						|
 | 
						|
		var observer = new IntersectionObserver(function(entries) {
 | 
						|
			for (var i = 0; i < entries.length; i++) {
 | 
						|
				var entry = entries[i];
 | 
						|
				if (entry.intersectionRatio > 0) {
 | 
						|
 | 
						|
					var $this = $(entry.target),
 | 
						|
						opts;
 | 
						|
 | 
						|
					var pluginOptions = theme.fn.getOptions($this.data('plugin-options'));
 | 
						|
					if (pluginOptions)
 | 
						|
						opts = pluginOptions;
 | 
						|
 | 
						|
					theme.fn.execPluginFunction(functionName, $this, opts);
 | 
						|
 | 
						|
					// Unobserve
 | 
						|
					observer.unobserve(entry.target);
 | 
						|
				}
 | 
						|
			}
 | 
						|
		}, intersectionObserverOptions);
 | 
						|
 | 
						|
		$($el).each(function() {
 | 
						|
			observer.observe($(this)[0]);
 | 
						|
		});
 | 
						|
	},
 | 
						|
 | 
						|
	dynIntObsInit: function(selector, functionName, pluginDefaults) {
 | 
						|
		var $el = document.querySelectorAll(selector);
 | 
						|
 | 
						|
		$($el).each(function() {
 | 
						|
			var $this = $(this),
 | 
						|
				opts;
 | 
						|
 | 
						|
			var pluginOptions = theme.fn.getOptions($this.data('plugin-options'));
 | 
						|
			if (pluginOptions)
 | 
						|
				opts = pluginOptions;
 | 
						|
 | 
						|
			var mergedPluginDefaults = theme.fn.mergeOptions(pluginDefaults, opts)
 | 
						|
 | 
						|
			var intersectionObserverOptions = {
 | 
						|
				rootMargin: theme.fn.getRootMargin(functionName, mergedPluginDefaults),
 | 
						|
				threshold: 0
 | 
						|
			}
 | 
						|
 | 
						|
			if (!mergedPluginDefaults.forceInit) {
 | 
						|
 | 
						|
				var observer = new IntersectionObserver(function(entries) {
 | 
						|
					for (var i = 0; i < entries.length; i++) {
 | 
						|
						var entry = entries[i];
 | 
						|
 | 
						|
						if (entry.intersectionRatio > 0) {
 | 
						|
							theme.fn.execPluginFunction(functionName, $this, mergedPluginDefaults);
 | 
						|
 | 
						|
							// Unobserve
 | 
						|
							observer.unobserve(entry.target);
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}, intersectionObserverOptions);
 | 
						|
 | 
						|
				observer.observe($this[0]);
 | 
						|
 | 
						|
			} else {
 | 
						|
				theme.fn.execPluginFunction(functionName, $this, mergedPluginDefaults);
 | 
						|
			}
 | 
						|
		});
 | 
						|
	},
 | 
						|
 | 
						|
	getRootMargin: function(plugin, pluginDefaults) {
 | 
						|
		switch (plugin) {
 | 
						|
			case 'themePluginCounter':
 | 
						|
				return pluginDefaults.accY ? '0px 0px ' + pluginDefaults.accY + 'px 0px' : '0px 0px 200px 0px';
 | 
						|
				break;
 | 
						|
 | 
						|
			case 'themePluginAnimate':
 | 
						|
				return pluginDefaults.accY ? '0px 0px ' + pluginDefaults.accY + 'px 0px' : '0px 0px 200px 0px';
 | 
						|
				break;
 | 
						|
 | 
						|
			case 'themePluginIcon':
 | 
						|
				return pluginDefaults.accY ? '0px 0px ' + pluginDefaults.accY + 'px 0px' : '0px 0px 200px 0px';
 | 
						|
				break;
 | 
						|
 | 
						|
			case 'themePluginRandomImages':
 | 
						|
				return pluginDefaults.accY ? '0px 0px ' + pluginDefaults.accY + 'px 0px' : '0px 0px 200px 0px';
 | 
						|
				break;
 | 
						|
 | 
						|
			default:
 | 
						|
				return '0px 0px 200px 0px';
 | 
						|
				break;
 | 
						|
		}
 | 
						|
	},
 | 
						|
 | 
						|
	mergeOptions: function(obj1, obj2) {
 | 
						|
		var obj3 = {};
 | 
						|
 | 
						|
		for (var attrname in obj1) {
 | 
						|
			obj3[attrname] = obj1[attrname];
 | 
						|
		}
 | 
						|
		for (var attrname in obj2) {
 | 
						|
			obj3[attrname] = obj2[attrname];
 | 
						|
		}
 | 
						|
 | 
						|
		return obj3;
 | 
						|
	},
 | 
						|
 | 
						|
	execOnceTroughEvent: function($el, event, callback) {
 | 
						|
		var self = this,
 | 
						|
			dataName = self.formatDataName(event);
 | 
						|
 | 
						|
		$($el).on(event, function() {
 | 
						|
			if (!$(this).data(dataName)) {
 | 
						|
 | 
						|
				// Exec Callback Function
 | 
						|
				callback.call($(this));
 | 
						|
 | 
						|
				// Add data name 
 | 
						|
				$(this).data(dataName, true);
 | 
						|
 | 
						|
				// Unbind event
 | 
						|
				$(this).off(event);
 | 
						|
			}
 | 
						|
		});
 | 
						|
 | 
						|
		return this;
 | 
						|
	},
 | 
						|
 | 
						|
	execOnceTroughWindowEvent: function($el, event, callback) {
 | 
						|
		var self = this,
 | 
						|
			dataName = self.formatDataName(event);
 | 
						|
 | 
						|
		$($el).on(event, function() {
 | 
						|
			if (!$(this).data(dataName)) {
 | 
						|
 | 
						|
				// Exec Callback Function
 | 
						|
				callback();
 | 
						|
 | 
						|
				// Add data name 
 | 
						|
				$(this).data(dataName, true);
 | 
						|
 | 
						|
				// Unbind event
 | 
						|
				$(this).off(event);
 | 
						|
			}
 | 
						|
		});
 | 
						|
 | 
						|
		return this;
 | 
						|
	},
 | 
						|
 | 
						|
	formatDataName: function(name) {
 | 
						|
		name = name.replace('.', '');
 | 
						|
		return name;
 | 
						|
	},
 | 
						|
 | 
						|
	isElementInView: function($el) {
 | 
						|
		var rect = $el[0].getBoundingClientRect();
 | 
						|
 | 
						|
		return (
 | 
						|
			rect.top <= (window.innerHeight / 3)
 | 
						|
		);
 | 
						|
	},
 | 
						|
 | 
						|
	getScripts: function(arr, path) {
 | 
						|
		var _arr = $.map(arr, function(scr) {
 | 
						|
			return $.getScript((path || "") + scr);
 | 
						|
		});
 | 
						|
 | 
						|
		_arr.push($.Deferred(function(deferred) {
 | 
						|
			$(deferred.resolve);
 | 
						|
		}));
 | 
						|
 | 
						|
		return $.when.apply($, _arr);
 | 
						|
	},
 | 
						|
 | 
						|
	showErrorMessage: function(title, content) {
 | 
						|
 | 
						|
		$('.modalThemeErrorMessage').remove();
 | 
						|
		$('body').append('<div class="modal fade" id="modalThemeErrorMessage" aria-hidden="true" tabindex="-1"><div class="modal-dialog modal-dialog-centered"><div class="modal-content"><div class="modal-header"><h5 class="modal-title">' + title + '</h5><button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button></div><div class="modal-body">' + content + '</div><div class="modal-footer"><button type="button" class="btn btn-primary" data-bs-dismiss="modal">Close</button></div></div></div></div>');
 | 
						|
 | 
						|
		var modalThemeErrorMessage = document.getElementById('modalThemeErrorMessage');
 | 
						|
		var modalThemeErrorMessage = bootstrap.Modal.getOrCreateInstance(modalThemeErrorMessage);
 | 
						|
		modalThemeErrorMessage.show();
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
};
 | 
						|
 | 
						|
(function($) {
 | 
						|
 | 
						|
	/*
 | 
						|
	Local Environment Warning
 | 
						|
	*/
 | 
						|
	try {
 | 
						|
		if ("file://" === location.origin) {
 | 
						|
			if ($('[data-icon]').length || $('iframe').length) {
 | 
						|
 | 
						|
				theme.fn.showErrorMessage('Local Environment Warning', 'SVG Objects, Icons, YouTube and Vimeo Videos might not show correctly on local environment. For better result, please preview on a server.');
 | 
						|
 | 
						|
			}
 | 
						|
		}
 | 
						|
	} catch (e) {}
 | 
						|
 | 
						|
	/*
 | 
						|
	Browser Selector
 | 
						|
	*/
 | 
						|
	$.extend({
 | 
						|
 | 
						|
		browserSelector: function() {
 | 
						|
 | 
						|
			// jQuery.browser.mobile (https://detectmobilebrowser.com/)
 | 
						|
			(function(a){(jQuery.browser=jQuery.browser||{}).mobile=/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i.test(a)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(a.substr(0,4))})(navigator.userAgent||navigator.vendor||window.opera);
 | 
						|
 | 
						|
			// Touch
 | 
						|
			var hasTouch = 'ontouchstart' in window || navigator.msMaxTouchPoints;
 | 
						|
 | 
						|
			var u = navigator.userAgent,
 | 
						|
				ua = u.toLowerCase(),
 | 
						|
				is = function (t) {
 | 
						|
					return ua.indexOf(t) > -1;
 | 
						|
				},
 | 
						|
				g = 'gecko',
 | 
						|
				w = 'webkit',
 | 
						|
				s = 'safari',
 | 
						|
				o = 'opera',
 | 
						|
				h = document.documentElement,
 | 
						|
				b = [(!(/opera|webtv/i.test(ua)) && /msie\s(\d)/.test(ua)) ? ('ie ie' + parseFloat(navigator.appVersion.split("MSIE")[1])) : is('firefox/2') ? g + ' ff2' : is('firefox/3.5') ? g + ' ff3 ff3_5' : is('firefox/3') ? g + ' ff3' : is('gecko/') ? g : is('opera') ? o + (/version\/(\d+)/.test(ua) ? ' ' + o + RegExp.jQuery1 : (/opera(\s|\/)(\d+)/.test(ua) ? ' ' + o + RegExp.jQuery2 : '')) : is('konqueror') ? 'konqueror' : is('chrome') ? w + ' chrome' : is('iron') ? w + ' iron' : is('applewebkit/') ? w + ' ' + s + (/version\/(\d+)/.test(ua) ? ' ' + s + RegExp.jQuery1 : '') : is('mozilla/') ? g : '', is('j2me') ? 'mobile' : is('iphone') ? 'iphone' : is('ipod') ? 'ipod' : is('mac') ? 'mac' : is('darwin') ? 'mac' : is('webtv') ? 'webtv' : is('win') ? 'win' : is('freebsd') ? 'freebsd' : (is('x11') || is('linux')) ? 'linux' : '', 'js'];
 | 
						|
 | 
						|
			c = b.join(' ');
 | 
						|
 | 
						|
			if ($.browser.mobile) {
 | 
						|
				c += ' mobile';
 | 
						|
			}
 | 
						|
 | 
						|
			if (hasTouch) {
 | 
						|
				c += ' touch';
 | 
						|
			}
 | 
						|
 | 
						|
			h.className += ' ' + c;
 | 
						|
 | 
						|
			// Edge Detect
 | 
						|
			var isEdge = /Edge/.test(navigator.userAgent);
 | 
						|
 | 
						|
			if(isEdge) {
 | 
						|
				$('html').removeClass('chrome').addClass('edge');
 | 
						|
			}
 | 
						|
 | 
						|
			// Dark and Boxed Compatibility
 | 
						|
			if($('body').hasClass('dark')) {
 | 
						|
				$('html').addClass('dark');
 | 
						|
			}
 | 
						|
 | 
						|
			if($('body').hasClass('boxed')) {
 | 
						|
				$('html').addClass('boxed');
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
	});
 | 
						|
 | 
						|
	$.browserSelector();
 | 
						|
 | 
						|
	/*
 | 
						|
	Browser Workarounds
 | 
						|
	*/
 | 
						|
	if (/iPad|iPhone|iPod/.test(navigator.platform)) {
 | 
						|
 | 
						|
		// iPad/Iphone/iPod Hover Workaround
 | 
						|
		$(document).ready(function($) {
 | 
						|
			$('.thumb-info').attr('onclick', 'return true');
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	Tabs
 | 
						|
	*/
 | 
						|
	if( $('a[data-bs-toggle="tab"]').length ) {
 | 
						|
		$('a[data-bs-toggle="tab"]').on('shown.bs.tab', function (e) {
 | 
						|
			var $tabPane = $($(e.target).attr('href'));
 | 
						|
 | 
						|
			// Carousel Refresh
 | 
						|
			if($tabPane.length) {
 | 
						|
				$tabPane.find('.owl-carousel').trigger('refresh.owl.carousel');
 | 
						|
			}
 | 
						|
 | 
						|
			// Change Active Class
 | 
						|
			$(this).parents('.nav-tabs').find('.active').removeClass('active');
 | 
						|
			$(this).addClass('active').parent().addClass('active');
 | 
						|
		});	
 | 
						|
 | 
						|
		if( window.location.hash ) {
 | 
						|
			$(window).on('load', function(){
 | 
						|
				if( window.location.hash !== '*' && $( window.location.hash ).get(0) ) {
 | 
						|
					new bootstrap.Tab( $('a.nav-link[href="'+ window.location.hash +'"]:not([data-hash])')[0] ).show();
 | 
						|
				}
 | 
						|
			});
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	On Load Scroll
 | 
						|
	*/
 | 
						|
	if( !$('html').hasClass('disable-onload-scroll') && window.location.hash && !['#*'].includes( window.location.hash ) ) {
 | 
						|
 | 
						|
		window.scrollTo(0, 0);
 | 
						|
 | 
						|
		$(window).on('load', function() {
 | 
						|
			setTimeout(function() {
 | 
						|
 | 
						|
				var target = window.location.hash,
 | 
						|
					offset = ( $(window).width() < 768 ) ? 180 : 90;
 | 
						|
 | 
						|
				if (!$(target).length) {
 | 
						|
					return;
 | 
						|
				}
 | 
						|
 | 
						|
				if ( $("a[href$='" + window.location.hash + "']").is('[data-hash-offset]') ) {
 | 
						|
					offset = parseInt( $("a[href$='" + window.location.hash + "']").first().attr('data-hash-offset') );
 | 
						|
				} else if ( $("html").is('[data-hash-offset]') ) {
 | 
						|
					offset = parseInt( $("html").attr('data-hash-offset') );
 | 
						|
				}
 | 
						|
 | 
						|
				if (isNaN(offset)) {
 | 
						|
					offset = 0;
 | 
						|
				}
 | 
						|
 | 
						|
				$('body').addClass('scrolling');
 | 
						|
 | 
						|
				$('html, body').animate({
 | 
						|
					scrollTop: $(target).offset().top - offset
 | 
						|
				}, 600, 'easeOutQuad', function() {
 | 
						|
					$('body').removeClass('scrolling');
 | 
						|
				});
 | 
						|
 | 
						|
			}, 1);
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Text Rotator
 | 
						|
	*/
 | 
						|
	$.fn.extend({
 | 
						|
		textRotator: function(options) {
 | 
						|
 | 
						|
			var defaults = {
 | 
						|
				fadeSpeed: 500,
 | 
						|
				pauseSpeed: 100,
 | 
						|
				child: null
 | 
						|
			};
 | 
						|
 | 
						|
			var options = $.extend(defaults, options);
 | 
						|
 | 
						|
			return this.each(function() {
 | 
						|
				var o = options;
 | 
						|
				var obj = $(this);
 | 
						|
				var items = $(obj.children(), obj);
 | 
						|
				items.each(function() {
 | 
						|
					$(this).hide();
 | 
						|
				})
 | 
						|
				if (!o.child) {
 | 
						|
					var next = $(obj).children(':first');
 | 
						|
				} else {
 | 
						|
					var next = o.child;
 | 
						|
				}
 | 
						|
				$(next).fadeIn(o.fadeSpeed, function() {
 | 
						|
					$(next).delay(o.pauseSpeed).fadeOut(o.fadeSpeed, function() {
 | 
						|
						var next = $(this).next();
 | 
						|
						if (next.length == 0) {
 | 
						|
							next = $(obj).children(':first');
 | 
						|
						}
 | 
						|
						$(obj).textRotator({
 | 
						|
							child: next,
 | 
						|
							fadeSpeed: o.fadeSpeed,
 | 
						|
							pauseSpeed: o.pauseSpeed
 | 
						|
						});
 | 
						|
					})
 | 
						|
				});
 | 
						|
			});
 | 
						|
		}
 | 
						|
	});
 | 
						|
 | 
						|
	/*
 | 
						|
	* Notice Top bar
 | 
						|
	*/
 | 
						|
	var $noticeTopBar = {
 | 
						|
		$wrapper: $('.notice-top-bar'),
 | 
						|
		$closeBtn: $('.notice-top-bar-close'),
 | 
						|
		$header: $('#header'),
 | 
						|
		$body: $('.body'),
 | 
						|
		init: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if( !$.cookie('portoNoticeTopBarClose') ) {
 | 
						|
				self
 | 
						|
					.build()
 | 
						|
					.events();
 | 
						|
			} else {
 | 
						|
				self.$wrapper.parent().prepend( '<!-- Notice Top Bar removed by cookie -->' );
 | 
						|
				self.$wrapper.remove();
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
		build: function(){
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			$(window).on('load', function(){
 | 
						|
				setTimeout(function(){
 | 
						|
					self.$body.css({
 | 
						|
						'margin-top': self.$wrapper.outerHeight(),
 | 
						|
						'transition': 'ease margin 300ms'
 | 
						|
					});
 | 
						|
 | 
						|
					$('#noticeTopBarContent').textRotator({
 | 
						|
						fadeSpeed: 500,
 | 
						|
						pauseSpeed: 5000
 | 
						|
					});
 | 
						|
 | 
						|
					if( ['absolute', 'fixed'].includes( self.$header.css('position') ) ) {
 | 
						|
						self.$header.css({
 | 
						|
							'top': self.$wrapper.outerHeight(),
 | 
						|
							'transition': 'ease top 300ms'
 | 
						|
						});
 | 
						|
					}
 | 
						|
 | 
						|
					$(window).trigger('notice.top.bar.opened');
 | 
						|
 | 
						|
				}, 1000);
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
		events: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			self.$closeBtn.on('click', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				self.$body.animate({
 | 
						|
					'margin-top': 0,
 | 
						|
				}, 300, function(){
 | 
						|
					self.$wrapper.remove();
 | 
						|
					self.saveCookie();
 | 
						|
				});
 | 
						|
 | 
						|
				if( ['absolute', 'fixed'].includes( self.$header.css('position') ) ) {
 | 
						|
					self.$header.animate({
 | 
						|
						top: 0
 | 
						|
					}, 300);
 | 
						|
				}
 | 
						|
 | 
						|
				// When header has shrink effect
 | 
						|
				if( self.$header.hasClass('header-effect-shrink') ) {
 | 
						|
					self.$header.find('.header-body').animate({
 | 
						|
						top: 0
 | 
						|
					}, 300);
 | 
						|
				}
 | 
						|
 | 
						|
				$(window).trigger('notice.top.bar.closed');
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
		checkCookie: function(){
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if( $.cookie('portoNoticeTopBarClose') ) {
 | 
						|
				return true;
 | 
						|
			} else {
 | 
						|
				return false;
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
		saveCookie: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			$.cookie('portoNoticeTopBarClose', true);
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	if( $('.notice-top-bar').length ) {
 | 
						|
		$noticeTopBar.init();
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Image Hotspots
 | 
						|
	*/
 | 
						|
	if( $('.image-hotspot').length ) {
 | 
						|
		$('.image-hotspot')
 | 
						|
			.append('<span class="ring"></span>')
 | 
						|
			.append('<span class="circle"></span>');
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Reading Progress
 | 
						|
	*/
 | 
						|
	if( $('.progress-reading').length ) {
 | 
						|
 | 
						|
		function updateScrollProgress() {
 | 
						|
			var pixels = $(document).scrollTop()
 | 
						|
				pageHeight = $(document).height() - $(window).height()
 | 
						|
				progress = 100 * pixels / pageHeight;
 | 
						|
 | 
						|
			$('.progress-reading .progress-bar').width(parseInt(progress) + "%");
 | 
						|
		}
 | 
						|
 | 
						|
		$(document).on('scroll ready', function() {
 | 
						|
			updateScrollProgress();
 | 
						|
		});
 | 
						|
 | 
						|
		$(document).ready(function(){
 | 
						|
			$(window).afterResize(function() {
 | 
						|
				updateScrollProgress();
 | 
						|
			});
 | 
						|
		});
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Page Transition
 | 
						|
	*/
 | 
						|
	if( $('body[data-plugin-page-transition]').length ) {
 | 
						|
		
 | 
						|
		var link_click = false;
 | 
						|
 | 
						|
		$(document).on('click', 'a', function(e){
 | 
						|
			link_click = $(this);
 | 
						|
		});
 | 
						|
 | 
						|
		$(window).on("beforeunload", function(e) {
 | 
						|
			if( typeof link_click === 'object' ) {
 | 
						|
				var href = link_click.attr('href');
 | 
						|
 | 
						|
				if( href.indexOf('mailto:') != 0 && href.indexOf('tel:') != 0 && !link_click.data('rm-from-transition') ) {
 | 
						|
					$('body').addClass('page-transition-active');
 | 
						|
				}
 | 
						|
			}
 | 
						|
		});
 | 
						|
 | 
						|
		$(window).on("pageshow", function(e){
 | 
						|
			if( e.persisted || e.originalEvent.persisted) {
 | 
						|
				if( $('html').hasClass('safari') ) {
 | 
						|
					window.location.reload();
 | 
						|
				}
 | 
						|
				
 | 
						|
		        $('body').removeClass('page-transition-active');
 | 
						|
		    }
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Clone Element
 | 
						|
	*/
 | 
						|
	if( $('[data-clone-element]').length ) {
 | 
						|
 | 
						|
		$('[data-clone-element]').each(function() {
 | 
						|
 | 
						|
			var $el = $(this),
 | 
						|
				content = $el.html(),
 | 
						|
				qty = $el.attr('data-clone-element');
 | 
						|
 | 
						|
			for (var i = 0; i < qty; i++) {
 | 
						|
				$el.html($el.html() + content);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Thumb Info Floating Caption
 | 
						|
	*/
 | 
						|
	$('.thumb-info-floating-caption').each(function() {
 | 
						|
 | 
						|
		$(this)
 | 
						|
			.addClass('thumb-info-floating-element-wrapper')
 | 
						|
			.append( '<span class="thumb-info-floating-element thumb-info-floating-caption-title d-none">'+ $(this).data('title') +'</span>' );
 | 
						|
 | 
						|
		if( $(this).data('type') ) {
 | 
						|
			$('.thumb-info-floating-caption-title', $(this))
 | 
						|
				.append( '<div class="thumb-info-floating-caption-type">'+ $(this).data('type') +'</div>' )
 | 
						|
				.css({
 | 
						|
					'padding-bottom' : 22
 | 
						|
				});
 | 
						|
		}
 | 
						|
 | 
						|
		if( $(this).hasClass('thumb-info-floating-caption-clean') ) {
 | 
						|
			$('.thumb-info-floating-element', $(this)).addClass('bg-transparent');
 | 
						|
		}
 | 
						|
 | 
						|
	});
 | 
						|
 | 
						|
	/*
 | 
						|
	* Thumb Info Floating Element
 | 
						|
	*/
 | 
						|
	if( $('.thumb-info-floating-element-wrapper').length ) {
 | 
						|
 | 
						|
		if (typeof gsap !== 'undefined') {
 | 
						|
 | 
						|
			$('.thumb-info-floating-element-wrapper').on('mouseenter', function(e){
 | 
						|
				
 | 
						|
				if(!$(this).data('offset')) {
 | 
						|
					$(this).data('offset', 0);
 | 
						|
				}
 | 
						|
 | 
						|
				var offset = parseInt($(this).data('offset'));
 | 
						|
 | 
						|
				$('.thumb-info-floating-element-clone').remove();
 | 
						|
 | 
						|
				$('.thumb-info-floating-element', $(this)).clone().addClass('thumb-info-floating-element-clone p-fixed p-events-none').attr('style', 'transform: scale(0.1);').removeClass('d-none').appendTo('body');
 | 
						|
 | 
						|
				$('.thumb-info-floating-element-clone').css({
 | 
						|
					left: e.clientX + (offset),
 | 
						|
					top: e.clientY + (offset)
 | 
						|
				}).fadeIn(300);
 | 
						|
 | 
						|
				gsap.to('.thumb-info-floating-element-clone', 0.5, {
 | 
						|
					css: {
 | 
						|
						scaleX: 1,
 | 
						|
						scaleY: 1
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				$(document).off('mousemove').on('mousemove', function(e){
 | 
						|
 | 
						|
					gsap.to('.thumb-info-floating-element-clone', 0.5, {
 | 
						|
						css: {
 | 
						|
							left: e.clientX + (offset),
 | 
						|
							top: e.clientY + (offset)
 | 
						|
						}
 | 
						|
					});
 | 
						|
 | 
						|
				});
 | 
						|
 | 
						|
			}).on('mouseout', function(){
 | 
						|
 | 
						|
				gsap.to('.thumb-info-floating-element-clone', 0.5, {
 | 
						|
					css: {
 | 
						|
						scaleX: 0.5,
 | 
						|
						scaleY: 0.5,
 | 
						|
						opacity: 0
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
			});
 | 
						|
 | 
						|
		} else {
 | 
						|
			theme.fn.showErrorMessage('Failed to Load File', 'Failed to load: GSAP - Include the following file(s): (vendor/gsap/gsap.min.js)');
 | 
						|
		}
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Thumb Info Direction Aware
 | 
						|
	*/
 | 
						|
	$(window).on('load', function() {
 | 
						|
		$('.thumb-info-wrapper-direction-aware').each( function() {
 | 
						|
			$(this).hoverdir({
 | 
						|
				speed : 300,
 | 
						|
				easing : 'ease',
 | 
						|
				hoverDelay : 0,
 | 
						|
				inverse : false,
 | 
						|
				hoverElem: '.thumb-info-wrapper-overlay'
 | 
						|
			});
 | 
						|
		});
 | 
						|
	});
 | 
						|
 | 
						|
	/*
 | 
						|
	* Thumb Info Container Full
 | 
						|
	*/
 | 
						|
	$('.thumb-info-container-full-img').each(function() {
 | 
						|
 | 
						|
		var $container = $(this);
 | 
						|
 | 
						|
		$('[data-full-width-img-src]', $container).each(function() {
 | 
						|
			var uniqueId = 'img' + Math.floor(Math.random() * 10000);
 | 
						|
			$(this).attr('data-rel', uniqueId);
 | 
						|
 | 
						|
			$container.append('<div style="background-image: url(' + $(this).attr('data-full-width-img-src') + ');" id="' + uniqueId + '" class="thumb-info-container-full-img-large opacity-0"></div>');
 | 
						|
		});
 | 
						|
 | 
						|
		$('.thumb-info', $container).on('mouseenter', function(e){
 | 
						|
			$('.thumb-info-container-full-img-large').removeClass('active');
 | 
						|
			$('#' + $(this).attr('data-rel')).addClass('active');
 | 
						|
		});
 | 
						|
 | 
						|
	});
 | 
						|
 | 
						|
	/*
 | 
						|
	* Toggle Text Click
 | 
						|
	*/
 | 
						|
	$('[data-toggle-text-click]').on('click', function () {
 | 
						|
		$(this).text(function(i, text){
 | 
						|
			return text === $(this).attr('data-toggle-text-click') ? $(this).attr('data-toggle-text-click-alt') : $(this).attr('data-toggle-text-click');
 | 
						|
		});
 | 
						|
	});
 | 
						|
 | 
						|
	/*
 | 
						|
	* Toggle Class
 | 
						|
	*/
 | 
						|
	$('[data-toggle-class]').on('click', function (e) {
 | 
						|
		e.preventDefault();
 | 
						|
 | 
						|
		$(this).toggleClass( $(this).data('porto-toggle-class') );
 | 
						|
	});
 | 
						|
 | 
						|
	/*
 | 
						|
	* Shape Divider Aspect Ratio
 | 
						|
	*/
 | 
						|
	if( $('.shape-divider').length ) {
 | 
						|
		aspectRatioSVG();
 | 
						|
		$(window).on('resize', function(){
 | 
						|
			aspectRatioSVG();
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Shape Divider Animated
 | 
						|
	*/
 | 
						|
	if( $('.shape-divider-horizontal-animation').length ) {
 | 
						|
		theme.fn.intObs('.shape-divider-horizontal-animation', function(){
 | 
						|
			for( var i = 0; i <= 1; i++ ) {
 | 
						|
				var svgClone = $(this).find('svg:nth-child(1)').clone();
 | 
						|
 | 
						|
				$(this).append( svgClone )
 | 
						|
			}
 | 
						|
 | 
						|
			$(this).addClass('start');
 | 
						|
		}, {});
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Shape Divider - SVG Aspect Ratio
 | 
						|
	*/
 | 
						|
	function aspectRatioSVG() {
 | 
						|
		if( $(window).width() < 1950 ) {
 | 
						|
			$('.shape-divider svg[preserveAspectRatio]').each(function(){
 | 
						|
				if( !$(this).parent().hasClass('shape-divider-horizontal-animation') ) {
 | 
						|
					$(this).attr('preserveAspectRatio', 'xMinYMin');
 | 
						|
				} else {
 | 
						|
					$(this).attr('preserveAspectRatio', 'none');
 | 
						|
				}
 | 
						|
			});
 | 
						|
		} else {
 | 
						|
			$('.shape-divider svg[preserveAspectRatio]').each(function(){
 | 
						|
				$(this).attr('preserveAspectRatio', 'none');
 | 
						|
			});
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Content Switcher
 | 
						|
	*/
 | 
						|
	$('[data-content-switcher]').on('change', function(e, v) {
 | 
						|
		var switcherRel = ($(this).is(':checked') ? '1' : '2' ),
 | 
						|
			switcherId = $(this).attr('data-content-switcher-content-id');
 | 
						|
 | 
						|
		$('[data-content-switcher-id=' + switcherId + ']').addClass('initialized').removeClass('active');
 | 
						|
 | 
						|
		var $activeEl = $('[data-content-switcher-id=' + switcherId + '][data-content-switcher-rel=' + switcherRel + ']');
 | 
						|
 | 
						|
		$activeEl.addClass('active');
 | 
						|
 | 
						|
		$activeEl.parent().css('height', $activeEl.height());
 | 
						|
	});
 | 
						|
 | 
						|
	$('[data-content-switcher]').trigger('change');
 | 
						|
 | 
						|
	/*
 | 
						|
	* Dynamic Height
 | 
						|
	*/
 | 
						|
	var $window = $(window);
 | 
						|
	$window.on('resize dynamic.height.resize', function(){
 | 
						|
		$('[data-dynamic-height]').each(function(){
 | 
						|
			var $this = $(this),
 | 
						|
				values = JSON.parse($this.data('dynamic-height').replace(/'/g,'"').replace(';',''))
 | 
						|
 | 
						|
			// XS
 | 
						|
			if( $window.width() < 576 ) {
 | 
						|
				$this.height( values[4] );
 | 
						|
			}
 | 
						|
 | 
						|
			// SM
 | 
						|
			if( $window.width() > 575 && $window.width() < 768 ) {
 | 
						|
				$this.height( values[3] );
 | 
						|
			}
 | 
						|
 | 
						|
			// MD
 | 
						|
			if( $window.width() > 767 && $window.width() < 992 ) {
 | 
						|
				$this.height( values[2] );
 | 
						|
			}
 | 
						|
 | 
						|
			// LG
 | 
						|
			if( $window.width() > 991 && $window.width() < 1200 ) {
 | 
						|
				$this.height( values[1] );
 | 
						|
			}
 | 
						|
 | 
						|
			// XS
 | 
						|
			if( $window.width() > 1199 ) {
 | 
						|
				$this.height( values[0] );
 | 
						|
			}
 | 
						|
		});
 | 
						|
	});
 | 
						|
 | 
						|
	// Mobile First Load
 | 
						|
	if( $window.width() < 992 ) {
 | 
						|
		$window.trigger('dynamic.height.resize');
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Video - Trigger Play
 | 
						|
	*/
 | 
						|
	if( $('[data-trigger-play-video]').length ) {
 | 
						|
		theme.fn.execOnceTroughEvent( '[data-trigger-play-video]', 'mouseover.trigger.play.video', function(){
 | 
						|
			var $video = $( $(this).data('trigger-play-video') );
 | 
						|
 | 
						|
			$(this).on('click', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				if( $(this).data('trigger-play-video-remove') == 'yes' ) {
 | 
						|
					$(this).animate({
 | 
						|
						opacity: 0
 | 
						|
					}, 300, function(){
 | 
						|
						$video[0].play();
 | 
						|
 | 
						|
						$(this).remove();
 | 
						|
					});
 | 
						|
				} else {
 | 
						|
					setTimeout(function(){
 | 
						|
						$video[0].play();
 | 
						|
					},300);
 | 
						|
				}
 | 
						|
			});
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Video - Auto Play
 | 
						|
	*/
 | 
						|
	if( $('video[data-auto-play]').length ) {
 | 
						|
		$(window).on('load', function(){
 | 
						|
			$('video[data-auto-play]').each(function(){
 | 
						|
				var $video = $(this);
 | 
						|
 | 
						|
				setTimeout(function(){
 | 
						|
					if( $( '#' + $video.attr('id') ).length ) {
 | 
						|
						if( $( '[data-trigger-play-video="#' + $video.attr('id') + '"]' ).data('trigger-play-video-remove') == 'yes' ) {
 | 
						|
							$( '[data-trigger-play-video="#' + $video.attr('id') + '"]' ).animate({
 | 
						|
								opacity: 0
 | 
						|
							}, 300, function(){
 | 
						|
								$video[0].play();
 | 
						|
 | 
						|
								$( '[data-trigger-play-video="#' + $video.attr('id') + '"]' ).remove();
 | 
						|
							});
 | 
						|
						} else {
 | 
						|
							setTimeout(function(){
 | 
						|
								$video[0].play();
 | 
						|
							},300);
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}, 100);
 | 
						|
 | 
						|
			});
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Remove min height after the load of page
 | 
						|
	*/
 | 
						|
	if( $('[data-remove-min-height]').length ) {
 | 
						|
		$(window).on('load', function(){
 | 
						|
			$('[data-remove-min-height]').each(function(){
 | 
						|
				$(this).css({
 | 
						|
					'min-height': 0
 | 
						|
				});
 | 
						|
			});
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Lazy Load Background Images (with lazySizes plugin)
 | 
						|
	*/
 | 
						|
	document.addEventListener('lazybeforeunveil', function(e){
 | 
						|
	    var bg = e.target.getAttribute('data-bg-src');
 | 
						|
	    if(bg) {
 | 
						|
	        e.target.style.backgroundImage = 'url(' + bg + ')';
 | 
						|
	    }
 | 
						|
	});
 | 
						|
 | 
						|
	/*
 | 
						|
	* Title Border
 | 
						|
	*/
 | 
						|
	if($('[data-title-border]').length) {
 | 
						|
 | 
						|
		var $pageHeaderTitleBorder = $('<span class="page-header-title-border"></span>'),
 | 
						|
			$pageHeaderTitle = $('[data-title-border]'),
 | 
						|
			$window = $(window);
 | 
						|
 | 
						|
		$pageHeaderTitle.before($pageHeaderTitleBorder);
 | 
						|
 | 
						|
		var setPageHeaderTitleBorderWidth = function() {
 | 
						|
			$pageHeaderTitleBorder.width($pageHeaderTitle.width());
 | 
						|
		}
 | 
						|
 | 
						|
		$window.afterResize(function(){
 | 
						|
			setPageHeaderTitleBorderWidth();
 | 
						|
		});
 | 
						|
 | 
						|
		setPageHeaderTitleBorderWidth();
 | 
						|
 | 
						|
		$pageHeaderTitleBorder.addClass('visible');
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Footer Reveal
 | 
						|
	*/
 | 
						|
	(function($) {
 | 
						|
		var $footerReveal = {
 | 
						|
			$wrapper: $('.footer-reveal'),
 | 
						|
			init: function() {
 | 
						|
				var self = this;
 | 
						|
 | 
						|
				self.build();
 | 
						|
				self.events();
 | 
						|
			},
 | 
						|
			build: function() {
 | 
						|
				var self = this, 
 | 
						|
					footer_height = self.$wrapper.outerHeight(true),
 | 
						|
					window_height = ( $(window).height() - $('.header-body').height() );
 | 
						|
 | 
						|
				if( footer_height > window_height ) {
 | 
						|
					$('#footer').removeClass('footer-reveal');
 | 
						|
					$('body').css('margin-bottom', 0);
 | 
						|
				} else {
 | 
						|
					$('#footer').addClass('footer-reveal');
 | 
						|
					$('body').css('margin-bottom', footer_height);
 | 
						|
				}
 | 
						|
 | 
						|
			},
 | 
						|
			events: function() {
 | 
						|
				var self = this,
 | 
						|
					$window = $(window);
 | 
						|
 | 
						|
				$window.on('load', function(){
 | 
						|
					$window.afterResize(function(){
 | 
						|
						self.build();
 | 
						|
					});
 | 
						|
				});
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		if( $('.footer-reveal').length ) {
 | 
						|
			$footerReveal.init();
 | 
						|
		}
 | 
						|
	})(jQuery);
 | 
						|
 | 
						|
	/*
 | 
						|
	* Re-Init Plugin
 | 
						|
	*/
 | 
						|
	if( $('[data-reinit-plugin]').length ) {
 | 
						|
		$('[data-reinit-plugin]').on('click', function(e) {
 | 
						|
			e.preventDefault();
 | 
						|
 | 
						|
			var pluginInstance = $(this).data('reinit-plugin'),
 | 
						|
				pluginFunction = $(this).data('reinit-plugin-function'),
 | 
						|
				pluginElement  = $(this).data('reinit-plugin-element'),
 | 
						|
				pluginOptions  = theme.fn.getOptions($(this).data('reinit-plugin-options'));
 | 
						|
 | 
						|
			$( pluginElement ).data( pluginInstance ).destroy();
 | 
						|
 | 
						|
			setTimeout(function(){
 | 
						|
				theme.fn.execPluginFunction(pluginFunction, $( pluginElement ), pluginOptions);	
 | 
						|
			}, 1000);
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Simple Copy To Clipboard
 | 
						|
	*/
 | 
						|
	if( $('[data-copy-to-clipboard]').length ) {
 | 
						|
		theme.fn.intObs( '[data-copy-to-clipboard]', function(){
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			$this.wrap( '<div class="copy-to-clipboard-wrapper position-relative"></div>' );
 | 
						|
 | 
						|
			var $copyButton = $('<a href="#" class="btn btn-primary btn-px-2 py-1 text-0 position-absolute top-8 right-8">COPY</a>');
 | 
						|
			$this.parent().prepend( $copyButton );
 | 
						|
 | 
						|
			$copyButton.on('click', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				var $btn       = $(this),
 | 
						|
					$temp = $('<textarea class="d-block opacity-0" style="height: 0;">');
 | 
						|
 | 
						|
				$btn.parent().append( $temp );
 | 
						|
 | 
						|
				$temp.val( $this.text() );
 | 
						|
					
 | 
						|
				$temp[0].select();
 | 
						|
				$temp[0].setSelectionRange(0, 99999);
 | 
						|
 | 
						|
				document.execCommand("copy");
 | 
						|
 | 
						|
				$btn.addClass('copied');
 | 
						|
				setTimeout(function(){
 | 
						|
					$btn.removeClass('copied');
 | 
						|
				}, 1000);
 | 
						|
 | 
						|
				$temp.remove();
 | 
						|
			});
 | 
						|
		}, {
 | 
						|
			rootMargin: '0px 0px 0px 0px'
 | 
						|
		} );
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Marquee
 | 
						|
	*/
 | 
						|
	if( $('.marquee').length && $.isFunction($.fn.marquee) ) {
 | 
						|
		$('.marquee').marquee({
 | 
						|
			duration: 5000,
 | 
						|
			gap: 0,
 | 
						|
			delayBeforeStart: 0,
 | 
						|
			direction: 'left',
 | 
						|
			duplicated: true
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	/*
 | 
						|
	* Style Switcher Open Loader Button
 | 
						|
	*/
 | 
						|
	if( $('.style-switcher-open-loader').length ) {
 | 
						|
 | 
						|
		$('.style-switcher-open-loader').on('click', function(e){
 | 
						|
			e.preventDefault();
 | 
						|
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			// Add Spinner to icon
 | 
						|
			$this.addClass('style-switcher-open-loader-loading');
 | 
						|
 | 
						|
			var	basePath = $(this).data('base-path'),
 | 
						|
				skinSrc = $(this).data('skin-src');
 | 
						|
 | 
						|
			var script1 = document.createElement("script");
 | 
						|
		  	script1.src = basePath + "master/style-switcher/style.switcher.localstorage.js";
 | 
						|
 | 
						|
		  	var script2 = document.createElement("script");
 | 
						|
		  	script2.src = basePath + "master/style-switcher/style.switcher.js";
 | 
						|
		  	script2.id = "styleSwitcherScript";
 | 
						|
		  	script2.setAttribute('data-base-path', basePath);
 | 
						|
		  	script2.setAttribute('data-skin-src', skinSrc);
 | 
						|
 | 
						|
		  	script2.onload = function() {
 | 
						|
		  		setTimeout(function(){
 | 
						|
		  			// Trigger a click to open the style switcher sidebar
 | 
						|
			  		function checkIfReady() {
 | 
						|
					    if( !$('.style-switcher-open').length ) {
 | 
						|
					       window.setTimeout(checkIfReady, 100);
 | 
						|
					    } else {
 | 
						|
					      $('.style-switcher-open').trigger('click');
 | 
						|
					    }
 | 
						|
					}
 | 
						|
					checkIfReady();
 | 
						|
 | 
						|
		  		}, 500);
 | 
						|
		  	}
 | 
						|
 | 
						|
		  	document.body.appendChild(script1);
 | 
						|
		  	document.body.appendChild(script2);	
 | 
						|
 | 
						|
		});
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
	})(jQuery);
 | 
						|
 | 
						|
// Animate
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__animate';
 | 
						|
 | 
						|
	var PluginAnimate = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginAnimate.defaults = {
 | 
						|
		accX: 0,
 | 
						|
		accY: -80,
 | 
						|
		delay: 100,
 | 
						|
		duration: '750ms',
 | 
						|
		minWindowWidth: 767,
 | 
						|
		forceAnimation: false,
 | 
						|
		flagClassOnly: false
 | 
						|
	};
 | 
						|
 | 
						|
	PluginAnimate.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginAnimate.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			// Flag Class Only
 | 
						|
			// - Useful for simple animations like hightlight
 | 
						|
			// - Less process and memory
 | 
						|
			if( self.options.flagClassOnly ) {
 | 
						|
				var delay = self.options.wrapper.attr('data-appear-animation-delay') ? self.options.wrapper.attr('data-appear-animation-delay') : self.options.delay;
 | 
						|
				
 | 
						|
				self.options.wrapper.css({
 | 
						|
					'animation-delay': delay + 'ms',
 | 
						|
					'transition-delay': delay + 'ms'
 | 
						|
				});
 | 
						|
				self.options.wrapper.addClass( self.options.wrapper.attr('data-appear-animation') );
 | 
						|
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			if($('body').hasClass('loading-overlay-showing')) {
 | 
						|
				$(window).on('loading.overlay.ready', function(){
 | 
						|
					self.animate();
 | 
						|
				});
 | 
						|
			} else {
 | 
						|
				self.animate();
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		animate: function() {
 | 
						|
			var self = this,
 | 
						|
				$el = this.options.wrapper,
 | 
						|
				delay = 0,
 | 
						|
				duration = this.options.duration,
 | 
						|
				elTopDistance = $el.offset().top,
 | 
						|
				windowTopDistance = $(window).scrollTop();
 | 
						|
 | 
						|
			// If has appear animation elements inside a SVG. 
 | 
						|
			// Intersection Observer API do not check elements inside SVG's, so we need initialize trough top parent SVG
 | 
						|
			if( $el.data('appear-animation-svg') ) {
 | 
						|
				$el.find('[data-appear-animation]').each(function(){
 | 
						|
					var $this = $(this),
 | 
						|
						opts;
 | 
						|
 | 
						|
					var pluginOptions = theme.fn.getOptions($this.data('plugin-options'));
 | 
						|
					if (pluginOptions)
 | 
						|
						opts = pluginOptions;
 | 
						|
 | 
						|
					$this.themePluginAnimate(opts);	
 | 
						|
				});
 | 
						|
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			// No animation at the first load of page. This is good for performance
 | 
						|
			if( self.options.firstLoadNoAnim ) {
 | 
						|
				$el.removeClass('appear-animation');
 | 
						|
 | 
						|
				// Inside Carousel
 | 
						|
				if( $el.closest('.owl-carousel').get(0) ) {
 | 
						|
					setTimeout(function(){
 | 
						|
						$el.closest('.owl-carousel').on('change.owl.carousel', function(){
 | 
						|
							self.options.firstLoadNoAnim = false;
 | 
						|
							$el.removeData('__animate');
 | 
						|
							$el.themePluginAnimate( self.options );
 | 
						|
						});
 | 
						|
					}, 500);
 | 
						|
				}
 | 
						|
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			$el.addClass('appear-animation animated');
 | 
						|
 | 
						|
			if (!$('html').hasClass('no-csstransitions') && $(window).width() > self.options.minWindowWidth && elTopDistance >= windowTopDistance || self.options.forceAnimation == true) {
 | 
						|
				delay = ($el.attr('data-appear-animation-delay') ? $el.attr('data-appear-animation-delay') : self.options.delay);
 | 
						|
				duration = ($el.attr('data-appear-animation-duration') ? $el.attr('data-appear-animation-duration') : self.options.duration);
 | 
						|
 | 
						|
				if (duration != '750ms') {
 | 
						|
					$el.css('animation-duration', duration);
 | 
						|
				}
 | 
						|
 | 
						|
				$el.css('animation-delay', delay + 'ms');
 | 
						|
				$el.addClass($el.attr('data-appear-animation') + ' appear-animation-visible');
 | 
						|
				
 | 
						|
				$el.trigger('animation:show');
 | 
						|
 | 
						|
			} else {
 | 
						|
				$el.addClass('appear-animation-visible');
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginAnimate: PluginAnimate
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginAnimate = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginAnimate($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	};
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Animated Content
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__animatedContent';
 | 
						|
 | 
						|
	var PluginAnimatedContent = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginAnimatedContent.defaults = {
 | 
						|
		contentType: 'letter',
 | 
						|
		animationName: 'fadeIn',
 | 
						|
		animationSpeed: 50,
 | 
						|
		startDelay: 500,
 | 
						|
		minWindowWidth: 768,
 | 
						|
		letterClass: '',
 | 
						|
		wordClass: '',
 | 
						|
		wrapperClass: ''
 | 
						|
	};
 | 
						|
 | 
						|
	PluginAnimatedContent.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
			this.initialText = $el.text();
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build()
 | 
						|
				.events();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginAnimatedContent.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self    = this;
 | 
						|
 | 
						|
			if( $(window).width() < self.options.minWindowWidth ) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			if( self.options.firstLoadNoAnim ) {
 | 
						|
				self.$el.css({
 | 
						|
					visibility: 'visible'
 | 
						|
				});
 | 
						|
 | 
						|
				// Inside Carousel
 | 
						|
				if( self.$el.closest('.owl-carousel').get(0) ) {
 | 
						|
					setTimeout(function(){
 | 
						|
						self.$el.closest('.owl-carousel').on('change.owl.carousel', function(){
 | 
						|
							self.options.firstLoadNoAnim = false;
 | 
						|
							self.build();
 | 
						|
						});
 | 
						|
					}, 500);
 | 
						|
				}
 | 
						|
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			// Set Min Height to avoid flicking issues
 | 
						|
			self.setMinHeight();
 | 
						|
 | 
						|
			// Letter
 | 
						|
			if( self.options.contentType == 'letter' ) {
 | 
						|
 | 
						|
				self.$el.addClass('initialized');
 | 
						|
 | 
						|
				var letters = self.$el.text().split('');
 | 
						|
 | 
						|
				self.$el.text('');
 | 
						|
 | 
						|
				// Type Writer
 | 
						|
				if( self.options.animationName == 'typeWriter' ) {
 | 
						|
					self.$el.append( '<span class="letters-wrapper"></span><span class="typeWriter"></pre>' );
 | 
						|
 | 
						|
					var index = 0;
 | 
						|
 | 
						|
					setTimeout(function(){
 | 
						|
 | 
						|
						var timeout = function(){
 | 
						|
							var st = setTimeout(function(){
 | 
						|
								var letter = letters[index];
 | 
						|
								
 | 
						|
								self.$el.find('.letters-wrapper').append( '<span class="letter '+ ( self.options.letterClass ? self.options.letterClass + ' ' : '' ) +'">' + letter + '</span>' );
 | 
						|
 | 
						|
								index++;
 | 
						|
								timeout();
 | 
						|
							}, self.options.animationSpeed);
 | 
						|
 | 
						|
							if( index >= letters.length ) {
 | 
						|
								clearTimeout(st);
 | 
						|
							}
 | 
						|
						};
 | 
						|
						timeout();
 | 
						|
 | 
						|
					}, self.options.startDelay);
 | 
						|
 | 
						|
				// Class Animation
 | 
						|
				} else {
 | 
						|
					setTimeout(function(){
 | 
						|
						for( var i = 0; i < letters.length; i++ ) {
 | 
						|
							var letter = letters[i];
 | 
						|
							
 | 
						|
							self.$el.append( '<span class="animated-letters-wrapper ' + self.options.wrapperClass + '"><span class="animated-letters-item letter '+ ( self.options.letterClass ? self.options.letterClass + ' ' : '' ) + self.options.animationName +' animated" style="animation-delay: '+ ( i * self.options.animationSpeed ) +'ms;">' + ( letter == ' ' ? ' ' : letter ) + '</span></span>' );
 | 
						|
		
 | 
						|
						}
 | 
						|
					}, self.options.startDelay);
 | 
						|
				}
 | 
						|
 | 
						|
			// Words
 | 
						|
			} else if( self.options.contentType == 'word' ) {
 | 
						|
 | 
						|
				var words = self.$el.text().split(" "),
 | 
						|
					delay = self.options.startDelay;
 | 
						|
				
 | 
						|
				self.$el.empty();
 | 
						|
 | 
						|
				$.each(words, function(i, v) {
 | 
						|
					self.$el.append( $('<span class="animated-words-wrapper ' + self.options.wrapperClass + '">').html('<span class="animated-words-item ' + self.options.wordClass + ' appear-animation" data-appear-animation="' + self.options.animationName + '" data-appear-animation-delay="' + delay + '">' + v + ' </span>') );
 | 
						|
					delay = delay + self.options.animationSpeed;
 | 
						|
				});
 | 
						|
 | 
						|
				if ($.isFunction($.fn['themePluginAnimate']) && $('.animated-words-item[data-appear-animation]').length) {
 | 
						|
					theme.fn.dynIntObsInit( '.animated-words-item[data-appear-animation]', 'themePluginAnimate', theme.PluginAnimate.defaults );
 | 
						|
				}
 | 
						|
 | 
						|
				self.$el.addClass('initialized');
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setMinHeight: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			// if it's inside carousel
 | 
						|
			if( self.$el.closest('.owl-carousel').get(0) ) {
 | 
						|
				self.$el.closest('.owl-carousel').addClass('d-block');
 | 
						|
				self.$el.css( 'min-height', self.$el.height() );
 | 
						|
				self.$el.closest('.owl-carousel').removeClass('d-block');
 | 
						|
			} else {
 | 
						|
				self.$el.css( 'min-height', self.$el.height() );
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		destroy: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			self.$el
 | 
						|
				.html( self.initialText )
 | 
						|
				.css( 'min-height', '' );
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		events: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			// Destroy
 | 
						|
			self.$el.on('animated.letters.destroy', function(){
 | 
						|
				self.destroy();
 | 
						|
			});
 | 
						|
 | 
						|
			// Initialize
 | 
						|
			self.$el.on('animated.letters.initialize', function(){
 | 
						|
				self.build();
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginAnimatedContent: PluginAnimatedContent
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginAnimatedContent = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginAnimatedContent($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Before / After
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__beforeafter';
 | 
						|
 | 
						|
	var PluginBeforeAfter = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginBeforeAfter.defaults = {
 | 
						|
		default_offset_pct: 0.5,
 | 
						|
		orientation: 'horizontal',
 | 
						|
		before_label: 'Before',
 | 
						|
		after_label: 'After',
 | 
						|
		no_overlay: false,
 | 
						|
		move_slider_on_hover: false,
 | 
						|
		move_with_handle_only: true,
 | 
						|
		click_to_move: false
 | 
						|
	};
 | 
						|
 | 
						|
	PluginBeforeAfter.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginBeforeAfter.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
 | 
						|
			if (!($.isFunction($.fn.twentytwenty))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			self.options.wrapper
 | 
						|
				.twentytwenty(self.options);
 | 
						|
 | 
						|
			return this;
 | 
						|
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginBeforeAfter: PluginBeforeAfter
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginBeforeAfter = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginBeforeAfter($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Carousel Light
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__carouselLight';
 | 
						|
 | 
						|
	var PluginCarouselLight = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginCarouselLight.defaults = {
 | 
						|
		autoplay: true,
 | 
						|
		autoplayTimeout: 7000,
 | 
						|
		disableAutoPlayOnClick: true
 | 
						|
	};
 | 
						|
 | 
						|
	PluginCarouselLight.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
			this.clickFlag = true;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build()
 | 
						|
				.owlNav()
 | 
						|
				.owlDots()
 | 
						|
				.autoPlay()
 | 
						|
				.events();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginCarouselLight.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			self.$el
 | 
						|
				.css('opacity', 1)
 | 
						|
				.find('.owl-item:first-child')
 | 
						|
				.addClass('active');
 | 
						|
 | 
						|
			self.$el.trigger('initialized.owl.carousel');
 | 
						|
 | 
						|
			// Carousel Navigate By ID and item index
 | 
						|
			self.carouselNavigate();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		changeSlide: function( $nextSlide ) {
 | 
						|
			var self = this,
 | 
						|
				$prevSlide = self.$el.find('.owl-item.active');
 | 
						|
 | 
						|
			self.$el.find('.owl-item.active').addClass('removing');
 | 
						|
 | 
						|
			$prevSlide
 | 
						|
				.removeClass('fadeIn')
 | 
						|
				.addClass( 'fadeOut animated' );
 | 
						|
 | 
						|
			setTimeout(function(){
 | 
						|
				setTimeout(function(){
 | 
						|
					$prevSlide.removeClass('active');
 | 
						|
				}, 400);
 | 
						|
 | 
						|
				$nextSlide
 | 
						|
					.addClass('active')
 | 
						|
					.removeClass('fadeOut')
 | 
						|
					.addClass( 'fadeIn animated' );
 | 
						|
 | 
						|
			}, 200);
 | 
						|
 | 
						|
			// Dots
 | 
						|
			self.$el
 | 
						|
				.find('.owl-dot')
 | 
						|
				.removeClass('active')
 | 
						|
				.eq( $nextSlide.index() )
 | 
						|
				.addClass('active');
 | 
						|
 | 
						|
			self.$el.trigger({
 | 
						|
				type: 'change.owl.carousel',
 | 
						|
				nextSlideIndex: $nextSlide.index(),
 | 
						|
				prevSlideIndex: $prevSlide.index()
 | 
						|
			});
 | 
						|
 | 
						|
			setTimeout(function(){
 | 
						|
				self.$el.trigger({
 | 
						|
					type: 'changed.owl.carousel',
 | 
						|
					nextSlideIndex: $nextSlide.index(),
 | 
						|
					prevSlideIndex: $prevSlide.index()
 | 
						|
				});
 | 
						|
			}, 500);
 | 
						|
		},
 | 
						|
 | 
						|
		owlNav: function() {
 | 
						|
			var self = this,
 | 
						|
				$owlNext = self.$el.find('.owl-next'),
 | 
						|
				$owlPrev = self.$el.find('.owl-prev');
 | 
						|
 | 
						|
			$owlPrev.on('click', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				if( self.options.disableAutoPlayOnClick ) {
 | 
						|
					window.clearInterval(self.autoPlayInterval);
 | 
						|
				}
 | 
						|
 | 
						|
				if( self.avoidMultipleClicks() ) {
 | 
						|
					return false;
 | 
						|
				}
 | 
						|
 | 
						|
				self.owlPrev();
 | 
						|
			});
 | 
						|
 | 
						|
			$owlNext.on('click', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				if( self.options.disableAutoPlayOnClick ) {
 | 
						|
					window.clearInterval(self.autoPlayInterval);
 | 
						|
				}
 | 
						|
 | 
						|
				if( self.avoidMultipleClicks() ) {
 | 
						|
					return false;
 | 
						|
				}
 | 
						|
 | 
						|
				self.owlNext();
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		owlDots: function(){
 | 
						|
			var self = this,
 | 
						|
				$owlDot = self.$el.find('.owl-dot');
 | 
						|
 | 
						|
			$owlDot.on('click', function(e){
 | 
						|
				$this = $(this);
 | 
						|
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				if( self.options.disableAutoPlayOnClick ) {
 | 
						|
					window.clearInterval(self.autoPlayInterval);
 | 
						|
				}
 | 
						|
 | 
						|
				if( self.avoidMultipleClicks() ) {
 | 
						|
					return false;
 | 
						|
				}
 | 
						|
 | 
						|
				var dotIndex = $(this).index();
 | 
						|
 | 
						|
				// Do nothing if respective dot slide is active/showing
 | 
						|
				if( $this.hasClass('active') ) {
 | 
						|
					return false;
 | 
						|
				}
 | 
						|
 | 
						|
				self.changeSlide( self.$el.find('.owl-item').eq( dotIndex ) );
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		owlPrev: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if( self.$el.find('.owl-item.active').prev().get(0) ) {
 | 
						|
				self.changeSlide( self.$el.find('.owl-item.active').prev() );
 | 
						|
			} else {
 | 
						|
				self.changeSlide( self.$el.find('.owl-item:last-child') );
 | 
						|
			}
 | 
						|
		},
 | 
						|
 | 
						|
		owlNext: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if( self.$el.find('.owl-item.active').next().get(0) ) {
 | 
						|
				self.changeSlide( self.$el.find('.owl-item.active').next() );
 | 
						|
			} else {
 | 
						|
				self.changeSlide( self.$el.find('.owl-item').eq(0) );
 | 
						|
			}
 | 
						|
		},
 | 
						|
 | 
						|
		avoidMultipleClicks: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if( !self.clickFlag ) {
 | 
						|
				return true;
 | 
						|
			}
 | 
						|
 | 
						|
			if( self.clickFlag ) {
 | 
						|
				self.clickFlag = false;
 | 
						|
				setTimeout(function(){
 | 
						|
					self.clickFlag = true; 
 | 
						|
				}, 1000);
 | 
						|
			}
 | 
						|
 | 
						|
			return false;
 | 
						|
		},
 | 
						|
 | 
						|
		autoPlay: function(){
 | 
						|
			var self = this,
 | 
						|
				$el  = this.options.wrapper;
 | 
						|
 | 
						|
			if( self.options.autoplay ) {
 | 
						|
				self.autoPlayInterval = window.setInterval(function() {
 | 
						|
					self.owlNext();
 | 
						|
				}, self.options.autoplayTimeout);
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		carouselNavigate: function() {
 | 
						|
			var self      = this,
 | 
						|
				$el       = this.options.wrapper,
 | 
						|
				$carousel = $el;
 | 
						|
 | 
						|
			if( $('[data-carousel-navigate]').get(0) ) {
 | 
						|
				$('[data-carousel-navigate-id="#'+ $el.attr('id') +'"]').each(function(){
 | 
						|
					var $this = $(this),
 | 
						|
						hasCarousel = $( $this.data('carousel-navigate-id') ).get(0),
 | 
						|
						toIndex = $this.data('carousel-navigate-to');
 | 
						|
 | 
						|
					if( hasCarousel ) {
 | 
						|
 | 
						|
						$this.on('click', function(){
 | 
						|
 | 
						|
							if( self.options.disableAutoPlayOnClick ) {
 | 
						|
								window.clearInterval(self.autoPlayInterval);
 | 
						|
							}
 | 
						|
							
 | 
						|
							self.changeSlide( self.$el.find('.owl-item').eq( parseInt(toIndex) - 1 ) );
 | 
						|
						});
 | 
						|
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				$el.on('change.owl.carousel', function(e){
 | 
						|
					$('[data-carousel-navigate-id="#'+ $el.attr('id') +'"]').removeClass('active');
 | 
						|
				});
 | 
						|
 | 
						|
				$el.on('changed.owl.carousel', function(e){
 | 
						|
					$('[data-carousel-navigate-id="#'+ $el.attr('id') +'"][data-carousel-navigate-to="'+ ( e.nextSlideIndex + 1 ) +'"]').addClass('active');
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		events: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			self.$el.on('change.owl.carousel', function(event) {
 | 
						|
 | 
						|
				// Hide elements inside carousel
 | 
						|
			    self.$el.find('[data-appear-animation]:not(.background-image-wrapper), [data-plugin-animated-letters]').addClass('invisible');
 | 
						|
 | 
						|
			    // Animated Letters
 | 
						|
			    self.$el.find('[data-plugin-animated-letters]').trigger('animated.letters.destroy');
 | 
						|
 | 
						|
			    // Remove "d-none" class before show the element. This is useful when using background images inside a carousel. Like ken burns effect
 | 
						|
			    self.$el.find('.owl-item:not(.active) [data-carousel-onchange-show]').removeClass('d-none');
 | 
						|
 | 
						|
			});
 | 
						|
 | 
						|
			self.$el.on('changed.owl.carousel', function(event) {
 | 
						|
				setTimeout(function(){
 | 
						|
 | 
						|
				    // Appear Animation
 | 
						|
				    if( self.$el.find('.owl-item.cloned [data-appear-animation]').get(0) ) {
 | 
						|
				    	self.$el.find('.owl-item.cloned [data-appear-animation]').each(function() {
 | 
						|
							var $this = $(this),
 | 
						|
								opts;
 | 
						|
 | 
						|
							var pluginOptions = theme.fn.getOptions($this.data('plugin-options'));
 | 
						|
							if (pluginOptions)
 | 
						|
								opts = pluginOptions;
 | 
						|
 | 
						|
							$this.themePluginAnimate(opts);
 | 
						|
						});
 | 
						|
				    }
 | 
						|
 | 
						|
					// Show elements inside carousel
 | 
						|
				    self.$el.find('.owl-item.active [data-appear-animation]:not(.background-image-wrapper), [data-plugin-animated-letters]').removeClass('invisible');
 | 
						|
 | 
						|
				    // Animated Letters
 | 
						|
				    self.$el.find('.owl-item.active [data-plugin-animated-letters]').trigger('animated.letters.initialize');
 | 
						|
 | 
						|
				    // Background Video
 | 
						|
				    self.$el.find('.owl-item.cloned.active [data-plugin-video-background]').trigger('video.background.initialize');
 | 
						|
 | 
						|
				}, 500);
 | 
						|
			    
 | 
						|
			});
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginCarouselLight: PluginCarouselLight
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginCarouselLight = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginCarouselLight($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	};
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Carousel
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__carousel';
 | 
						|
 | 
						|
	var PluginCarousel = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginCarousel.defaults = {
 | 
						|
		loop: true,
 | 
						|
		responsive: {
 | 
						|
			0: {
 | 
						|
				items: 1
 | 
						|
			},
 | 
						|
			479: {
 | 
						|
				items: 1
 | 
						|
			},
 | 
						|
			768: {
 | 
						|
				items: 2
 | 
						|
			},
 | 
						|
			979: {
 | 
						|
				items: 3
 | 
						|
			},
 | 
						|
			1199: {
 | 
						|
				items: 4
 | 
						|
			}
 | 
						|
		},
 | 
						|
		navText: [],
 | 
						|
		refresh: false
 | 
						|
	};
 | 
						|
 | 
						|
	PluginCarousel.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			// If has data-icon inside, initialize only after icons get rendered
 | 
						|
			// Prevent flicking issues
 | 
						|
			if( $el.find('[data-icon]').get(0) ) {
 | 
						|
				var self = this;
 | 
						|
 | 
						|
				$(window).on('icon.rendered', function(){
 | 
						|
					if ($el.data(instanceName)) {
 | 
						|
						return this;
 | 
						|
					}
 | 
						|
 | 
						|
					setTimeout(function(){
 | 
						|
						self
 | 
						|
							.setData()
 | 
						|
							.setOptions(opts)
 | 
						|
							.build();
 | 
						|
					}, 1000);
 | 
						|
				});
 | 
						|
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginCarousel.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			if (!($.isFunction($.fn.owlCarousel))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this,
 | 
						|
				$el = this.options.wrapper;
 | 
						|
 | 
						|
			// Add Theme Class
 | 
						|
			$el.addClass('owl-theme');
 | 
						|
 | 
						|
			// Add Loading
 | 
						|
			$el.addClass('owl-loading');
 | 
						|
 | 
						|
			// Force RTL according to HTML dir attribute
 | 
						|
			if ($('html').attr('dir') == 'rtl') {
 | 
						|
				this.options = $.extend(true, {}, this.options, {
 | 
						|
					rtl: true
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			if (this.options.items == 1) {
 | 
						|
				this.options.responsive = {}
 | 
						|
			}
 | 
						|
 | 
						|
			if (this.options.items > 4) {
 | 
						|
				this.options = $.extend(true, {}, this.options, {
 | 
						|
					responsive: {
 | 
						|
						1199: {
 | 
						|
							items: this.options.items
 | 
						|
						}
 | 
						|
					}
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			// Auto Height Fixes
 | 
						|
			if (this.options.autoHeight) {
 | 
						|
				var itemsHeight = [];
 | 
						|
 | 
						|
				$el.find('.owl-item').each(function(){
 | 
						|
					if( $(this).hasClass('active') ) {
 | 
						|
						itemsHeight.push( $(this).height() );
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				$(window).afterResize(function() {
 | 
						|
					$el.find('.owl-stage-outer').height( Math.max.apply(null, itemsHeight) );
 | 
						|
				});
 | 
						|
 | 
						|
				$(window).on('load', function() {
 | 
						|
					$el.find('.owl-stage-outer').height( Math.max.apply(null, itemsHeight) );
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			// Initialize OwlCarousel
 | 
						|
			$el.owlCarousel(this.options).addClass('owl-carousel-init animated fadeIn');
 | 
						|
 | 
						|
			// Remove "animated fadeIn" class to prevent conflicts
 | 
						|
			setTimeout(function(){
 | 
						|
				$el.removeClass('animated fadeIn');
 | 
						|
			}, 1000);
 | 
						|
 | 
						|
			// Owl Carousel Wrapper
 | 
						|
			if( $el.closest('.owl-carousel-wrapper').get(0) ) {
 | 
						|
				setTimeout(function(){
 | 
						|
					$el.closest('.owl-carousel-wrapper').css({
 | 
						|
						height: ''
 | 
						|
					});
 | 
						|
				}, 500);
 | 
						|
			}
 | 
						|
 | 
						|
			// Owl Carousel Loader
 | 
						|
			if( $el.prev().hasClass('owl-carousel-loader') ) {
 | 
						|
				$el.prev().remove();
 | 
						|
			}
 | 
						|
 | 
						|
			// Nav Offset
 | 
						|
			self.navigationOffsets();
 | 
						|
 | 
						|
			// Nav Outside
 | 
						|
			if( $el.hasClass('nav-outside') ) {
 | 
						|
				$(window).on('owl.carousel.nav.outside', function(){
 | 
						|
					if( $(window).width() < 992 ) {
 | 
						|
						self.options.stagePadding = 40;
 | 
						|
						$el.addClass('stage-margin');
 | 
						|
					} else {
 | 
						|
						self.options.stagePadding = 0;
 | 
						|
						$el.removeClass('stage-margin');
 | 
						|
					}
 | 
						|
 | 
						|
					$el.owlCarousel('destroy').owlCarousel( self.options );
 | 
						|
 | 
						|
					// Nav Offset
 | 
						|
					self.navigationOffsets();
 | 
						|
				});
 | 
						|
 | 
						|
				// Window Resize
 | 
						|
				$(window).on('load', function(){
 | 
						|
					$(window).afterResize(function(){
 | 
						|
						$(window).trigger('owl.carousel.nav.outside');
 | 
						|
					});
 | 
						|
				});
 | 
						|
 | 
						|
				// First Load
 | 
						|
				$(window).trigger('owl.carousel.nav.outside');
 | 
						|
			}
 | 
						|
 | 
						|
			// Nav style 5 (SVG Arrows)
 | 
						|
			if( $el.hasClass('nav-svg-arrows-1') ) {
 | 
						|
				var svg_arrow = '' +
 | 
						|
					'<svg version="1.1" viewBox="0 0 15.698 8.706" width="17" xml:space="preserve" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">' +
 | 
						|
						'<polygon stroke="#212121" stroke-width="0.1" fill="#212121" points="11.354,0 10.646,0.706 13.786,3.853 0,3.853 0,4.853 13.786,4.853 10.646,8 11.354,8.706 15.698,4.353 "/>' +
 | 
						|
					'</svg>';
 | 
						|
 | 
						|
				$el.find('.owl-next, .owl-prev').append( svg_arrow );
 | 
						|
			}
 | 
						|
 | 
						|
			// Sync
 | 
						|
			if( $el.attr('data-sync') ) {
 | 
						|
				$el.on('change.owl.carousel', function(event) {
 | 
						|
					if (event.namespace && event.property.name === 'position') {
 | 
						|
					    var target = event.relatedTarget.relative(event.property.value, true);
 | 
						|
					    $( $el.data('sync') ).owlCarousel('to', target, 300, true);				        
 | 
						|
				  	}
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			// Carousel Center Active Item
 | 
						|
			if( $el.hasClass('carousel-center-active-item') ) {
 | 
						|
				var itemsActive    = $el.find('.owl-item.active'),
 | 
						|
					indexCenter    = Math.floor( ($el.find('.owl-item.active').length - 1) / 2 ),
 | 
						|
					itemCenter     = itemsActive.eq(indexCenter);
 | 
						|
 | 
						|
				itemCenter.addClass('current');
 | 
						|
 | 
						|
				$el.on('change.owl.carousel', function(event) {
 | 
						|
				  	$el.find('.owl-item').removeClass('current');
 | 
						|
					
 | 
						|
					setTimeout(function(){
 | 
						|
					  	var itemsActive    = $el.find('.owl-item.active'),
 | 
						|
					  		indexCenter    = Math.floor( ($el.find('.owl-item.active').length - 1) / 2 ),
 | 
						|
					  		itemCenter     = itemsActive.eq(indexCenter);
 | 
						|
 | 
						|
					  	itemCenter.addClass('current');
 | 
						|
					}, 100);
 | 
						|
				});
 | 
						|
 | 
						|
				// Refresh
 | 
						|
				$el.trigger('refresh.owl.carousel');
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
			// AnimateIn / AnimateOut Fix
 | 
						|
			if( self.options.animateIn || self.options.animateOut ) {
 | 
						|
				$el.on('change.owl.carousel', function(event) {
 | 
						|
 | 
						|
					// Hide elements inside carousel
 | 
						|
				    $el.find('[data-appear-animation], [data-plugin-animated-letters]').addClass('d-none');
 | 
						|
 | 
						|
				    // Animated Letters
 | 
						|
				    $el.find('[data-plugin-animated-letters]').trigger('animated.letters.destroy');
 | 
						|
 | 
						|
				    // Remove "d-none" class before show the element. This is useful when using background images inside a carousel. Like ken burns effect
 | 
						|
				    $el.find('.owl-item:not(.active) [data-carousel-onchange-show]').removeClass('d-none');
 | 
						|
 | 
						|
				});
 | 
						|
 | 
						|
				$el.on('changed.owl.carousel', function(event) {
 | 
						|
					setTimeout(function(){
 | 
						|
 | 
						|
					    // Appear Animation
 | 
						|
				    	$el.find('[data-appear-animation]').each(function() {
 | 
						|
							var $this = $(this),
 | 
						|
								opts;
 | 
						|
 | 
						|
							var pluginOptions = theme.fn.getOptions($this.data('plugin-options'));
 | 
						|
							if (pluginOptions)
 | 
						|
								opts = pluginOptions;
 | 
						|
 | 
						|
							$this.themePluginAnimate(opts);
 | 
						|
						});
 | 
						|
 | 
						|
						// Show elements inside carousel
 | 
						|
					    $el.find('.owl-item.active [data-appear-animation], [data-plugin-animated-letters]').removeClass('d-none');
 | 
						|
 | 
						|
					    // Animated Letters
 | 
						|
					    $el.find('.owl-item.active [data-plugin-animated-letters]').trigger('animated.letters.initialize');
 | 
						|
 | 
						|
					    // Background Video
 | 
						|
					    $el.find('.owl-item.cloned.active [data-plugin-video-background]').trigger('video.background.initialize');
 | 
						|
 | 
						|
					}, 10);
 | 
						|
				    
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			// data-icon inside carousel
 | 
						|
			if( $el.find('[data-icon]').length ) {
 | 
						|
				$el.on('change.owl.carousel drag.owl.carousel', function(){
 | 
						|
					$el.find('.owl-item.cloned [data-icon]').each(function(){
 | 
						|
						var $this = $(this),
 | 
						|
							opts;
 | 
						|
 | 
						|
						var pluginOptions = theme.fn.getOptions($this.data('plugin-options'));
 | 
						|
						if (pluginOptions)
 | 
						|
							opts = pluginOptions;
 | 
						|
 | 
						|
						$this.themePluginIcon(opts);	
 | 
						|
					});
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			// Render Background Videos inside carousel. Just a trigger on window is sufficient to render
 | 
						|
			if( $el.find('[data-plugin-video-background]').get(0) ) {
 | 
						|
				$(window).resize();
 | 
						|
			}
 | 
						|
 | 
						|
			// Remove Loading
 | 
						|
			$el.removeClass('owl-loading');
 | 
						|
 | 
						|
			// Remove Height
 | 
						|
			$el.css('height', 'auto');
 | 
						|
 | 
						|
			// Carousel Navigate By ID and item index
 | 
						|
			self.carouselNavigate();
 | 
						|
 | 
						|
			// Refresh Carousel
 | 
						|
			if( self.options.refresh ) {
 | 
						|
				$el.owlCarousel('refresh');
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		navigationOffsets: function() {
 | 
						|
			var self 			 = this,
 | 
						|
				$el  			 = this.options.wrapper,
 | 
						|
				navHasTransform  = $el.find('.owl-nav').css('transform') == 'none' ? false : true,
 | 
						|
				dotsHasTransform = $el.find('.owl-dots').css('transform') == 'none' ? false : true;
 | 
						|
 | 
						|
			// ************* NAV *****************
 | 
						|
			// Nav Offset - Horizontal
 | 
						|
			if( self.options.navHorizontalOffset && !self.options.navVerticalOffset ) {
 | 
						|
				if( !navHasTransform ) {
 | 
						|
					$el.find('.owl-nav').css({
 | 
						|
						transform: 'translate3d('+ self.options.navHorizontalOffset +', 0, 0)'
 | 
						|
					});
 | 
						|
				} else {
 | 
						|
					$el.find('.owl-nav').css({
 | 
						|
						left: self.options.navHorizontalOffset
 | 
						|
					});
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			// Nav Offset - Vertical
 | 
						|
			if( self.options.navVerticalOffset && !self.options.navHorizontalOffset ) {
 | 
						|
				if( !navHasTransform ) {
 | 
						|
					$el.find('.owl-nav').css({
 | 
						|
						transform: 'translate3d(0, '+ self.options.navVerticalOffset +', 0)'
 | 
						|
					});
 | 
						|
				} else {
 | 
						|
					$el.find('.owl-nav').css({
 | 
						|
						top: 'calc( 50% - '+ self.options.navVerticalOffset +' )'
 | 
						|
					});
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			// Nav Offset - Horizontal & Vertical
 | 
						|
			if( self.options.navVerticalOffset && self.options.navHorizontalOffset ) {
 | 
						|
				if( !navHasTransform ) {
 | 
						|
					$el.find('.owl-nav').css({
 | 
						|
						transform: 'translate3d('+ self.options.navHorizontalOffset +', '+ self.options.navVerticalOffset +', 0)'
 | 
						|
					});
 | 
						|
				} else {
 | 
						|
					$el.find('.owl-nav').css({
 | 
						|
						top: 'calc( 50% - '+ self.options.navVerticalOffset +' )',
 | 
						|
						left: self.options.navHorizontalOffset
 | 
						|
					});
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			// ********** DOTS *********************
 | 
						|
			// Dots Offset - Horizontal
 | 
						|
			if( self.options.dotsHorizontalOffset && !self.options.dotsVerticalOffset ) {
 | 
						|
				$el.find('.owl-dots').css({
 | 
						|
					transform: 'translate3d('+ self.options.dotsHorizontalOffset +', 0, 0)'
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			// Dots Offset - Vertical
 | 
						|
			if( self.options.dotsVerticalOffset && !self.options.dotsHorizontalOffset ) {
 | 
						|
				if( !dotsHasTransform ) {
 | 
						|
					$el.find('.owl-dots').css({
 | 
						|
						transform: 'translate3d(0, '+ self.options.dotsVerticalOffset +', 0)'
 | 
						|
					});
 | 
						|
				} else {
 | 
						|
					$el.find('.owl-dots').css({
 | 
						|
						top: 'calc( 50% - '+ self.options.dotsVerticalOffset +' )'
 | 
						|
					});
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			// Dots Offset - Horizontal & Vertical
 | 
						|
			if( self.options.dotsVerticalOffset && self.options.dotsHorizontalOffset ) {
 | 
						|
				$el.find('.owl-dots').css({
 | 
						|
					transform: 'translate3d('+ self.options.dotsHorizontalOffset +', '+ self.options.dotsVerticalOffset +', 0)'
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		carouselNavigate: function() {
 | 
						|
			var self      = this,
 | 
						|
				$el       = this.options.wrapper,
 | 
						|
				$carousel = $el.data('owl.carousel');
 | 
						|
 | 
						|
			if( $('[data-carousel-navigate]').get(0) ) {
 | 
						|
				$('[data-carousel-navigate-id="#'+ $el.attr('id') +'"]').each(function(){
 | 
						|
					var $this = $(this),
 | 
						|
						hasCarousel = $( $this.data('carousel-navigate-id') ).get(0),
 | 
						|
						toIndex = $this.data('carousel-navigate-to');
 | 
						|
 | 
						|
					if( hasCarousel ) {
 | 
						|
 | 
						|
						$this.on('click', function(){
 | 
						|
							$carousel.to( parseInt(toIndex) - 1 );
 | 
						|
						});
 | 
						|
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				$el.on('change.owl.carousel', function(){
 | 
						|
					$('[data-carousel-navigate-id="#'+ $el.attr('id') +'"]').removeClass('active');
 | 
						|
				});
 | 
						|
 | 
						|
				$el.on('changed.owl.carousel', function(e){
 | 
						|
					$('[data-carousel-navigate-id="#'+ $el.attr('id') +'"][data-carousel-navigate-to="'+ ( e.item.index + 1 ) +'"]').addClass('active');
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginCarousel: PluginCarousel
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginCarousel = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginCarousel($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Chart Circular
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__chartCircular';
 | 
						|
 | 
						|
	var PluginChartCircular = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginChartCircular.defaults = {
 | 
						|
		accX: 0,
 | 
						|
		accY: -150,
 | 
						|
		delay: 1,
 | 
						|
		barColor: '#0088CC',
 | 
						|
		trackColor: '#f2f2f2',
 | 
						|
		scaleColor: false,
 | 
						|
		scaleLength: 5,
 | 
						|
		lineCap: 'round',
 | 
						|
		lineWidth: 13,
 | 
						|
		size: 175,
 | 
						|
		rotate: 0,
 | 
						|
		animate: ({
 | 
						|
			duration: 2500,
 | 
						|
			enabled: true
 | 
						|
		})
 | 
						|
	};
 | 
						|
 | 
						|
	PluginChartCircular.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginChartCircular.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			if (!($.isFunction($.fn.easyPieChart))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this,
 | 
						|
				$el = this.options.wrapper,
 | 
						|
				value = ($el.attr('data-percent') ? $el.attr('data-percent') : 0),
 | 
						|
				percentEl = $el.find('.percent');
 | 
						|
 | 
						|
			$.extend(true, self.options, {
 | 
						|
				onStep: function(from, to, currentValue) {
 | 
						|
					percentEl.html(parseInt(currentValue));
 | 
						|
				}
 | 
						|
			});
 | 
						|
 | 
						|
			$el.attr('data-percent', 0);
 | 
						|
 | 
						|
			$el.easyPieChart(self.options);
 | 
						|
 | 
						|
			setTimeout(function() {
 | 
						|
 | 
						|
				$el.data('easyPieChart').update(value);
 | 
						|
				$el.attr('data-percent', value);
 | 
						|
 | 
						|
			}, self.options.delay);
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginChartCircular: PluginChartCircular
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginChartCircular = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginChartCircular($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Countdown
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__countdown';
 | 
						|
 | 
						|
	var PluginCountdown = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginCountdown.defaults = {
 | 
						|
		date: '2030/06/10 12:00:00',
 | 
						|
		textDay: 'DAYS',
 | 
						|
		textHour: 'HRS',
 | 
						|
		textMin: 'MIN',
 | 
						|
		textSec: 'SEC',
 | 
						|
		uppercase: true,
 | 
						|
		numberClass: '',
 | 
						|
		wrapperClass: '',
 | 
						|
		insertHTMLbefore: '',
 | 
						|
		insertHTMLafter: ''
 | 
						|
	};
 | 
						|
 | 
						|
	PluginCountdown.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginCountdown.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			if (!($.isFunction($.fn.countTo))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this,
 | 
						|
				$el = this.options.wrapper,
 | 
						|
				numberClass = ( self.options.numberClass ) ? ' ' + self.options.numberClass : '',
 | 
						|
				wrapperClass = ( self.options.wrapperClass ) ? ' ' + self.options.wrapperClass : '';
 | 
						|
 | 
						|
			if( self.options.uppercase ) {
 | 
						|
				$el.countdown(self.options.date).on('update.countdown', function(event) {
 | 
						|
					var $this = $(this).html(event.strftime(self.options.insertHTMLbefore
 | 
						|
						+ '<span class="days'+ wrapperClass +'"><span class="'+ numberClass +'">%D</span> '+ self.options.textDay +'</span> '
 | 
						|
						+ '<span class="hours'+ wrapperClass +'"><span class="'+ numberClass +'">%H</span> '+ self.options.textHour +'</span> '
 | 
						|
						+ '<span class="minutes'+ wrapperClass +'"><span class="'+ numberClass +'">%M</span> '+ self.options.textMin +'</span> '
 | 
						|
						+ '<span class="seconds'+ wrapperClass +'"><span class="'+ numberClass +'">%S</span> '+ self.options.textSec +'</span> '
 | 
						|
						+ self.options.insertHTMLafter
 | 
						|
					));
 | 
						|
				});
 | 
						|
			} else {
 | 
						|
				$el.countdown(self.options.date).on('update.countdown', function(event) {
 | 
						|
					var $this = $(this).html(event.strftime(self.options.insertHTMLbefore
 | 
						|
						+ '<span class="days'+ wrapperClass +'"><span class="'+ numberClass +'">%D</span> '+ self.options.textDay +'</span> '
 | 
						|
						+ '<span class="hours'+ wrapperClass +'"><span class="'+ numberClass +'">%H</span> '+ self.options.textHour +'</span> '
 | 
						|
						+ '<span class="minutes'+ wrapperClass +'"><span class="'+ numberClass +'">%M</span> '+ self.options.textMin +'</span> '
 | 
						|
						+ '<span class="seconds'+ wrapperClass +'"><span class="'+ numberClass +'">%S</span> '+ self.options.textSec +'</span> '
 | 
						|
						+ self.options.insertHTMLafter
 | 
						|
					));
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginCountdown: PluginCountdown
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginCountdown = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginCountdown($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Counter
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__counter';
 | 
						|
 | 
						|
	var PluginCounter = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginCounter.defaults = {
 | 
						|
		accX: 0,
 | 
						|
		accY: 0,
 | 
						|
		appendWrapper: false,
 | 
						|
		prependWrapper: false,
 | 
						|
		speed: 3000,
 | 
						|
		refreshInterval: 100,
 | 
						|
		decimals: 0,
 | 
						|
		onUpdate: null,
 | 
						|
		onComplete: null
 | 
						|
	}
 | 
						|
 | 
						|
	PluginCounter.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginCounter.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			if (!($.isFunction($.fn.countTo))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this,
 | 
						|
				$el = this.options.wrapper;
 | 
						|
 | 
						|
			$.extend(self.options, {
 | 
						|
				onComplete: function() {
 | 
						|
					
 | 
						|
					if ($el.data('append')) {
 | 
						|
						if( self.options.appendWrapper ) {
 | 
						|
							var appendWrapper = $( self.options.appendWrapper );
 | 
						|
 | 
						|
							appendWrapper.append( $el.data('append') );
 | 
						|
 | 
						|
							$el.html( $el.html() + appendWrapper[0].outerHTML );
 | 
						|
						} else {
 | 
						|
							$el.html($el.html() + $el.data('append'));
 | 
						|
						}
 | 
						|
					}
 | 
						|
 | 
						|
					if ($el.data('prepend')) {
 | 
						|
						if( self.options.prependWrapper ) {
 | 
						|
							var prependWrapper = $( self.options.prependWrapper );
 | 
						|
 | 
						|
							prependWrapper.append( $el.data('prepend') );
 | 
						|
 | 
						|
							$el.html( $el.html() + prependWrapper[0].outerHTML );
 | 
						|
						} else {
 | 
						|
							$el.html($el.data('prepend') + $el.html());
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}
 | 
						|
			});
 | 
						|
 | 
						|
			$el.countTo(self.options);
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginCounter: PluginCounter
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginCounter = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginCounter($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// CursorEffect
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__cursorEffect';
 | 
						|
 | 
						|
	var PluginCursorEffect = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginCursorEffect.defaults = {
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
	PluginCursorEffect.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build()
 | 
						|
				.events();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginCursorEffect.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			// Global Variables for cursor position
 | 
						|
			self.clientX = -100;
 | 
						|
			self.clientY = -100;
 | 
						|
 | 
						|
			// Hide Mouse Cursor
 | 
						|
			if( self.options.hideMouseCursor ) {
 | 
						|
				self.$el.addClass('hide-mouse-cursor');
 | 
						|
			}
 | 
						|
 | 
						|
			// Creates the cursor wrapper node
 | 
						|
			var cursorOuter = document.createElement('DIV');
 | 
						|
				cursorOuter.className = 'cursor-outer';
 | 
						|
 | 
						|
			// Creates the cursor inner node
 | 
						|
			var cursorInner = document.createElement('DIV');
 | 
						|
				cursorInner.className = 'cursor-inner';
 | 
						|
 | 
						|
			// Custom Cursor Outer Color
 | 
						|
			if( self.options.cursorOuterColor ) {
 | 
						|
				cursorOuter.style = 'border-color: ' + self.options.cursorOuterColor + ';';
 | 
						|
			}
 | 
						|
 | 
						|
			// Custom Cursor Inner Color
 | 
						|
			if( self.options.cursorInnerColor ) {
 | 
						|
				cursorInner.style = 'background-color: ' + self.options.cursorInnerColor + ';';
 | 
						|
			}
 | 
						|
 | 
						|
			// Size
 | 
						|
			if( self.options.size ) {
 | 
						|
				switch ( self.options.size ) {
 | 
						|
					case 'small':
 | 
						|
						self.$el.addClass( 'cursor-effect-size-small' );
 | 
						|
						break;
 | 
						|
					
 | 
						|
					case 'big':
 | 
						|
						self.$el.addClass( 'cursor-effect-size-big' );
 | 
						|
						break;
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			// Style
 | 
						|
			if( self.options.style ) {
 | 
						|
				self.$el.addClass( self.options.style );
 | 
						|
			}
 | 
						|
 | 
						|
			// Prepend cursor wrapper node to the body
 | 
						|
			document.body.prepend( cursorOuter );
 | 
						|
 | 
						|
			// Prepend cursor inner node to the body
 | 
						|
			document.body.prepend( cursorInner );
 | 
						|
 | 
						|
			// Loop for render
 | 
						|
			var render = function() {
 | 
						|
				cursorOuter.style.transform = 'translate('+ self.clientX +'px, '+ self.clientY +'px)';
 | 
						|
				cursorInner.style.transform = 'translate('+ self.clientX +'px, '+ self.clientY +'px)';
 | 
						|
 | 
						|
				self.loopInside = requestAnimationFrame(render);
 | 
						|
			}
 | 
						|
			self.loop = requestAnimationFrame(render);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		events: function() {
 | 
						|
			var self = this,
 | 
						|
				$cursorOuter = $('.cursor-outer'),
 | 
						|
				$cursorInner = $('.cursor-inner');
 | 
						|
 | 
						|
			var initialCursorOuterBox    = $cursorOuter[0].getBoundingClientRect(),
 | 
						|
				initialCursorOuterRadius = $cursorOuter.css('border-radius');
 | 
						|
 | 
						|
			// Update Cursor Position
 | 
						|
			document.addEventListener('mousemove', function(e){
 | 
						|
				if( !self.isStuck ) {
 | 
						|
					self.clientX = e.clientX - 20;
 | 
						|
					self.clientY = e.clientY - 20;
 | 
						|
				}
 | 
						|
 | 
						|
				$cursorOuter.removeClass('opacity-0');
 | 
						|
			});
 | 
						|
 | 
						|
			self.isStuck = false;
 | 
						|
			$('[data-cursor-effect-hover]').on('mouseenter', function(e){
 | 
						|
 | 
						|
				// Identify Event With Hover Class
 | 
						|
				$cursorOuter.addClass('cursor-outer-hover');
 | 
						|
				$cursorInner.addClass('cursor-inner-hover');
 | 
						|
 | 
						|
				// Hover Color
 | 
						|
				var hoverColor = $(this).data('cursor-effect-hover-color');
 | 
						|
				$cursorOuter.addClass( 'cursor-color-' + hoverColor );
 | 
						|
				$cursorInner.addClass( 'cursor-color-' + hoverColor );
 | 
						|
 | 
						|
				// Effect Types
 | 
						|
				switch ( $(this).data('cursor-effect-hover') ) {
 | 
						|
					case 'fit':
 | 
						|
						var thisBox = $(this)[0].getBoundingClientRect();
 | 
						|
 | 
						|
						self.clientX = thisBox.x;
 | 
						|
						self.clientY = thisBox.y;
 | 
						|
 | 
						|
						$cursorOuter.css({
 | 
						|
							width: thisBox.width,
 | 
						|
							height: thisBox.height,
 | 
						|
							'border-radius': $(this).css('border-radius')
 | 
						|
						}).addClass('cursor-outer-fit');
 | 
						|
 | 
						|
						$cursorInner.addClass('opacity-0');
 | 
						|
 | 
						|
						self.isStuck = true;
 | 
						|
						break;
 | 
						|
 | 
						|
					case 'plus':
 | 
						|
						$cursorInner.addClass('cursor-inner-plus');
 | 
						|
						break;
 | 
						|
				}
 | 
						|
			});
 | 
						|
 | 
						|
			$('[data-cursor-effect-hover]').on('mouseleave', function(){
 | 
						|
				
 | 
						|
				// Identify Event With Hover Class
 | 
						|
				$cursorOuter.removeClass('cursor-outer-hover');
 | 
						|
				$cursorInner.removeClass('cursor-inner-hover');
 | 
						|
 | 
						|
				// Remove Color Class
 | 
						|
				var hoverColor = $(this).data('cursor-effect-hover-color');
 | 
						|
				$cursorOuter.removeClass( 'cursor-color-' + hoverColor );
 | 
						|
				$cursorInner.removeClass( 'cursor-color-' + hoverColor );
 | 
						|
 | 
						|
				// Effect Types
 | 
						|
				switch ( $(this).data('cursor-effect-hover') ) {
 | 
						|
					case 'fit':
 | 
						|
						$cursorOuter.css({
 | 
						|
							width: initialCursorOuterBox.width,
 | 
						|
							height: initialCursorOuterBox.height,
 | 
						|
							'border-radius': initialCursorOuterRadius
 | 
						|
						}).removeClass('cursor-outer-fit');
 | 
						|
 | 
						|
						$cursorInner.removeClass('opacity-0');
 | 
						|
 | 
						|
						self.isStuck = false;
 | 
						|
						break;
 | 
						|
 | 
						|
					case 'plus':
 | 
						|
						$cursorInner.removeClass('cursor-inner-plus');
 | 
						|
						break;
 | 
						|
				}
 | 
						|
			});
 | 
						|
 | 
						|
			$(window).on('scroll', function(){
 | 
						|
				if( $cursorOuter.hasClass('cursor-outer-fit') ) {
 | 
						|
					$cursorOuter.addClass('opacity-0').removeClass('cursor-outer-fit');
 | 
						|
				}
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		destroy: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			self.$el.removeClass('hide-mouse-cursor cursor-effect-size-small cursor-effect-size-big cursor-effect-style-square');		
 | 
						|
 | 
						|
			cancelAnimationFrame( self.loop );
 | 
						|
			cancelAnimationFrame( self.loopInside );
 | 
						|
 | 
						|
			document.querySelector('.cursor-outer').remove();
 | 
						|
			document.querySelector('.cursor-inner').remove();
 | 
						|
 | 
						|
			self.$el.removeData( instanceName, self );
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginCursorEffect: PluginCursorEffect
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginCursorEffect = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginCursorEffect($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Float Element
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	'use strict';
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__floatElement';
 | 
						|
 | 
						|
	var PluginFloatElement = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginFloatElement.defaults = {
 | 
						|
		startPos: 'top',
 | 
						|
		speed: 3,
 | 
						|
		horizontal: false,
 | 
						|
		isInsideSVG: false,
 | 
						|
		transition: false,
 | 
						|
		transitionDelay: 0,
 | 
						|
		transitionDuration: 500
 | 
						|
	};
 | 
						|
 | 
						|
	PluginFloatElement.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginFloatElement.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this,
 | 
						|
				$el = this.options.wrapper,
 | 
						|
				$window = $(window),
 | 
						|
				minus;
 | 
						|
 | 
						|
			// If has floating elements inside a SVG. 
 | 
						|
			// Intersection Observer API do not check elements inside SVG's, so we need initialize trough top parent SVG
 | 
						|
			if( $el.data('plugin-float-element-svg') ) {
 | 
						|
				$el.find('[data-plugin-float-element]').each(function(){
 | 
						|
					var $this = $(this),
 | 
						|
						opts;
 | 
						|
 | 
						|
					var pluginOptions = theme.fn.getOptions($this.data('plugin-options'));
 | 
						|
					if (pluginOptions)
 | 
						|
						opts = pluginOptions;
 | 
						|
 | 
						|
					$this.themePluginFloatElement(opts);
 | 
						|
				});
 | 
						|
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			if( self.options.style ) {
 | 
						|
				$el.attr('style', self.options.style);
 | 
						|
			}
 | 
						|
 | 
						|
			if( $window.width() > 767 ) {
 | 
						|
 | 
						|
				// Set Start Position
 | 
						|
				if( self.options.startPos == 'none' ) {
 | 
						|
					minus = '';
 | 
						|
				} else if( self.options.startPos == 'top' ) {
 | 
						|
					$el.css({
 | 
						|
						top: 0
 | 
						|
					});
 | 
						|
					minus = '';
 | 
						|
				} else {
 | 
						|
					$el.css({
 | 
						|
						bottom: 0
 | 
						|
					});
 | 
						|
					minus = '-';
 | 
						|
				}
 | 
						|
 | 
						|
				// Set Transition
 | 
						|
				if( self.options.transition ) {
 | 
						|
					$el.css({
 | 
						|
						transition: 'ease-out transform '+ self.options.transitionDuration +'ms ' + self.options.transitionDelay + 'ms'
 | 
						|
					});
 | 
						|
				}
 | 
						|
 | 
						|
				// First Load
 | 
						|
				self.movement(minus);	
 | 
						|
 | 
						|
				// Scroll
 | 
						|
				$window.on('scroll', function(){
 | 
						|
					self.movement(minus);				   
 | 
						|
				});
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		movement: function(minus) {
 | 
						|
			var self = this,
 | 
						|
				$el = this.options.wrapper,
 | 
						|
				$window = $(window),
 | 
						|
				scrollTop = $window.scrollTop(),
 | 
						|
		    	elementOffset = $el.offset().top,
 | 
						|
		     	currentElementOffset = (elementOffset - scrollTop),
 | 
						|
		     	factor = ( self.options.isInsideSVG ) ? 2 : 100;
 | 
						|
 | 
						|
		   	var scrollPercent = factor * currentElementOffset / ($window.height());
 | 
						|
 | 
						|
		   	if( $el.visible( true ) ) {
 | 
						|
 | 
						|
		   		if( !self.options.horizontal ) {
 | 
						|
 | 
						|
		   			$el.css({
 | 
						|
			   			transform: 'translate3d(0, '+ minus + scrollPercent / self.options.speed +'%, 0)'
 | 
						|
			   		});
 | 
						|
 | 
						|
		   		} else {
 | 
						|
 | 
						|
		   			$el.css({
 | 
						|
			   			transform: 'translate3d('+ minus + scrollPercent / self.options.speed +'%, 0, 0)'
 | 
						|
			   		});
 | 
						|
 | 
						|
		   		}
 | 
						|
		   		
 | 
						|
		   	}
 | 
						|
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginFloatElement: PluginFloatElement
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginFloatElement = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginFloatElement($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// GDPR
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__gdpr';
 | 
						|
 | 
						|
	var PluginGDPR = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginGDPR.defaults = {
 | 
						|
		cookieBarShowDelay: 3000
 | 
						|
	};
 | 
						|
 | 
						|
	PluginGDPR.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build()
 | 
						|
				.events();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginGDPR.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			// Show
 | 
						|
			if( !$.cookie( 'porto-privacy-bar' ) ) {
 | 
						|
				setTimeout(function(){
 | 
						|
					self.options.wrapper.addClass('show');
 | 
						|
				}, self.options.cookieBarShowDelay);
 | 
						|
			}
 | 
						|
 | 
						|
			// If already has preferences cookie, check inputs according preferences cookie data
 | 
						|
			if( $.cookie( 'porto-gdpr-preferences' ) ) {
 | 
						|
				var preferencesArr = $.cookie( 'porto-gdpr-preferences' ).split(',');
 | 
						|
 | 
						|
				for( var i = 0; i < preferencesArr.length; i++ ) {
 | 
						|
					if( $('input[value="'+ preferencesArr[i] +'"]').get(0) ) {
 | 
						|
						if( $('input[value="'+ preferencesArr[i] +'"]').is(':checkbox') ) {
 | 
						|
							$('input[value="'+ preferencesArr[i] +'"]').prop('checked', true);
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
 | 
						|
		},
 | 
						|
 | 
						|
		events: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			// Agree Trigger
 | 
						|
			self.options.wrapper.find('.gdpr-agree-trigger').on('click', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				$('.gdpr-preferences-form').find('.gdpr-input').each(function(){
 | 
						|
					if( $(this).is(':checkbox') || $(this).is(':hidden') ) {
 | 
						|
						$(this).prop('checked', true);
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				$('.gdpr-preferences-form').trigger('submit').removeClass('show');
 | 
						|
 | 
						|
				self.removeCookieBar();
 | 
						|
			});
 | 
						|
 | 
						|
			// Preferences Trigger
 | 
						|
			self.options.wrapper.find('.gdpr-preferences-trigger').on('click', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				$('.gdpr-preferences-popup').addClass('show');
 | 
						|
			});
 | 
						|
 | 
						|
			// Close Popup Button
 | 
						|
			$('.gdpr-close-popup').on('click', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				$('.gdpr-preferences-popup').removeClass('show');
 | 
						|
			});
 | 
						|
 | 
						|
			// Close Popup When Click Outside of popup area
 | 
						|
			$('.gdpr-preferences-popup').on('click', function(e){
 | 
						|
				if( !$(e.target).closest('.gdpr-preferences-popup-content').get(0) ) {
 | 
						|
					$('.gdpr-preferences-popup').removeClass('show');
 | 
						|
				}
 | 
						|
			});
 | 
						|
 | 
						|
			// Preference Form
 | 
						|
			$('.gdpr-preferences-form').on('submit', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				var $this = $(this);
 | 
						|
 | 
						|
				// Save Preferences Button
 | 
						|
				$this.find('button[type="submit"]').text( 'SAVING...' );
 | 
						|
 | 
						|
				// Form Data
 | 
						|
				var formData = [];
 | 
						|
				$this.find('.gdpr-input').each(function(){
 | 
						|
					if( $(this).is(':checkbox') && $(this).is(':checked') || $(this).is(':hidden') ) {
 | 
						|
						formData.push( $(this).val() );
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				$.cookie( 'porto-privacy-bar', true );
 | 
						|
 | 
						|
				setTimeout(function(){
 | 
						|
					$this.find('button[type="submit"]').text( 'SAVED!' ).removeClass('btn-primary').addClass('btn-success');
 | 
						|
 | 
						|
					setTimeout(function(){
 | 
						|
						$('.gdpr-preferences-popup').removeClass('show');
 | 
						|
						self.removeCookieBar();
 | 
						|
 | 
						|
						$this.find('button[type="submit"]').text( 'SAVE PREFERENCES' ).removeClass('btn-success').addClass('btn-primary');
 | 
						|
 | 
						|
						if( $.cookie( 'porto-gdpr-preferences' ) ) {
 | 
						|
 | 
						|
							$.cookie( 'porto-gdpr-preferences', formData );
 | 
						|
							location.reload();
 | 
						|
 | 
						|
						} else {
 | 
						|
 | 
						|
							$.cookie( 'porto-gdpr-preferences', formData );
 | 
						|
 | 
						|
							if ($.isFunction($.fn['themePluginGDPRWrapper']) && $('[data-plugin-gdpr-wrapper]').length) {
 | 
						|
 | 
						|
								$(function() {
 | 
						|
									$('[data-plugin-gdpr-wrapper]:not(.manual)').each(function() {
 | 
						|
										var $this = $(this),
 | 
						|
											opts;
 | 
						|
 | 
						|
										$this.removeData('__gdprwrapper');
 | 
						|
 | 
						|
										var pluginOptions = theme.fn.getOptions($this.data('plugin-options'));
 | 
						|
										if (pluginOptions)
 | 
						|
											opts = pluginOptions;
 | 
						|
 | 
						|
										$this.themePluginGDPRWrapper(opts);
 | 
						|
									});
 | 
						|
								});
 | 
						|
 | 
						|
							}
 | 
						|
 | 
						|
						}
 | 
						|
 | 
						|
					}, 500);
 | 
						|
				}, 1000);
 | 
						|
			});
 | 
						|
 | 
						|
			// Remove/Reset Cookies
 | 
						|
			$('.gdpr-reset-cookies').on('click', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				self.clearCookies();
 | 
						|
 | 
						|
				location.reload();
 | 
						|
			});
 | 
						|
 | 
						|
			// Open Preferences
 | 
						|
			$('.gdpr-open-preferences').on('click', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				$('.gdpr-preferences-popup').toggleClass('show');
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		removeCookieBar: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			self.options.wrapper.addClass('removing').on('transitionend', function(){
 | 
						|
				setTimeout(function(){
 | 
						|
					self.options.wrapper.removeClass('show removing');
 | 
						|
				}, 500);
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		clearCookies: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			$.removeCookie( 'porto-privacy-bar' );
 | 
						|
			$.removeCookie( 'porto-gdpr-preferences' );
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginGDPR: PluginGDPR
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginGDPR = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginGDPR($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// GDPR Wrapper
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__gdprwrapper';
 | 
						|
 | 
						|
	var PluginGDPRWrapper = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginGDPRWrapper.defaults = {
 | 
						|
 | 
						|
	};
 | 
						|
 | 
						|
	PluginGDPRWrapper.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
				
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginGDPRWrapper.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if( $.cookie( 'porto-gdpr-preferences' ) && $.cookie( 'porto-gdpr-preferences' ).indexOf( self.options.checkCookie ) != -1 ) {
 | 
						|
 | 
						|
				$.ajax({
 | 
						|
					url: self.options.ajaxURL,
 | 
						|
					cache: false,
 | 
						|
					complete: function(data) {
 | 
						|
					
 | 
						|
						setTimeout(function() {
 | 
						|
 | 
						|
							self.options.wrapper.html(data.responseText).addClass('show');
 | 
						|
 | 
						|
						}, 1000);
 | 
						|
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
			} else {
 | 
						|
				self.options.wrapper.addClass('show');
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginGDPRWrapper: PluginGDPRWrapper
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginGDPRWrapper = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginGDPRWrapper($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Hover Effect
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__hoverEffect';
 | 
						|
 | 
						|
	var PluginHoverEffect = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginHoverEffect.defaults = {
 | 
						|
		effect: 'magnetic',
 | 
						|
		magneticMx: 0.15,
 | 
						|
		magneticMy: 0.3,
 | 
						|
		magneticDeg: 12,
 | 
						|
		selector: '.thumb-info, .hover-effect-3d-wrapper',
 | 
						|
		sensitivity: 20
 | 
						|
	};
 | 
						|
 | 
						|
	PluginHoverEffect.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginHoverEffect.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if(self.$el.hasClass('hover-effect-3d')) {
 | 
						|
				self.options.effect = '3d';
 | 
						|
			}
 | 
						|
 | 
						|
			// Magnetic
 | 
						|
			if(self.options.effect == 'magnetic') {
 | 
						|
				self.magnetic();
 | 
						|
			}
 | 
						|
 | 
						|
			// 3d
 | 
						|
			if(self.options.effect == '3d') {
 | 
						|
				self.hover3d();
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		magnetic: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			self.$el.mousemove(function(e) {
 | 
						|
 | 
						|
				const pos = this.getBoundingClientRect();
 | 
						|
				const mx = e.clientX - pos.left - pos.width/2; 
 | 
						|
				const my = e.clientY - pos.top - pos.height/2;
 | 
						|
 | 
						|
				this.style.transform = 'translate('+ mx * self.options.magneticMx +'px, '+ my * self.options.magneticMx +'px)';
 | 
						|
 | 
						|
			});
 | 
						|
 | 
						|
			self.$el.mouseleave(function(e) {
 | 
						|
 | 
						|
				this.style.transform = 'translate3d(0px, 0px, 0px)';
 | 
						|
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
 | 
						|
		},
 | 
						|
 | 
						|
		hover3d: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if ($.isFunction($.fn['hover3d'])) {
 | 
						|
 | 
						|
				self.$el.hover3d({
 | 
						|
					selector: self.options.selector,
 | 
						|
					sensitivity: self.options.sensitivity
 | 
						|
				});
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginHoverEffect: PluginHoverEffect
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginHoverEffect = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginHoverEffect($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	};
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Icon
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	'use strict';
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__icon';
 | 
						|
 | 
						|
	var PluginIcon = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginIcon.defaults = {
 | 
						|
		color: '#2388ED',
 | 
						|
		animated: false,
 | 
						|
		delay: 300,
 | 
						|
		onlySVG: false,
 | 
						|
		removeClassAfterInit: false,
 | 
						|
		fadeIn: true,
 | 
						|
		accY: 0
 | 
						|
	};
 | 
						|
 | 
						|
	PluginIcon.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginIcon.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self  	 = this,
 | 
						|
				$el   	 = this.options.wrapper,
 | 
						|
				color 	 = self.options.color,
 | 
						|
				elTopDistance = $el.offset().top,
 | 
						|
				windowTopDistance = $(window).scrollTop(),
 | 
						|
				duration = ( self.options.animated && !self.options.strokeBased ) ? 200 : 100;
 | 
						|
 | 
						|
			// Check origin
 | 
						|
			if( window.location.protocol === 'file:' ) {
 | 
						|
				$el.css({
 | 
						|
					opacity: 1,
 | 
						|
					width: $el.attr('width')
 | 
						|
				});
 | 
						|
 | 
						|
				if( self.options.extraClass ) {
 | 
						|
					$el.addClass( self.options.extraClass );
 | 
						|
				}
 | 
						|
 | 
						|
				if( self.options.extraClass.indexOf('-color-light') > 0 ) {
 | 
						|
					$el.css({
 | 
						|
						filter: 'invert(1)'
 | 
						|
					});
 | 
						|
				}
 | 
						|
 | 
						|
				$(window).trigger('icon.rendered');
 | 
						|
				return;
 | 
						|
			}
 | 
						|
 | 
						|
			// Duration
 | 
						|
			if( self.options.duration ) {
 | 
						|
				duration = self.options.duration;
 | 
						|
			}
 | 
						|
 | 
						|
			// SVG Content
 | 
						|
			var SVGContent = $.get({
 | 
						|
				url: $el.attr('src'), 
 | 
						|
				success: function(data, status, xhr){
 | 
						|
					var iconWrapper = self.options.fadeIn ? $('<div class="animated-icon animated fadeIn">'+ xhr.responseText +'</div>') : $('<div class="animated-icon animated">'+ xhr.responseText +'</div>'),
 | 
						|
						uniqid = 'icon_' + Math.floor(Math.random() * 26) + Date.now();
 | 
						|
 | 
						|
					// Add ID
 | 
						|
					iconWrapper.find('svg').attr('id', uniqid);
 | 
						|
 | 
						|
					// Identify with filename
 | 
						|
					iconWrapper.find('svg').attr('data-filename', $el.attr('src').split(/(\\|\/)/g).pop());
 | 
						|
 | 
						|
					if( $el.attr('width') ) {
 | 
						|
						iconWrapper.find('svg')
 | 
						|
							.attr('width', $el.attr('width'))
 | 
						|
							.attr('height', $el.attr('width'));						
 | 
						|
					}
 | 
						|
 | 
						|
					if( $el.attr('height') ) {
 | 
						|
						iconWrapper.find('svg')
 | 
						|
							.attr('height', $el.attr('height'));	
 | 
						|
					}
 | 
						|
 | 
						|
					if( self.options.svgViewBox ) {
 | 
						|
						iconWrapper.find('svg')
 | 
						|
							.attr('viewBox', self.options.svgViewBox);
 | 
						|
					}
 | 
						|
 | 
						|
					$el.replaceWith(iconWrapper);
 | 
						|
 | 
						|
					if( self.options.extraClass ) {
 | 
						|
						iconWrapper.addClass( self.options.extraClass );
 | 
						|
					}
 | 
						|
 | 
						|
					if( self.options.removeClassAfterInit ) {
 | 
						|
						iconWrapper.removeClass(self.options.removeClassAfterInit);
 | 
						|
					}
 | 
						|
 | 
						|
					if( self.options.onlySVG ) {
 | 
						|
						$(window).trigger('icon.rendered');
 | 
						|
						return this;
 | 
						|
					}
 | 
						|
 | 
						|
					$el = iconWrapper;
 | 
						|
 | 
						|
					var icon = new Vivus(uniqid, {start: 'manual', type: 'sync', selfDestroy: true, duration: duration, onReady: function(obj){
 | 
						|
						var styleElement = document.createElementNS("http://www.w3.org/2000/svg", "style"),
 | 
						|
							animateStyle = '';
 | 
						|
 | 
						|
						// SVG Fill Based
 | 
						|
						if( self.options.animated && !self.options.strokeBased || !self.options.animated && color && !self.options.strokeBased ) {
 | 
						|
							animateStyle = 'stroke-width: 0.1px; fill-opacity: 0; transition: ease fill-opacity 300ms;';
 | 
						|
							
 | 
						|
							// Set Style on SVG inside object
 | 
						|
							styleElement.textContent = '#' + uniqid + ' path, #' + uniqid + ' line, #' + uniqid + ' rect, #' + uniqid + ' circle, #' + uniqid + ' polyline { fill: '+ color +'; stroke: '+ color +'; '+ animateStyle + (self.options.svgStyle ? self.options.svgStyle : "") + ' } .finished path { fill-opacity: 1; }';
 | 
						|
							obj.el.appendChild(styleElement);
 | 
						|
						}
 | 
						|
 | 
						|
						// SVG Stroke Based
 | 
						|
						if( self.options.animated && self.options.strokeBased || !self.options.animated && color && self.options.strokeBased ) {
 | 
						|
 | 
						|
							// Set Style on SVG inside object
 | 
						|
							styleElement.textContent = '#' + uniqid + ' path, #' + uniqid + ' line, #' + uniqid + ' rect, #' + uniqid + ' circle, #' + uniqid + ' polyline { stroke: '+ color +'; ' + (self.options.svgStyle ? self.options.svgStyle : "") + '}';
 | 
						|
							obj.el.appendChild(styleElement);
 | 
						|
						}
 | 
						|
 | 
						|
						$.event.trigger('theme.plugin.icon.svg.ready');
 | 
						|
					}});
 | 
						|
 | 
						|
					// Isn't animated
 | 
						|
					if( !self.options.animated ) {
 | 
						|
						setTimeout(function(){
 | 
						|
							icon.finish();
 | 
						|
						}, 10);
 | 
						|
						$el.css({ opacity: 1 });
 | 
						|
					}
 | 
						|
 | 
						|
					// Animated
 | 
						|
					if( self.options.animated && $(window).width() > 767 ) {
 | 
						|
						
 | 
						|
						// First Load
 | 
						|
						if( $el.visible( true ) ) {
 | 
						|
							self.startIconAnimation( icon, $el );
 | 
						|
						} else if( elTopDistance < windowTopDistance ) {
 | 
						|
							self.startIconAnimation( icon, $el );
 | 
						|
						}
 | 
						|
 | 
						|
						// On Scroll
 | 
						|
						$(window).on('scroll', function(){
 | 
						|
							if( $el.visible( true ) ) {
 | 
						|
								self.startIconAnimation( icon, $el );
 | 
						|
							}
 | 
						|
						});
 | 
						|
 | 
						|
					} else {
 | 
						|
						
 | 
						|
						$el.css({ opacity: 1 });
 | 
						|
						icon.finish();
 | 
						|
						
 | 
						|
						$(window).on('theme.plugin.icon.svg.ready', function(){
 | 
						|
							setTimeout(function(){
 | 
						|
								icon.el.setAttribute('class', 'finished');
 | 
						|
								icon.finish();
 | 
						|
							}, 300);
 | 
						|
						});
 | 
						|
						
 | 
						|
					}
 | 
						|
 | 
						|
					$(window).trigger('icon.rendered');
 | 
						|
				}
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		startIconAnimation: function(icon, $el) {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			// Animate for better performance
 | 
						|
			$({to:0}).animate({to:1}, ((self.options.strokeBased) ? self.options.delay : self.options.delay + 300 ), function() {
 | 
						|
				$el.css({ opacity: 1 });
 | 
						|
			});
 | 
						|
 | 
						|
			$({to:0}).animate({to:1}, self.options.delay, function() {
 | 
						|
				icon.play(1);
 | 
						|
 | 
						|
				setTimeout(function(){
 | 
						|
					icon.el.setAttribute('class', 'finished');
 | 
						|
				}, icon.duration * 5 );
 | 
						|
			});
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginIcon: PluginIcon
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginIcon = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginIcon($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	};
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// In Viewport Style
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__inviewportstyle';
 | 
						|
 | 
						|
	var PluginInViewportStyle = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginInViewportStyle.defaults = {
 | 
						|
		viewport: window, 
 | 
						|
		threshold: [0],
 | 
						|
		modTop: '-200px',
 | 
						|
		modBottom: '-200px',
 | 
						|
		style: {'transition': 'all 1s ease-in-out'},
 | 
						|
		styleIn: '',
 | 
						|
		styleOut: '',
 | 
						|
		classIn: '',
 | 
						|
		classOut: ''
 | 
						|
	};
 | 
						|
 | 
						|
	PluginInViewportStyle.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginInViewportStyle.defaults, opts, {});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this,
 | 
						|
				el = self.$el.get(0);
 | 
						|
 | 
						|
			self.$el.css(self.options.style);
 | 
						|
 | 
						|
		    if (typeof window.IntersectionObserver === 'function') {
 | 
						|
			    const un = observeElementInViewport.observeElementInViewport(
 | 
						|
			        el, function() {
 | 
						|
			        	self.$el.css(self.options.styleIn);
 | 
						|
			        	self.$el
 | 
						|
			        		.addClass(self.options.classIn)
 | 
						|
			        		.removeClass(self.options.classOut);
 | 
						|
			        }, function() {
 | 
						|
			        	self.$el.css(self.options.styleOut);
 | 
						|
			        	self.$el
 | 
						|
			        		.addClass(self.options.classOut)
 | 
						|
			        		.removeClass(self.options.classIn);
 | 
						|
			        }, {
 | 
						|
			        	viewport: self.options.viewport, 
 | 
						|
			            threshold: self.options.threshold,
 | 
						|
						modTop: self.options.modTop,
 | 
						|
						modBottom: self.options.modBottom
 | 
						|
			        }
 | 
						|
			    )
 | 
						|
		    };
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginInViewportStyle: PluginInViewportStyle
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginInViewportStyle = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginInViewportStyle($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Lightbox
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__lightbox';
 | 
						|
 | 
						|
	var PluginLightbox = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginLightbox.defaults = {
 | 
						|
		tClose: 'Close (Esc)', // Alt text on close button
 | 
						|
		tLoading: 'Loading...', // Text that is displayed during loading. Can contain %curr% and %total% keys
 | 
						|
		gallery: {
 | 
						|
			tPrev: 'Previous (Left arrow key)', // Alt text on left arrow
 | 
						|
			tNext: 'Next (Right arrow key)', // Alt text on right arrow
 | 
						|
			tCounter: '%curr% of %total%' // Markup for "1 of 7" counter
 | 
						|
		},
 | 
						|
		image: {
 | 
						|
			tError: '<a href="%url%">The image</a> could not be loaded.' // Error message when image could not be loaded
 | 
						|
		},
 | 
						|
		ajax: {
 | 
						|
			tError: '<a href="%url%">The content</a> could not be loaded.' // Error message when ajax request failed
 | 
						|
		},
 | 
						|
		callbacks: {
 | 
						|
			open: function() {
 | 
						|
				$('html').addClass('lightbox-opened');
 | 
						|
			},
 | 
						|
			close: function() {
 | 
						|
				$('html').removeClass('lightbox-opened');
 | 
						|
			}
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	PluginLightbox.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginLightbox.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			if (!($.isFunction($.fn.magnificPopup))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.options.wrapper.magnificPopup(this.options);
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginLightbox: PluginLightbox
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginLightbox = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginLightbox($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Loading Overlay
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	'use strict';
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	// Default
 | 
						|
	var loadingOverlayDefaultTemplate = [
 | 
						|
		'<div class="loading-overlay">',
 | 
						|
			'<div class="bounce-loader"><div class="bounce1"></div><div class="bounce2"></div><div class="bounce3"></div></div>',
 | 
						|
		'</div>'
 | 
						|
	].join('');
 | 
						|
 | 
						|
	// Percentage
 | 
						|
	var loadingOverlayPercentageTemplate = [
 | 
						|
		'<div class="loading-overlay loading-overlay-percentage">',
 | 
						|
			'<div class="page-loader-progress-wrapper"><span class="page-loader-progress">0</span><span class="page-loader-progress-symbol">%</span></div>',
 | 
						|
		'</div>'
 | 
						|
	].join('');
 | 
						|
 | 
						|
	// Cubes
 | 
						|
	var loadingOverlayCubesTemplate = [
 | 
						|
		'<div class="loading-overlay">',
 | 
						|
			'<div class="bounce-loader"><div class="cssload-thecube"><div class="cssload-cube cssload-c1"></div><div class="cssload-cube cssload-c2"></div><div class="cssload-cube cssload-c4"></div><div class="cssload-cube cssload-c3"></div></div></div>',
 | 
						|
		'</div>'
 | 
						|
	].join('');
 | 
						|
 | 
						|
	// Cube Progress
 | 
						|
	var loadingOverlayCubeProgressTemplate = [
 | 
						|
		'<div class="loading-overlay">',
 | 
						|
			'<div class="bounce-loader"><span class="cssload-cube-progress"><span class="cssload-cube-progress-inner"></span></span></div>',
 | 
						|
		'</div>'
 | 
						|
	].join('');
 | 
						|
 | 
						|
	// Float Rings
 | 
						|
	var loadingOverlayFloatRingsTemplate = [
 | 
						|
		'<div class="loading-overlay">',
 | 
						|
			'<div class="bounce-loader"><div class="cssload-float-rings-loader"><div class="cssload-float-rings-inner cssload-one"></div><div class="cssload-float-rings-inner cssload-two"></div><div class="cssload-float-rings-inner cssload-three"></div></div></div>',
 | 
						|
		'</div>'
 | 
						|
	].join('');
 | 
						|
 | 
						|
	// Floating Bars
 | 
						|
	var loadingOverlayFloatBarsTemplate = [
 | 
						|
		'<div class="loading-overlay">',
 | 
						|
			'<div class="bounce-loader"><div class="cssload-float-bars-container"><ul class="cssload-float-bars-flex-container"><li><span class="cssload-float-bars-loading"></span></li></div></div></div>',
 | 
						|
		'</div>'
 | 
						|
	].join('');
 | 
						|
 | 
						|
	// Speeding Wheel
 | 
						|
	var loadingOverlaySpeedingWheelTemplate = [
 | 
						|
		'<div class="loading-overlay">',
 | 
						|
			'<div class="bounce-loader"><div class="cssload-speeding-wheel-container"><div class="cssload-speeding-wheel"></div></div></div>',
 | 
						|
		'</div>'
 | 
						|
	].join('');
 | 
						|
 | 
						|
	// Zenith
 | 
						|
	var loadingOverlayZenithTemplate = [
 | 
						|
		'<div class="loading-overlay">',
 | 
						|
			'<div class="bounce-loader"><div class="cssload-zenith-container"><div class="cssload-zenith"></div></div></div>',
 | 
						|
		'</div>'
 | 
						|
	].join('');
 | 
						|
 | 
						|
	// Spinning Square
 | 
						|
	var loadingOverlaySpinningSquareTemplate = [
 | 
						|
		'<div class="loading-overlay">',
 | 
						|
			'<div class="bounce-loader"><div class="cssload-spinning-square-loading"></div></div>',
 | 
						|
		'</div>'
 | 
						|
	].join('');
 | 
						|
 | 
						|
	// Pulse
 | 
						|
	var loadingOverlayPulseTemplate = [
 | 
						|
		'<div class="loading-overlay">',
 | 
						|
			'<div class="bounce-loader"><div class="wrapper-pulse"><div class="cssload-pulse-loader"></div></div></div>',
 | 
						|
		'</div>'
 | 
						|
	].join('');
 | 
						|
 | 
						|
	var LoadingOverlay = function( $wrapper, options, noInheritOptions ) {
 | 
						|
		return this.initialize( $wrapper, options, noInheritOptions );
 | 
						|
	};
 | 
						|
 | 
						|
	LoadingOverlay.prototype = {
 | 
						|
 | 
						|
		options: {
 | 
						|
			css: {},
 | 
						|
			hideDelay: 500,
 | 
						|
			progressMinTimeout: 0,
 | 
						|
			effect: 'default'
 | 
						|
		},
 | 
						|
 | 
						|
		initialize: function( $wrapper, options, noInheritOptions ) {
 | 
						|
			this.$wrapper = $wrapper;
 | 
						|
 | 
						|
			this
 | 
						|
				.setVars()
 | 
						|
				.setOptions( options, noInheritOptions )
 | 
						|
				.build()
 | 
						|
				.events()
 | 
						|
				.dynamicShowHideEvents();
 | 
						|
 | 
						|
			this.$wrapper.data( 'loadingOverlay', this );
 | 
						|
		},
 | 
						|
 | 
						|
		setVars: function() {
 | 
						|
			this.$overlay = this.$wrapper.find('.loading-overlay');
 | 
						|
			this.pageStatus = null;
 | 
						|
			this.progress = null;
 | 
						|
			this.animationInterval = 33;
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function( options, noInheritOptions ) {
 | 
						|
			if ( !this.$overlay.get(0) ) {
 | 
						|
				this.matchProperties();
 | 
						|
			}
 | 
						|
			
 | 
						|
			if( noInheritOptions ) {
 | 
						|
				this.options     = $.extend( true, {}, this.options, options );
 | 
						|
			} else {
 | 
						|
				this.options     = $.extend( true, {}, this.options, options, theme.fn.getOptions(this.$wrapper.data('plugin-options')) );
 | 
						|
			}
 | 
						|
 | 
						|
			this.loaderClass = this.getLoaderClass( this.options.css.backgroundColor );
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var _self = this;
 | 
						|
 | 
						|
			if ( !this.$overlay.closest(document.documentElement).get(0) ) {
 | 
						|
				if ( !this.$cachedOverlay ) {
 | 
						|
 | 
						|
					switch ( _self.options.effect ) {
 | 
						|
						case 'percentageProgress1':
 | 
						|
							this.$overlay = $( loadingOverlayPercentageTemplate ).clone();
 | 
						|
							break;
 | 
						|
 | 
						|
						case 'percentageProgress2':
 | 
						|
							this.$overlay = $( loadingOverlayPercentageTemplate ).clone();
 | 
						|
							this.$overlay
 | 
						|
								.addClass('loading-overlay-percentage-effect-2')
 | 
						|
								.prepend('<div class="loading-overlay-background-layer"></div>');
 | 
						|
							break;
 | 
						|
 | 
						|
						case 'cubes':
 | 
						|
							this.$overlay = $( loadingOverlayCubesTemplate ).clone();
 | 
						|
							break;
 | 
						|
 | 
						|
						case 'cubeProgress':
 | 
						|
							this.$overlay = $( loadingOverlayCubeProgressTemplate ).clone();
 | 
						|
							break;
 | 
						|
 | 
						|
						case 'floatRings':
 | 
						|
							this.$overlay = $( loadingOverlayFloatRingsTemplate ).clone();
 | 
						|
							break;
 | 
						|
 | 
						|
						case 'floatBars':
 | 
						|
							this.$overlay = $( loadingOverlayFloatBarsTemplate ).clone();
 | 
						|
							break;
 | 
						|
 | 
						|
						case 'speedingWheel':
 | 
						|
							this.$overlay = $( loadingOverlaySpeedingWheelTemplate ).clone();
 | 
						|
							break;
 | 
						|
 | 
						|
						case 'zenith':
 | 
						|
							this.$overlay = $( loadingOverlayZenithTemplate ).clone();
 | 
						|
							break;
 | 
						|
 | 
						|
						case 'spinningSquare':
 | 
						|
							this.$overlay = $( loadingOverlaySpinningSquareTemplate ).clone();
 | 
						|
							break;
 | 
						|
 | 
						|
						case 'pulse':
 | 
						|
							this.$overlay = $( loadingOverlayPulseTemplate ).clone();
 | 
						|
							break;
 | 
						|
 | 
						|
						case 'default':
 | 
						|
						default:
 | 
						|
							this.$overlay = $( loadingOverlayDefaultTemplate ).clone();
 | 
						|
							break;
 | 
						|
					}
 | 
						|
					
 | 
						|
					if ( this.options.css ) {
 | 
						|
						this.$overlay.css( this.options.css );
 | 
						|
						this.$overlay.find( '.loader' ).addClass( this.loaderClass );
 | 
						|
					}
 | 
						|
				} else {
 | 
						|
					this.$overlay = this.$cachedOverlay.clone();
 | 
						|
				}
 | 
						|
 | 
						|
				this.$wrapper.prepend( this.$overlay );
 | 
						|
			}
 | 
						|
 | 
						|
			if ( !this.$cachedOverlay ) {
 | 
						|
				this.$cachedOverlay = this.$overlay.clone();
 | 
						|
			}
 | 
						|
 | 
						|
			if( ['percentageProgress1', 'percentageProgress2'].includes(_self.options.effect) ) {
 | 
						|
				_self.updateProgress();
 | 
						|
 | 
						|
				if( _self.options.isDynamicHideShow ) {
 | 
						|
					setTimeout(function(){
 | 
						|
						_self.progress = 'complete';
 | 
						|
						
 | 
						|
						$('.page-loader-progress').text(100);
 | 
						|
 | 
						|
						if( ['percentageProgress2'].includes(_self.options.effect) ) {
 | 
						|
			            	$('.loading-overlay-background-layer').css({
 | 
						|
			            		width: '100%'
 | 
						|
			            	});
 | 
						|
			            }
 | 
						|
					}, 2800);
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		events: function() {
 | 
						|
			var _self = this;
 | 
						|
 | 
						|
			if ( this.options.startShowing ) {
 | 
						|
				_self.show();
 | 
						|
			}
 | 
						|
 | 
						|
			if ( this.$wrapper.is('body') || this.options.hideOnWindowLoad ) {
 | 
						|
				$( window ).on( 'load error', function() {
 | 
						|
					setTimeout(function(){
 | 
						|
						_self.hide();
 | 
						|
					}, _self.options.progressMinTimeout);
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			if ( this.options.listenOn ) {
 | 
						|
				$( this.options.listenOn )
 | 
						|
					.on( 'loading-overlay:show beforeSend.ic', function( e ) {
 | 
						|
						e.stopPropagation();
 | 
						|
						_self.show();
 | 
						|
					})
 | 
						|
					.on( 'loading-overlay:hide complete.ic', function( e ) {
 | 
						|
						e.stopPropagation();
 | 
						|
						_self.hide();
 | 
						|
					});
 | 
						|
			}
 | 
						|
 | 
						|
			this.$wrapper
 | 
						|
				.on( 'loading-overlay:show beforeSend.ic', function( e ) {
 | 
						|
					if ( e.target === _self.$wrapper.get(0) ) {
 | 
						|
						e.stopPropagation();
 | 
						|
						_self.show();
 | 
						|
						return true;
 | 
						|
					}
 | 
						|
					return false;
 | 
						|
				})
 | 
						|
				.on( 'loading-overlay:hide complete.ic', function( e ) {
 | 
						|
					if ( e.target === _self.$wrapper.get(0) ) {
 | 
						|
						e.stopPropagation();
 | 
						|
						_self.hide();
 | 
						|
						return true;
 | 
						|
					}
 | 
						|
					return false;
 | 
						|
				});
 | 
						|
 | 
						|
			if( ['percentageProgress1', 'percentageProgress2'].includes(_self.options.effect) ) {
 | 
						|
				$(window).on('load', function(){
 | 
						|
		            setTimeout(function(){
 | 
						|
			            _self.pageStatus = "complete";
 | 
						|
 | 
						|
			            $('.page-loader-progress').text(100);
 | 
						|
 | 
						|
			            if( ['percentageProgress2'].includes(_self.options.effect) ) {
 | 
						|
			            	$('.loading-overlay-background-layer').css({
 | 
						|
			            		width: '100%'
 | 
						|
			            	});
 | 
						|
			            }
 | 
						|
		            }, _self.options.progressMinTimeout);
 | 
						|
				});
 | 
						|
			}
 | 
						|
		        
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		show: function() {
 | 
						|
			this.build();
 | 
						|
 | 
						|
			this.position = this.$wrapper.css( 'position' ).toLowerCase();
 | 
						|
			if ( this.position != 'relative' || this.position != 'absolute' || this.position != 'fixed' ) {
 | 
						|
				this.$wrapper.css({
 | 
						|
					position: 'relative'
 | 
						|
				});
 | 
						|
			}
 | 
						|
			this.$wrapper.addClass( 'loading-overlay-showing' );
 | 
						|
		},
 | 
						|
 | 
						|
		hide: function() {
 | 
						|
			var _self = this;
 | 
						|
 | 
						|
			setTimeout(function() {
 | 
						|
				_self.$wrapper.removeClass( 'loading-overlay-showing' );
 | 
						|
				
 | 
						|
				if ( this.position != 'relative' || this.position != 'absolute' || this.position != 'fixed' ) {
 | 
						|
					_self.$wrapper.css({ position: '' });
 | 
						|
				}
 | 
						|
 | 
						|
				$(window).trigger('loading.overlay.ready');
 | 
						|
			}, _self.options.hideDelay);
 | 
						|
		},
 | 
						|
 | 
						|
		updateProgress: function() {
 | 
						|
			var _self = this;
 | 
						|
 | 
						|
			var render = function() {
 | 
						|
				if(_self.pageStatus == "complete"){
 | 
						|
		            $('.page-loader-progress').text(100);
 | 
						|
		            setTimeout(function(){
 | 
						|
		                $('.page-loader-progress').addClass('d-none');    
 | 
						|
		            }, 700);
 | 
						|
		        }
 | 
						|
		        else{            
 | 
						|
		            if(_self.progress == null){
 | 
						|
		                _self.progress = 1;
 | 
						|
		            }
 | 
						|
		           
 | 
						|
		            _self.progress = _self.progress + 1;
 | 
						|
		            if(_self.progress >= 0 && _self.progress <= 30){
 | 
						|
		                _self.animationInterval += 1;
 | 
						|
		                $('.page-loader-progress').text(_self.progress);
 | 
						|
		            }
 | 
						|
		            else if(_self.progress > 30 && _self.progress <= 60){
 | 
						|
		                _self.animationInterval += 2;
 | 
						|
		                $('.page-loader-progress').text(_self.progress);
 | 
						|
		            }
 | 
						|
		            else if(_self.progress > 60 && _self.progress <= 80){
 | 
						|
		                _self.animationInterval += 40;
 | 
						|
		                $('.page-loader-progress').text(_self.progress);
 | 
						|
		            }
 | 
						|
		            else if(_self.progress > 80 && _self.progress <= 90){
 | 
						|
		                _self.animationInterval += 80;
 | 
						|
		                $('.page-loader-progress').text(_self.progress);
 | 
						|
		            }
 | 
						|
		            else if(_self.progress > 90 && _self.progress <= 95){
 | 
						|
		                _self.animationInterval += 150;
 | 
						|
		                $('.page-loader-progress').text(_self.progress);
 | 
						|
		            }
 | 
						|
		            else if(_self.progress > 95 && _self.progress <= 99){
 | 
						|
		                _self.animationInterval += 400;
 | 
						|
		                $('.page-loader-progress').text(_self.progress);
 | 
						|
		            }
 | 
						|
		            else if(_self.progress >= 100){
 | 
						|
		                $('.page-loader-progress').text(99);
 | 
						|
		            }
 | 
						|
 | 
						|
		            if( ['percentageProgress2'].includes(_self.options.effect) ) {
 | 
						|
		            	$('.loading-overlay-background-layer').css({
 | 
						|
		            		width: _self.progress + '%'
 | 
						|
		            	});
 | 
						|
		            }
 | 
						|
		              
 | 
						|
					self.loopInside = setTimeout(render, _self.animationInterval);
 | 
						|
		        }
 | 
						|
 | 
						|
			}
 | 
						|
			render();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		matchProperties: function() {
 | 
						|
			var i,
 | 
						|
				l,
 | 
						|
				properties;
 | 
						|
 | 
						|
			properties = [
 | 
						|
				'backgroundColor',
 | 
						|
				'borderRadius'
 | 
						|
			];
 | 
						|
 | 
						|
			l = properties.length;
 | 
						|
 | 
						|
			for( i = 0; i < l; i++ ) {
 | 
						|
				var obj = {};
 | 
						|
				obj[ properties[ i ] ] = this.$wrapper.css( properties[ i ] );
 | 
						|
 | 
						|
				$.extend( this.options.css, obj );
 | 
						|
			}
 | 
						|
		},
 | 
						|
 | 
						|
		getLoaderClass: function( backgroundColor ) {
 | 
						|
			if ( !backgroundColor || backgroundColor === 'transparent' || backgroundColor === 'inherit' ) {
 | 
						|
				return 'black';
 | 
						|
			}
 | 
						|
 | 
						|
			var hexColor,
 | 
						|
				r,
 | 
						|
				g,
 | 
						|
				b,
 | 
						|
				yiq;
 | 
						|
 | 
						|
			var colorToHex = function( color ){
 | 
						|
				var hex,
 | 
						|
					rgb;
 | 
						|
 | 
						|
				if( color.indexOf('#') >- 1 ){
 | 
						|
					hex = color.replace('#', '');
 | 
						|
				} else {
 | 
						|
					rgb = color.match(/\d+/g);
 | 
						|
					hex = ('0' + parseInt(rgb[0], 10).toString(16)).slice(-2) + ('0' + parseInt(rgb[1], 10).toString(16)).slice(-2) + ('0' + parseInt(rgb[2], 10).toString(16)).slice(-2);
 | 
						|
				}
 | 
						|
 | 
						|
				if ( hex.length === 3 ) {
 | 
						|
					hex = hex + hex;
 | 
						|
				}
 | 
						|
 | 
						|
				return hex;
 | 
						|
			};
 | 
						|
 | 
						|
			hexColor = colorToHex( backgroundColor );
 | 
						|
 | 
						|
			r = parseInt( hexColor.substr( 0, 2), 16 );
 | 
						|
			g = parseInt( hexColor.substr( 2, 2), 16 );
 | 
						|
			b = parseInt( hexColor.substr( 4, 2), 16 );
 | 
						|
			yiq = ((r * 299) + (g * 587) + (b * 114)) / 1000;
 | 
						|
 | 
						|
			return ( yiq >= 128 ) ? 'black' : 'white';
 | 
						|
		},
 | 
						|
 | 
						|
		dynamicShowHide: function( effect ) {
 | 
						|
			var _self = this;
 | 
						|
 | 
						|
			// Remove Loading Overlay Data
 | 
						|
			$('body').removeData('loadingOverlay');
 | 
						|
 | 
						|
			// Remove Html Of Loading Overlay
 | 
						|
			$('.loading-overlay').remove();
 | 
						|
 | 
						|
			if( effect == '' ) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			// Initialize New Loading Overlay (second parameter is to NO inherit data-plugin-options)
 | 
						|
			$('body').loadingOverlay({
 | 
						|
				effect: effect ? effect : 'pulse',
 | 
						|
				isDynamicHideShow: true
 | 
						|
			}, true);
 | 
						|
 | 
						|
			// Show Loading Overlay Loader
 | 
						|
			$('body').data('loadingOverlay').show();
 | 
						|
 | 
						|
			// Hide Loading Overlay Loader
 | 
						|
			setTimeout(function(){
 | 
						|
				$('body').data('loadingOverlay').hide();
 | 
						|
			}, 3000);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		dynamicShowHideEvents: function() {
 | 
						|
			var _self = this;
 | 
						|
 | 
						|
			// Button
 | 
						|
			$(document).off('click.loading-overlay-button').on('click.loading-overlay-button', '.loading-overlay-button', function(e){
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				_self.dynamicShowHide( $(this).data('effect') );
 | 
						|
			});
 | 
						|
 | 
						|
			// Select
 | 
						|
			$(document).off('change.loading-overlay-select').on('change.loading-overlay-select', '.loading-overlay-select', function(){
 | 
						|
				_self.dynamicShowHide( $(this).val() );
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		LoadingOverlay: LoadingOverlay
 | 
						|
	});
 | 
						|
 | 
						|
	// expose as a jquery plugin
 | 
						|
	$.fn.loadingOverlay = function( opts, noInheritOptions ) {
 | 
						|
		return this.each(function() {
 | 
						|
			var $this = $( this );
 | 
						|
 | 
						|
			var loadingOverlay = $this.data( 'loadingOverlay' );
 | 
						|
			if ( loadingOverlay ) {
 | 
						|
				return loadingOverlay;
 | 
						|
			} else {
 | 
						|
				var options = opts || $this.data( 'loading-overlay-options' ) || {};
 | 
						|
				return new LoadingOverlay( $this, options, noInheritOptions );
 | 
						|
			}
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	// auto init
 | 
						|
	$('[data-loading-overlay]').loadingOverlay();
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Masonry
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__masonry';
 | 
						|
 | 
						|
	var PluginMasonry = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginMasonry.defaults = {
 | 
						|
 | 
						|
	};
 | 
						|
 | 
						|
	PluginMasonry.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginMasonry.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			if (!($.isFunction($.fn.isotope))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this,
 | 
						|
				$window = $(window);
 | 
						|
 | 
						|
			self.$loader = false;
 | 
						|
 | 
						|
			if (self.options.wrapper.parents('.masonry-loader').get(0)) {
 | 
						|
				self.$loader = self.options.wrapper.parents('.masonry-loader');
 | 
						|
				self.createLoader();
 | 
						|
			}
 | 
						|
 | 
						|
			self.options.wrapper.one('layoutComplete', function(event, laidOutItems) {
 | 
						|
				self.removeLoader();
 | 
						|
			});
 | 
						|
 | 
						|
			self.options.wrapper.waitForImages(function() {
 | 
						|
				self.options.wrapper.isotope(self.options);	
 | 
						|
			});
 | 
						|
 | 
						|
			$(window).on('resize', function() {
 | 
						|
				setTimeout(function() {
 | 
						|
					self.options.wrapper.isotope('layout');
 | 
						|
				}, 300);
 | 
						|
			});
 | 
						|
 | 
						|
			setTimeout(function() {
 | 
						|
				self.removeLoader();
 | 
						|
			}, 3000);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		createLoader: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			var loaderTemplate = [
 | 
						|
				'<div class="bounce-loader">',
 | 
						|
					'<div class="bounce1"></div>',
 | 
						|
					'<div class="bounce2"></div>',
 | 
						|
					'<div class="bounce3"></div>',
 | 
						|
				'</div>'
 | 
						|
			].join('');
 | 
						|
 | 
						|
			self.$loader.append(loaderTemplate);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		removeLoader: function() {
 | 
						|
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if (self.$loader) {
 | 
						|
 | 
						|
				self.$loader.removeClass('masonry-loader-showing');
 | 
						|
 | 
						|
				setTimeout(function() {
 | 
						|
					self.$loader.addClass('masonry-loader-loaded');
 | 
						|
				}, 300);
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginMasonry: PluginMasonry
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginMasonry = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginMasonry($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Match Height
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__matchHeight';
 | 
						|
 | 
						|
	var PluginMatchHeight = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginMatchHeight.defaults = {
 | 
						|
		byRow: true,
 | 
						|
		property: 'height',
 | 
						|
		target: null,
 | 
						|
		remove: false
 | 
						|
	};
 | 
						|
 | 
						|
	PluginMatchHeight.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginMatchHeight.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			if (!($.isFunction($.fn.matchHeight))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			self.options.wrapper.matchHeight(self.options);
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginMatchHeight: PluginMatchHeight
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginMatchHeight = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginMatchHeight($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Parallax
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__parallax';
 | 
						|
 | 
						|
	var PluginParallax = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginParallax.defaults = {
 | 
						|
		speed: 1.5,
 | 
						|
		horizontalPosition: '50%',
 | 
						|
		offset: 0,
 | 
						|
		parallaxDirection: 'top',
 | 
						|
		parallaxHeight: '180%',
 | 
						|
		parallaxScale: false,
 | 
						|
		parallaxScaleInvert: false,
 | 
						|
		scrollableParallax: false,
 | 
						|
		scrollableParallaxMinWidth: 991,
 | 
						|
		startOffset: 7,
 | 
						|
		transitionDuration: '200ms',
 | 
						|
		cssProperty: 'width',
 | 
						|
		cssValueStart: 40,
 | 
						|
		cssValueEnd: 100,
 | 
						|
		cssValueUnit: 'vw',
 | 
						|
		mouseParallax: false
 | 
						|
	};
 | 
						|
 | 
						|
	PluginParallax.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginParallax.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this,
 | 
						|
				$window = $(window),
 | 
						|
				offset,
 | 
						|
				yPos,
 | 
						|
				bgpos,
 | 
						|
				background,
 | 
						|
				rotateY;
 | 
						|
 | 
						|
			// Mouse Parallax
 | 
						|
			if( self.options.mouseParallax ) {
 | 
						|
 | 
						|
				$window.mousemove(function(e) {
 | 
						|
 | 
						|
					$('.parallax-mouse-object', self.options.wrapper).each(function() {
 | 
						|
 | 
						|
				        var moving_value = $( this ).attr('data-value');
 | 
						|
				        var x = (e.clientX * moving_value) / 250;
 | 
						|
				        var y = (e.clientY * moving_value) / 250;
 | 
						|
 | 
						|
				        $( this ).css('transform', 'translateX(' + x + 'px) translateY(' + y + 'px)');
 | 
						|
				    });
 | 
						|
 | 
						|
				});
 | 
						|
 | 
						|
				return this;
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
			// Scrollable
 | 
						|
			if( self.options.scrollableParallax && $(window).width() > self.options.scrollableParallaxMinWidth ) {
 | 
						|
				var $scrollableWrapper = self.options.wrapper.find('.scrollable-parallax-wrapper');
 | 
						|
 | 
						|
				if( $scrollableWrapper.get(0) ) {
 | 
						|
 | 
						|
					var progress 	 = ( $(window).scrollTop() > ( self.options.wrapper.offset().top + $(window).outerHeight() ) ) ? self.options.cssValueEnd : self.options.cssValueStart,
 | 
						|
						cssValueUnit = self.options.cssValueUnit ? self.options.cssValueUnit : '';
 | 
						|
 | 
						|
					$scrollableWrapper.css({
 | 
						|
						'background-image' : 'url(' + self.options.wrapper.data('image-src') + ')',
 | 
						|
						'background-size' : 'cover',
 | 
						|
						'background-position' : 'center',
 | 
						|
						'background-attachment' : 'fixed',
 | 
						|
						'transition' : 'ease '+ self.options.cssProperty +' '+ self.options.transitionDuration,
 | 
						|
						'width' : progress + '%'
 | 
						|
					});
 | 
						|
 | 
						|
					$(window).on('scroll', function(e){
 | 
						|
						if( self.options.wrapper.visible( true ) ) {
 | 
						|
							var $window = $(window),
 | 
						|
								scrollTop = $window.scrollTop(),
 | 
						|
						    	elementOffset = self.options.wrapper.offset().top,
 | 
						|
						     	currentElementOffset = (elementOffset - scrollTop);
 | 
						|
 | 
						|
						   	var scrollPercent = Math.abs( +( currentElementOffset - $window.height() ) / (self.options.startOffset ? self.options.startOffset : 7) );
 | 
						|
						 	
 | 
						|
						 	// Increment progress value according scroll position
 | 
						|
						 	if( scrollPercent <= self.options.cssValueEnd && progress <= self.options.cssValueEnd ) {
 | 
						|
						 		progress = self.options.cssValueStart + scrollPercent;
 | 
						|
						 	}
 | 
						|
 | 
						|
						 	// Adjust CSS end value
 | 
						|
						 	if( progress > self.options.cssValueEnd ) {
 | 
						|
						 		progress = self.options.cssValueEnd;
 | 
						|
						 	}
 | 
						|
 | 
						|
						 	// Adjust CSS start value
 | 
						|
						 	if( progress < self.options.cssValueStart ) {
 | 
						|
						 		progress = self.options.cssValueStart;
 | 
						|
						 	}
 | 
						|
 | 
						|
						 	var styles = {}
 | 
						|
						 	styles[self.options.cssProperty] = progress + cssValueUnit;
 | 
						|
 | 
						|
							$scrollableWrapper.css(styles);
 | 
						|
						}
 | 
						|
					});
 | 
						|
 | 
						|
				}
 | 
						|
 | 
						|
				return;
 | 
						|
			}
 | 
						|
 | 
						|
			// Create Parallax Element
 | 
						|
			if( self.options.fadeIn ) {
 | 
						|
				background = $('<div class="parallax-background fadeIn animated"></div>');
 | 
						|
			} else {
 | 
						|
				background = $('<div class="parallax-background"></div>');
 | 
						|
			}
 | 
						|
 | 
						|
			// Set Style for Parallax Element
 | 
						|
			background.css({
 | 
						|
				'background-image' : 'url(' + self.options.wrapper.data('image-src') + ')',
 | 
						|
				'background-size' : 'cover',
 | 
						|
				'position' : 'absolute',
 | 
						|
				'top' : 0,
 | 
						|
				'left' : 0,
 | 
						|
				'width' : '100%',
 | 
						|
				'height' : self.options.parallaxHeight
 | 
						|
			});
 | 
						|
 | 
						|
			if( self.options.parallaxScale ) {
 | 
						|
				background.css({
 | 
						|
					'transition' : 'transform 500ms ease-out'
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			// Add Parallax Element on DOM
 | 
						|
			self.options.wrapper.prepend(background);
 | 
						|
 | 
						|
			// Set Overlfow Hidden and Position Relative to Parallax Wrapper
 | 
						|
			self.options.wrapper.css({
 | 
						|
				'position' : 'relative',
 | 
						|
				'overflow' : 'hidden'
 | 
						|
			});
 | 
						|
 | 
						|
			// Parallax Effect on Scroll & Resize
 | 
						|
			var parallaxEffectOnScrolResize = function() {
 | 
						|
				$window.on('scroll resize', function() {
 | 
						|
					offset  = self.options.wrapper.offset();
 | 
						|
					yPos    = -($window.scrollTop() - (offset.top - 100)) / ((self.options.speed + 2 ));
 | 
						|
					plxPos  = (yPos < 0) ? Math.abs(yPos) : -Math.abs(yPos);
 | 
						|
					rotateY = ( $('html[dir="rtl"]').get(0) ) ? ' rotateY(180deg)' : ''; // RTL
 | 
						|
 | 
						|
					if( !self.options.parallaxScale ) {
 | 
						|
 | 
						|
						if( self.options.parallaxDirection == 'bottom' ) {
 | 
						|
							self.options.offset = 250;
 | 
						|
						}
 | 
						|
 | 
						|
						var y = ( (plxPos - 50) + (self.options.offset) );
 | 
						|
						if( self.options.parallaxDirection == 'bottom' ) {
 | 
						|
							y = ( y < 0 ) ? Math.abs( y ) : -Math.abs( y );
 | 
						|
						}
 | 
						|
 | 
						|
						background.css({
 | 
						|
							'transform' : 'translate3d(0, '+ y +'px, 0)' + rotateY,
 | 
						|
							'background-position-x' : self.options.horizontalPosition
 | 
						|
						});
 | 
						|
 | 
						|
					} else {
 | 
						|
 | 
						|
						var	scrollTop = $window.scrollTop(),
 | 
						|
					    	elementOffset = self.options.wrapper.offset().top,
 | 
						|
					     	currentElementOffset = (elementOffset - scrollTop),
 | 
						|
					   		scrollPercent = Math.abs( +( currentElementOffset - $window.height() ) / (self.options.startOffset ? self.options.startOffset : 7) );
 | 
						|
 | 
						|
					   	scrollPercent = parseInt((scrollPercent >= 100) ? 100 : scrollPercent);
 | 
						|
 | 
						|
					   	var currentScale = (scrollPercent / 100) * 50;
 | 
						|
 | 
						|
					   	if ( !self.options.parallaxScaleInvert ) {
 | 
						|
							background.css({
 | 
						|
								'transform' : 'scale(1.' + String(currentScale).padStart(2, '0') + ', 1.' + String(currentScale).padStart(2, '0') + ')'
 | 
						|
							});
 | 
						|
						} else {
 | 
						|
							background.css({
 | 
						|
								'transform' : 'scale(1.' + String(50 - currentScale).padStart(2, '0') + ', 1.' + String(50 - currentScale).padStart(2, '0') + ')'
 | 
						|
							});
 | 
						|
						}
 | 
						|
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				$window.trigger('scroll');
 | 
						|
			}
 | 
						|
 | 
						|
			if (!$.browser.mobile) {
 | 
						|
				parallaxEffectOnScrolResize();
 | 
						|
			} else {
 | 
						|
				if( self.options.enableOnMobile == true ) {
 | 
						|
					parallaxEffectOnScrolResize();
 | 
						|
				} else {
 | 
						|
					self.options.wrapper.addClass('parallax-disabled');
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginParallax: PluginParallax
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginParallax = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginParallax($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Progress Bar
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__progressBar';
 | 
						|
 | 
						|
	var PluginProgressBar = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginProgressBar.defaults = {
 | 
						|
		accX: 0,
 | 
						|
		accY: -50,
 | 
						|
		delay: 1
 | 
						|
	};
 | 
						|
 | 
						|
	PluginProgressBar.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginProgressBar.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this,
 | 
						|
				$el = this.options.wrapper,
 | 
						|
				delay = 1;
 | 
						|
 | 
						|
			delay = ($el.attr('data-appear-animation-delay') ? $el.attr('data-appear-animation-delay') : self.options.delay);
 | 
						|
 | 
						|
			$el.addClass($el.attr('data-appear-animation'));
 | 
						|
 | 
						|
			setTimeout(function() {
 | 
						|
 | 
						|
				$el.animate({
 | 
						|
					width: $el.attr('data-appear-progress-animation')
 | 
						|
				}, 1500, 'easeOutQuad', function() {
 | 
						|
					$el.find('.progress-bar-tooltip').animate({
 | 
						|
						opacity: 1
 | 
						|
					}, 500, 'easeOutQuad');
 | 
						|
				});
 | 
						|
 | 
						|
			}, delay);
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginProgressBar: PluginProgressBar
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginProgressBar = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginProgressBar($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Random Images
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__randomimages';
 | 
						|
 | 
						|
	var PluginRandomImages = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginRandomImages.defaults = {
 | 
						|
		minWindowWidth: 0,
 | 
						|
		random: true,
 | 
						|
		imagesListURL: null,
 | 
						|
		lightboxImagesListURL: null,
 | 
						|
        delay: null,
 | 
						|
        animateIn: 'fadeIn',
 | 
						|
		animateOut: 'fadeOut',
 | 
						|
		stopAtImageIndex: false, // The value shoudl be the index value of array with images as string. Eg: '2' 
 | 
						|
		stopAfterFewSeconds: false, // The value should be in mili-seconds. Eg: 10000 = 10 seconds
 | 
						|
		stopAfterXTimes: false,
 | 
						|
		accY: 0
 | 
						|
	};
 | 
						|
 | 
						|
	PluginRandomImages.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			this.$el = $el;
 | 
						|
            this.st = '';
 | 
						|
			this.times = 0;
 | 
						|
			this.perImageIndex = 0;
 | 
						|
 | 
						|
            if( $el.is('img') && typeof opts.imagesListURL == 'undefined' ) {
 | 
						|
                return false;
 | 
						|
            }
 | 
						|
 | 
						|
            this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginRandomImages.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
            var self = this;
 | 
						|
			
 | 
						|
			// Control the screens size we want to have the plugin working
 | 
						|
			if( $(window).width() < self.options.minWindowWidth  ) {
 | 
						|
				return false;
 | 
						|
			}
 | 
						|
 | 
						|
			// Check if is single image or wrapper with images inside
 | 
						|
            if( self.$el.is('img') ) {
 | 
						|
				
 | 
						|
				// Check it's inside a lightbox
 | 
						|
				self.isInsideLightbox = self.$el.closest('.lightbox').length ? true : false;
 | 
						|
 | 
						|
				// Push the initial image to lightbox list/array
 | 
						|
				if( self.isInsideLightbox && self.options.lightboxImagesListURL ) {
 | 
						|
					self.options.lightboxImagesListURL.push( self.$el.closest('.lightbox').attr('href') );
 | 
						|
				}
 | 
						|
	
 | 
						|
				// Push the current image src to the array
 | 
						|
				self.options.imagesListURL.push( self.$el.attr('src') );
 | 
						|
 | 
						|
				// Start with lastIndex as the first image loaded on the page
 | 
						|
				self.lastIndex = self.options.imagesListURL.length - 1;
 | 
						|
 | 
						|
				// Identify the last random image element (if has more than one on the page)
 | 
						|
				if( self.options.random == false ) {
 | 
						|
					$('.plugin-random-images').each(function(i){
 | 
						|
						if( i == $('.plugin-random-images').length - 1 ) {
 | 
						|
							$(this).addClass('the-last');
 | 
						|
						}
 | 
						|
					});
 | 
						|
				}
 | 
						|
 | 
						|
				// Start the recursive timeout
 | 
						|
				setTimeout(function(){
 | 
						|
					self.recursiveTimeout( 
 | 
						|
						self.perImageTag, 
 | 
						|
						self.options.delay == null ? 3000 : self.options.delay
 | 
						|
					);
 | 
						|
				}, self.options.delay == null ? 300 : self.options.delay / 3);
 | 
						|
 | 
						|
			} else {
 | 
						|
				
 | 
						|
				// Start the recursive timeout
 | 
						|
				setTimeout( self.recursiveTimeout( 
 | 
						|
					self.perWrapper, 
 | 
						|
					self.options.delay ? self.options.delay : getPerWrapperHighDelay(), 
 | 
						|
					false 
 | 
						|
				), 300);
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
			// Stop After Few Seconds
 | 
						|
			if( self.options.stopAfterFewSeconds ) {
 | 
						|
				setTimeout(function(){
 | 
						|
					clearTimeout(self.st);
 | 
						|
				}, self.options.stopAfterFewSeconds);
 | 
						|
			}
 | 
						|
			
 | 
						|
			return this;
 | 
						|
 | 
						|
		},
 | 
						|
 | 
						|
		perImageTag: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			// Generate a random index to make the images rotate randomly
 | 
						|
			var index = self.options.random ? Math.floor(Math.random() * self.options.imagesListURL.length) : self.lastIndex;
 | 
						|
 | 
						|
			// Avoid repeat the same image
 | 
						|
			if( self.lastIndex !== '' && self.lastIndex == index ) {
 | 
						|
				if( self.options.random ) {
 | 
						|
					while( index == self.lastIndex ) {
 | 
						|
						index = Math.floor(Math.random() * self.options.imagesListURL.length);
 | 
						|
					}
 | 
						|
				} else {
 | 
						|
					index = index - 1;
 | 
						|
					if( index == -1 ) {
 | 
						|
						index = self.options.imagesListURL.length - 1;
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			// Turn the image ready for animations
 | 
						|
			self.$el.addClass('animated');
 | 
						|
 | 
						|
			// Remove the entrance animation class and add the out animation class
 | 
						|
			self.$el.removeClass( self.options.animateIn ).addClass( self.options.animateOut );
 | 
						|
			
 | 
						|
			// Change the image src and add the class for entrance animation
 | 
						|
			setTimeout( function(){
 | 
						|
				self.$el.attr('src', self.options.imagesListURL[index]).removeClass( self.options.animateOut ).addClass(self.options.animateIn);
 | 
						|
 | 
						|
				if( self.isInsideLightbox && self.options.lightboxImagesListURL ) {
 | 
						|
					self.$el.closest('.lightbox').attr('href', self.options.lightboxImagesListURL[index]);
 | 
						|
				}
 | 
						|
			}, 1000);
 | 
						|
			
 | 
						|
			// Save the last index for future checks
 | 
						|
			self.lastIndex = index;
 | 
						|
			
 | 
						|
			// Increment the times var
 | 
						|
			self.times++;
 | 
						|
 | 
						|
			// Save the index for stopAtImageIndex option
 | 
						|
			self.perImageIndex = index;
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		// Iterate the imaes loop and get the higher value
 | 
						|
		getPerWrapperHighDelay: function() {
 | 
						|
			var self = this,
 | 
						|
				$wrapper = self.$el,
 | 
						|
				delay = 0;
 | 
						|
 | 
						|
			$wrapper.find('img').each(function(){
 | 
						|
				var $image = $(this);
 | 
						|
				
 | 
						|
				if( $image.data('rimage-delay') && parseInt( $image.data('rimage-delay') ) > delay ) {
 | 
						|
					delay = parseInt( $image.data('rimage-delay') );
 | 
						|
				}
 | 
						|
			});
 | 
						|
 | 
						|
			return delay;
 | 
						|
		},
 | 
						|
 | 
						|
		perWrapper: function() {
 | 
						|
			var self = this,
 | 
						|
				$wrapper = self.$el;
 | 
						|
 | 
						|
			// Turns the imageLlistURL into an array
 | 
						|
			self.options.imagesListURL = [];
 | 
						|
 | 
						|
			// Find all images inside the element wrapper and push their sources to image list array
 | 
						|
			$wrapper.find('img').each(function(){
 | 
						|
				var $image = $(this);
 | 
						|
				self.options.imagesListURL.push( $image.attr('src') ); 
 | 
						|
			});
 | 
						|
 | 
						|
			// Shuffle the images list array (random effect)
 | 
						|
			self.options.imagesListURL = self.shuffle( self.options.imagesListURL );
 | 
						|
 | 
						|
			// Iterate over each image and make some checks like delay for each image, animations, etc...
 | 
						|
			$wrapper.find('img').each(function(index){
 | 
						|
				var $image = $(this),
 | 
						|
					animateIn  = $image.data('rimage-animate-in') ? $image.data('rimage-animate-in') : self.options.animateIn,
 | 
						|
					animateOut = $image.data('rimage-animate-out') ? $image.data('rimage-animate-out') : self.options.animateOut,
 | 
						|
					delay      = $image.data('rimage-delay') ? $image.data('rimage-delay') : 2000;
 | 
						|
 | 
						|
				$image.addClass('animated');
 | 
						|
 | 
						|
				setTimeout( function(){
 | 
						|
					$image.removeClass( animateIn ).addClass( animateOut );
 | 
						|
				}, delay / 2);
 | 
						|
 | 
						|
				setTimeout( function(){
 | 
						|
					$image.attr('src', self.options.imagesListURL[index]).removeClass( animateOut ).addClass(animateIn);
 | 
						|
				}, delay);
 | 
						|
 | 
						|
			});
 | 
						|
			
 | 
						|
			// Increment the times variable
 | 
						|
			self.times++;
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		recursiveTimeout: function(callback, delay) {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			var timeout = function() {
 | 
						|
 | 
						|
				if( callback !== null ) {
 | 
						|
					callback.call(self);
 | 
						|
				}
 | 
						|
 | 
						|
				// Recursive
 | 
						|
				self.st = setTimeout(timeout, delay == null ? 1000 : delay);
 | 
						|
 | 
						|
				if( self.options.random == false ) {
 | 
						|
					if( self.$el.hasClass('the-last') ) {
 | 
						|
						$('.plugin-random-images').trigger('rimages.start');
 | 
						|
					} else {
 | 
						|
						clearTimeout(self.st);
 | 
						|
					}
 | 
						|
				}
 | 
						|
 | 
						|
				// Stop At Image Index
 | 
						|
				if( self.options.stopAtImageIndex && parseInt(self.options.stopAtImageIndex) == self.perImageIndex ) {
 | 
						|
					clearTimeout(self.st);
 | 
						|
				}
 | 
						|
 | 
						|
				// Stop After X Timers
 | 
						|
				if( self.options.stopAfterXTimes == self.times ) {
 | 
						|
					clearTimeout(self.st);
 | 
						|
				}
 | 
						|
			}
 | 
						|
			timeout();
 | 
						|
 | 
						|
			self.$el.on('rimages.start', function(){
 | 
						|
				clearTimeout(self.st);
 | 
						|
				self.st = setTimeout(timeout, delay == null ? 1000 : delay);
 | 
						|
			});
 | 
						|
 | 
						|
		},
 | 
						|
		
 | 
						|
		shuffle: function( array ) {
 | 
						|
			for (var i = array.length - 1; i > 0; i--) {
 | 
						|
				var j = Math.floor(Math.random() * (i + 1));
 | 
						|
				var temp = array[i];
 | 
						|
				array[i] = array[j];
 | 
						|
				array[j] = temp;
 | 
						|
			}
 | 
						|
 | 
						|
			return array;
 | 
						|
		}
 | 
						|
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginRandomImages: PluginRandomImages
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginRandomImages = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginRandomImages($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Read More
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__readmore';
 | 
						|
 | 
						|
	var PluginReadMore = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginReadMore.defaults = {
 | 
						|
		buttonOpenLabel: 'Read More <i class="fas fa-chevron-down text-2 ms-1"></i>',
 | 
						|
		buttonCloseLabel: 'Read Less <i class="fas fa-chevron-up text-2 ms-1"></i>',
 | 
						|
		enableToggle: true,
 | 
						|
		maxHeight: 110,
 | 
						|
		overlayColor: '#FFF',
 | 
						|
		overlayHeight: 100,
 | 
						|
		startOpened: false,
 | 
						|
		align: 'left'
 | 
						|
	};
 | 
						|
 | 
						|
	PluginReadMore.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build()
 | 
						|
				.events();
 | 
						|
 | 
						|
			if( self.options.startOpened ) {
 | 
						|
				self.options.wrapper.find('.readmore-button-wrapper > a').trigger('click');
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginReadMore.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			self.options.wrapper.addClass('position-relative');
 | 
						|
 | 
						|
			// Overlay
 | 
						|
			self.options.wrapper.append( '<div class="readmore-overlay"></div>' );
 | 
						|
 | 
						|
			// Check if is Safari
 | 
						|
			var backgroundCssValue = 'linear-gradient(180deg, rgba(2, 0, 36, 0) 0%, '+ self.options.overlayColor +' 100%)';
 | 
						|
			if( $('html').hasClass('safari') ) {
 | 
						|
				backgroundCssValue = '-webkit-linear-gradient(top, rgba(2, 0, 36, 0) 0%, '+ self.options.overlayColor +' 100%)'
 | 
						|
			}
 | 
						|
			
 | 
						|
			self.options.wrapper.find('.readmore-overlay').css({
 | 
						|
				background: backgroundCssValue,
 | 
						|
				position: 'absolute',
 | 
						|
				bottom: 0,
 | 
						|
				left: 0,
 | 
						|
				width: '100%',
 | 
						|
				height: self.options.overlayHeight,
 | 
						|
				'z-index': 1
 | 
						|
			});
 | 
						|
 | 
						|
			// Read More Button
 | 
						|
			self.options.wrapper.find('.readmore-button-wrapper').removeClass('d-none').css({
 | 
						|
				position: 'absolute',
 | 
						|
				bottom: 0,
 | 
						|
				left: 0,
 | 
						|
				width: '100%',
 | 
						|
				'z-index': 2
 | 
						|
			});	
 | 
						|
 | 
						|
			// Button Label
 | 
						|
			self.options.wrapper.find('.readmore-button-wrapper > a').html( self.options.buttonOpenLabel );
 | 
						|
 | 
						|
			self.options.wrapper.css({
 | 
						|
				'height': self.options.maxHeight,
 | 
						|
				'overflow-y': 'hidden'
 | 
						|
			});
 | 
						|
 | 
						|
			// Alignment
 | 
						|
			switch ( self.options.align ) {
 | 
						|
				case 'center':
 | 
						|
					self.options.wrapper.find('.readmore-button-wrapper').addClass('text-center');
 | 
						|
					break;
 | 
						|
 | 
						|
				case 'right':
 | 
						|
					self.options.wrapper.find('.readmore-button-wrapper').addClass('text-end');
 | 
						|
					break;
 | 
						|
 | 
						|
				case 'left':
 | 
						|
				default:
 | 
						|
					self.options.wrapper.find('.readmore-button-wrapper').addClass('text-start');
 | 
						|
					break;
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
 | 
						|
		},
 | 
						|
 | 
						|
		events: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			// Read More
 | 
						|
			self.readMore = function() {
 | 
						|
				self.options.wrapper.find('.readmore-button-wrapper > a:not(.readless)').on('click', function(e){
 | 
						|
					e.preventDefault();
 | 
						|
 | 
						|
					var $this = $(this);
 | 
						|
 | 
						|
					setTimeout(function(){
 | 
						|
						self.options.wrapper.animate({
 | 
						|
							'height': self.options.wrapper[0].scrollHeight
 | 
						|
						}, function(){
 | 
						|
							if( !self.options.enableToggle ) {
 | 
						|
								$this.fadeOut();
 | 
						|
							}
 | 
						|
 | 
						|
							$this.html( self.options.buttonCloseLabel ).addClass('readless').off('click');
 | 
						|
 | 
						|
							self.readLess();
 | 
						|
 | 
						|
							self.options.wrapper.find('.readmore-overlay').fadeOut();
 | 
						|
							self.options.wrapper.css({
 | 
						|
								'max-height': 'none',
 | 
						|
								'overflow': 'visible'
 | 
						|
							});
 | 
						|
 | 
						|
							self.options.wrapper.find('.readmore-button-wrapper').animate({
 | 
						|
								bottom: -20
 | 
						|
							});
 | 
						|
						});
 | 
						|
					}, 200);
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			// Read Less
 | 
						|
			self.readLess = function() {
 | 
						|
				self.options.wrapper.find('.readmore-button-wrapper > a.readless').on('click', function(e){
 | 
						|
					e.preventDefault();
 | 
						|
 | 
						|
					var $this = $(this);
 | 
						|
 | 
						|
					// Button
 | 
						|
					self.options.wrapper.find('.readmore-button-wrapper').animate({
 | 
						|
						bottom: 0
 | 
						|
					});
 | 
						|
 | 
						|
					// Overlay
 | 
						|
					self.options.wrapper.find('.readmore-overlay').fadeIn();
 | 
						|
 | 
						|
					setTimeout(function(){
 | 
						|
						self.options.wrapper.height(self.options.wrapper[0].scrollHeight).animate({
 | 
						|
							'height': self.options.maxHeight
 | 
						|
						}, function(){
 | 
						|
							$this.html( self.options.buttonOpenLabel ).removeClass('readless').off('click');
 | 
						|
 | 
						|
							self.readMore();
 | 
						|
 | 
						|
							self.options.wrapper.css({
 | 
						|
								'overflow': 'hidden'
 | 
						|
							});
 | 
						|
						});
 | 
						|
					}, 200);
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			// First Load
 | 
						|
			self.readMore();
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginReadMore: PluginReadMore
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginReadMore = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginReadMore($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Revolution Slider
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__revolution';
 | 
						|
 | 
						|
	var PluginRevolutionSlider = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginRevolutionSlider.defaults = {
 | 
						|
		sliderType: 'standard',
 | 
						|
		sliderLayout: 'fullwidth',
 | 
						|
		delay: 9000,
 | 
						|
		gridwidth: 1170,
 | 
						|
		gridheight: 500,
 | 
						|
		spinner: 'spinner3',
 | 
						|
		disableProgressBar: 'on',
 | 
						|
		parallax: {
 | 
						|
			type: 'off',
 | 
						|
			bgparallax: 'off'
 | 
						|
		},
 | 
						|
		navigation: {
 | 
						|
			keyboardNavigation: 'off',
 | 
						|
			keyboard_direction: 'horizontal',
 | 
						|
			mouseScrollNavigation: 'off',
 | 
						|
			onHoverStop: 'off',
 | 
						|
			touch: {
 | 
						|
				touchenabled: 'on',
 | 
						|
				swipe_threshold: 75,
 | 
						|
				swipe_min_touches: 1,
 | 
						|
				swipe_direction: 'horizontal',
 | 
						|
				drag_block_vertical: false
 | 
						|
			},
 | 
						|
			arrows: {
 | 
						|
				enable: true,
 | 
						|
				hide_onmobile: false,
 | 
						|
				hide_under: 0,
 | 
						|
				hide_onleave: true,
 | 
						|
				hide_delay: 200,
 | 
						|
				hide_delay_mobile: 1200,
 | 
						|
				left: {
 | 
						|
					h_align: 'left',
 | 
						|
					v_align: 'center',
 | 
						|
					h_offset: 30,
 | 
						|
					v_offset: 0
 | 
						|
				},
 | 
						|
				right: {
 | 
						|
					h_align: 'right',
 | 
						|
					v_align: 'center',
 | 
						|
					h_offset: 30,
 | 
						|
					v_offset: 0
 | 
						|
				}
 | 
						|
			}
 | 
						|
		},
 | 
						|
 | 
						|
		/* ADDONS */
 | 
						|
	    addOnTypewriter: {
 | 
						|
			enable: false
 | 
						|
		},
 | 
						|
		addOnWhiteboard: {
 | 
						|
			enable: false,
 | 
						|
 | 
						|
		},
 | 
						|
	    whiteboard: {
 | 
						|
	        movehand: {
 | 
						|
	            src: '../vendor/rs-plugin/revolution-addons/whiteboard/assets/images/hand_point_right.png',
 | 
						|
	            width: 400,
 | 
						|
	            height: 1000,
 | 
						|
	            handtype: 'right',
 | 
						|
	            transform: {
 | 
						|
	                transformX: 50,
 | 
						|
	                transformY: 50
 | 
						|
	            },
 | 
						|
	            jittering: {
 | 
						|
	                distance: '80',
 | 
						|
	                distance_horizontal: '100',
 | 
						|
	                repeat: '5',
 | 
						|
	                offset: '10',
 | 
						|
	                offset_horizontal: '0'
 | 
						|
	            },
 | 
						|
	            rotation: {
 | 
						|
	                angle: '10',
 | 
						|
	                repeat: '3'
 | 
						|
	            }
 | 
						|
	        },
 | 
						|
	        writehand: {
 | 
						|
	            src: '../vendor/rs-plugin/revolution-addons/whiteboard/assets/images/write_right_angle.png',
 | 
						|
	            width: 572,
 | 
						|
	            height: 691,
 | 
						|
	            handtype: 'right',
 | 
						|
	            transform: {
 | 
						|
	                transformX: 50,
 | 
						|
	                transformY: 50
 | 
						|
	            },
 | 
						|
	            jittering: {
 | 
						|
	                distance: '80',
 | 
						|
	                distance_horizontal: '100',
 | 
						|
	                repeat: '5',
 | 
						|
	                offset: '10',
 | 
						|
	                offset_horizontal: '0'
 | 
						|
	            },
 | 
						|
	            rotation:{
 | 
						|
	                angle: '10',
 | 
						|
	                repeat: '3'
 | 
						|
	            }
 | 
						|
	        }
 | 
						|
	    },
 | 
						|
	    addOnParticles: {
 | 
						|
	    	enable: false
 | 
						|
	    },
 | 
						|
	    particles: {
 | 
						|
			startSlide: "first", 
 | 
						|
			endSlide: "last", 
 | 
						|
			zIndex: "1",
 | 
						|
			particles: {
 | 
						|
				number: {value: 80}, color: {value: "#ffffff"},
 | 
						|
				shape: {
 | 
						|
					type: "circle", stroke: {width: 0, color: "#ffffff", opacity: 1},
 | 
						|
					image: {src: ""}
 | 
						|
				},
 | 
						|
				opacity: {value: 0.5, random: true, min: 0.25, anim: {enable: false, speed: 3, opacity_min: 0, sync: false}},
 | 
						|
				size: {value: 2, random: false, min: 30, anim: {enable: false, speed: 40, size_min: 1, sync: false}},
 | 
						|
				line_linked: {enable: true, distance: 150, color: "#ffffff", opacity: 0.4, width: 1},
 | 
						|
				move: {enable: true, speed: 6, direction: "none", random: true, min_speed: 6, straight: false, out_mode: "out"}
 | 
						|
			},
 | 
						|
			interactivity: {
 | 
						|
				events: {onhover: {enable: false, mode: "repulse"}, onclick: {enable: false, mode: "repulse"}},
 | 
						|
				modes: {grab: {distance: 400, line_linked: {opacity: 0.5}}, bubble: {distance: 400, size: 40, opacity: 0.4}, repulse: {distance: 200}}
 | 
						|
			}
 | 
						|
		},
 | 
						|
		addOnCountdown: {
 | 
						|
			enable: false,
 | 
						|
			targetdate: new Date().getTime() + 864000000, // https://www.freeformatter.com/epoch-timestamp-to-date-converter.html
 | 
						|
			slidechanges: [{days: 0, hours: 0, minutes: 0, seconds: 0, slide: 2}]
 | 
						|
		},
 | 
						|
		addOnSlicey: {
 | 
						|
			enable: false
 | 
						|
		},
 | 
						|
		addOnFilmstrip: {
 | 
						|
			enable: false
 | 
						|
		},
 | 
						|
		addOnBeforeAfter : {
 | 
						|
			enable: false,
 | 
						|
			options: {
 | 
						|
				cursor: "move",
 | 
						|
			    carousel: false,
 | 
						|
			    arrowStyles: {
 | 
						|
			        leftIcon: "fa-icon-caret-left",
 | 
						|
			        rightIcon: "fa-icon-caret-right",
 | 
						|
			        topIcon: "fa-icon-caret-up",
 | 
						|
			        bottomIcon: "fa-icon-caret-down",
 | 
						|
			        size: "35",
 | 
						|
			        color: "#ffffff",
 | 
						|
			        spacing: "10",
 | 
						|
			        bgColor: "transparent",
 | 
						|
			        padding: "0",
 | 
						|
			        borderRadius: "0"
 | 
						|
			    },
 | 
						|
			    dividerStyles: {
 | 
						|
			        width: "1",
 | 
						|
			        color: "rgba(255, 255, 255, 0.5)"
 | 
						|
			    }
 | 
						|
			}
 | 
						|
		},
 | 
						|
		addOnPanorama: {
 | 
						|
			enable: false
 | 
						|
		},
 | 
						|
		addOnRevealer: {
 | 
						|
			enable: false,
 | 
						|
		},
 | 
						|
		revealer: {
 | 
						|
			direction: "open_horizontal",
 | 
						|
			color: "#ffffff",
 | 
						|
			duration: "1500",
 | 
						|
			delay: "0",
 | 
						|
			easing: "Power2.easeInOut",
 | 
						|
			overlay_enabled: true,
 | 
						|
			overlay_color: "#000000",
 | 
						|
			overlay_duration: "1500",
 | 
						|
			overlay_delay: "0",
 | 
						|
			overlay_easing: "Power2.easeInOut",
 | 
						|
			spinner: "1",
 | 
						|
			spinnerColor: "#006dd2",
 | 
						|
			spinnerHtml: "<div class='rsaddon-revealer-spinner rsaddon-revealer-spinner-1'><div class='rsaddon-revealer-1'><span style='background: {{color}}'><\/span><span style='background: {{color}}'><\/span><span style='background: {{color}}'><\/span><span style='background: {{color}}'><\/span><span style='background: {{color}}'><\/span><span style='background: {{color}}'><\/span><span style='background: {{color}}'><\/span><span style='background: {{color}}'><\/span><span style='background: {{color}}'><\/span><span style='background: {{color}}'><\/span><\/div><\/div \/>"
 | 
						|
		},
 | 
						|
		addOnDuotone: {
 | 
						|
			enable: false
 | 
						|
		},
 | 
						|
		addOnBubblemorph: {
 | 
						|
			enable: false
 | 
						|
		},
 | 
						|
		addOnDistortion: {
 | 
						|
			enable: false
 | 
						|
		}
 | 
						|
		
 | 
						|
	};
 | 
						|
 | 
						|
	PluginRevolutionSlider.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build()
 | 
						|
				.events();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginRevolutionSlider.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			if (!($.isFunction($.fn.revolution))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			// Single Slider Class
 | 
						|
			if(this.options.wrapper.find('> ul > li').length == 1) {
 | 
						|
				this.options.wrapper.addClass('slider-single-slide');
 | 
						|
 | 
						|
				// Remove Bullets
 | 
						|
				// this.options.navigation.bullets.enable = false;
 | 
						|
				$.extend(this.options.navigation, {
 | 
						|
					bullets: {
 | 
						|
						enable: false
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
			// Full Screen Class
 | 
						|
			if(this.options.sliderLayout == 'fullscreen') {
 | 
						|
				this.options.wrapper.closest('.slider-container').addClass('fullscreen-slider');
 | 
						|
			}
 | 
						|
			
 | 
						|
			// Initialize Revolution Slider
 | 
						|
			this.options.wrapper.revolution(this.options);
 | 
						|
 | 
						|
			// Addon Init - Typewriter
 | 
						|
			if(this.options.addOnTypewriter.enable) {
 | 
						|
				RsTypewriterAddOn($, this.options.wrapper);
 | 
						|
			}
 | 
						|
 | 
						|
			// Addon Init - Whiteboard
 | 
						|
			if(this.options.addOnWhiteboard.enable) {
 | 
						|
				this.options.wrapper.rsWhiteBoard();
 | 
						|
			}
 | 
						|
 | 
						|
			// Addon Init - Particles
 | 
						|
			if(this.options.addOnParticles.enable) {
 | 
						|
				RsParticlesAddOn(this.options.wrapper);
 | 
						|
			}
 | 
						|
 | 
						|
			// Addon Init - Countdown
 | 
						|
			if(this.options.addOnCountdown.enable) {
 | 
						|
				tp_countdown(this.options.wrapper, this.options.addOnCountdown.targetdate, this.options.addOnCountdown.slidechanges);
 | 
						|
			}
 | 
						|
 | 
						|
			// Addon Init - Slicey
 | 
						|
			if(this.options.addOnSlicey.enable) {
 | 
						|
				this.options.wrapper.revSliderSlicey();
 | 
						|
			}
 | 
						|
 | 
						|
			// Addon Init - Filmstrip
 | 
						|
			if(this.options.addOnFilmstrip.enable) {
 | 
						|
				RsFilmstripAddOn($, this.options.wrapper, '../vendor/rs-plugin/revolution-addons/filmstrip/', false);
 | 
						|
			}
 | 
						|
 | 
						|
			// Addon Init - Before After
 | 
						|
			if(this.options.addOnBeforeAfter.enable) {
 | 
						|
				RevSliderBeforeAfter($, this.options.wrapper, this.options.addOnBeforeAfter.options);
 | 
						|
			}
 | 
						|
 | 
						|
			// Addon Init - Panorama
 | 
						|
			if(this.options.addOnPanorama.enable) {
 | 
						|
				RsAddonPanorama($, this.options.wrapper);
 | 
						|
			}
 | 
						|
 | 
						|
			// Addon Init - Revealer
 | 
						|
			if(this.options.addOnRevealer.enable) {
 | 
						|
				RsRevealerAddOn($, this.options.wrapper, this.options.revealer.spinnerHtml);
 | 
						|
			}
 | 
						|
 | 
						|
			// Addon Init - Duotone
 | 
						|
			if(this.options.addOnDuotone.enable) {
 | 
						|
				RsAddonDuotone($, this.options.wrapper, true, "cubic-bezier(0.645, 0.045, 0.355, 1.000)", "1000");
 | 
						|
			}
 | 
						|
 | 
						|
			// Addon Init - Bubblemorph
 | 
						|
			if(this.options.addOnBubblemorph.enable) {
 | 
						|
				BubbleMorphAddOn($, this.options.wrapper, false);
 | 
						|
			}
 | 
						|
 | 
						|
			// Addon Init - Distortion
 | 
						|
			if(this.options.addOnDistortion.enable) {
 | 
						|
				RsLiquideffectAddOn($, this.options.wrapper);
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		events: function() {
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginRevolutionSlider: PluginRevolutionSlider
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginRevolutionSlider = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginRevolutionSlider($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Scroll Spy
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__scrollSpy';
 | 
						|
 | 
						|
	var PluginScrollSpy = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginScrollSpy.defaults = {
 | 
						|
		target: '#header'
 | 
						|
	};
 | 
						|
 | 
						|
	PluginScrollSpy.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
 | 
						|
			if( document.querySelector( opts.target ) == null ) {
 | 
						|
				return false;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts);
 | 
						|
			
 | 
						|
			this.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginScrollSpy.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
            var self = this,
 | 
						|
                target = document.querySelector( self.options.target ) != null ? document.querySelector( self.options.target ) : false,
 | 
						|
                navItems = target == '#header' || target == '.wrapper-spy' ? target.querySelectorAll('.header-nav .nav > li a') : target.querySelectorAll('.nav > li a');
 | 
						|
 | 
						|
			// Get all section ID's
 | 
						|
			var sectionIDs = Object.keys(navItems).map(function(key, index) {
 | 
						|
				return navItems[key].hash;
 | 
						|
			});
 | 
						|
 | 
						|
			// Remove empty values from sectionIDs array
 | 
						|
			sectionIDs = sectionIDs.filter(function(value){
 | 
						|
				return value != ''; 
 | 
						|
			});
 | 
						|
 | 
						|
			// Store in a global variable
 | 
						|
			self.sectionIDs = sectionIDs;
 | 
						|
 | 
						|
			for( var i = 0; i < sectionIDs.length; i++ ) {
 | 
						|
 | 
						|
				// Default Root Margin
 | 
						|
				var rootMargin = '-20% 0px -79.9% 0px';
 | 
						|
				
 | 
						|
				// Spy Offset
 | 
						|
				if( $( sectionIDs[i] ).data('spy-offset') ) {
 | 
						|
					var rootMarginOffset = $( sectionIDs[i] ).data('spy-offset'),
 | 
						|
						isNegativeOffset = parseInt( rootMarginOffset ) < 0 ? true : false;
 | 
						|
 | 
						|
					// Mount a new rootMargin based on offset value
 | 
						|
					rootMargin = rootMargin.split(' ').map(function(element, index){
 | 
						|
						if( element.indexOf('%') > 0 ) {
 | 
						|
							var valueToInt = parseInt( element.replace('%','') ),
 | 
						|
								newValue = 0;
 | 
						|
 | 
						|
							switch ( index ) {
 | 
						|
								case 0:
 | 
						|
									if( isNegativeOffset ) {
 | 
						|
										newValue = valueToInt - rootMarginOffset;
 | 
						|
									} else {
 | 
						|
										newValue = Math.abs(valueToInt) + rootMarginOffset;
 | 
						|
									}
 | 
						|
									break;
 | 
						|
 | 
						|
								case 2:
 | 
						|
									if( isNegativeOffset ) {
 | 
						|
										newValue = valueToInt + rootMarginOffset;
 | 
						|
									} else {
 | 
						|
										newValue = Math.abs(valueToInt) - rootMarginOffset;
 | 
						|
									}
 | 
						|
									break;
 | 
						|
							
 | 
						|
							}
 | 
						|
 | 
						|
							if( isNegativeOffset ) {
 | 
						|
								newValue = newValue + '%';
 | 
						|
							} else {
 | 
						|
								newValue = '-' + newValue + '%';
 | 
						|
							}
 | 
						|
 | 
						|
							return newValue;
 | 
						|
						} else {
 | 
						|
							return element;
 | 
						|
						}
 | 
						|
					}).join(' ');
 | 
						|
				}
 | 
						|
 | 
						|
				var selector = sectionIDs[i],
 | 
						|
					callback = function() {
 | 
						|
						var $section = $(this);
 | 
						|
 | 
						|
						if( target == '#header' || target == '.wrapper-spy' ) {
 | 
						|
							$('#header .header-nav .nav > li a').removeClass('active');
 | 
						|
							$('#header .header-nav .nav > li a[href="#'+ $section[0].id +'"]').addClass('active');
 | 
						|
						} else {
 | 
						|
							$( target ).find('.nav > li a').removeClass('active');
 | 
						|
							$( target ).find('.nav > li a[href="#'+ $section[0].id +'"]').addClass('active');
 | 
						|
						}
 | 
						|
						
 | 
						|
					}
 | 
						|
 | 
						|
				this.scrollSpyIntObs( selector, callback, { 
 | 
						|
					rootMargin: rootMargin,
 | 
						|
					threshold: 0
 | 
						|
				}, true, i, true);
 | 
						|
 | 
						|
            }
 | 
						|
 | 
						|
            return this;
 | 
						|
 | 
						|
		},
 | 
						|
 | 
						|
		scrollSpyIntObs: function(selector, functionName, intObsOptions, alwaysObserve, index, firstLoad) {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			var $el = document.querySelectorAll( selector );
 | 
						|
			var intersectionObserverOptions = {
 | 
						|
				rootMargin: '0px 0px 200px 0px'
 | 
						|
			}
 | 
						|
 | 
						|
			if( Object.keys(intObsOptions).length ) {
 | 
						|
				intersectionObserverOptions = $.extend(intersectionObserverOptions, intObsOptions);
 | 
						|
			}
 | 
						|
 | 
						|
			var observer = new IntersectionObserver(function(entries) {
 | 
						|
 | 
						|
				for(var i=0; i < entries.length; i++) {
 | 
						|
					var entry = entries[i];
 | 
						|
 | 
						|
					if (entry.intersectionRatio > 0 ) {
 | 
						|
						if( typeof functionName === 'string' ) {
 | 
						|
							var func = Function( 'return ' + functionName )();
 | 
						|
						} else {
 | 
						|
							var callback = functionName;
 | 
						|
 | 
						|
							callback.call( $(entry.target) );
 | 
						|
						}
 | 
						|
 | 
						|
						// Unobserve
 | 
						|
						if( !alwaysObserve ) {
 | 
						|
							observer.unobserve(entry.target);   
 | 
						|
						}
 | 
						|
 | 
						|
					} else {
 | 
						|
						if( firstLoad == false ) {
 | 
						|
							if( index == self.sectionIDs.length - 1 ) {
 | 
						|
								$('#header .header-nav .nav > li a').removeClass('active');
 | 
						|
								$('#header .header-nav .nav > li a[href="#'+ entry.target.id +'"]').parent().prev().find('a').addClass('active');
 | 
						|
							}
 | 
						|
						}
 | 
						|
						firstLoad = false;
 | 
						|
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}, intersectionObserverOptions);
 | 
						|
			
 | 
						|
			$( $el ).each(function(){
 | 
						|
				observer.observe( $(this)[0] );
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginScrollSpy: PluginScrollSpy
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginScrollSpy = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginScrollSpy($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Scroll to Top
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	$.extend(theme, {
 | 
						|
 | 
						|
		PluginScrollToTop: {
 | 
						|
 | 
						|
			defaults: {
 | 
						|
				wrapper: $('body'),
 | 
						|
				offset: 150,
 | 
						|
				buttonClass: 'scroll-to-top',
 | 
						|
				buttonAriaLabel: 'Scroll To Top',
 | 
						|
				iconClass: 'fas fa-chevron-up',
 | 
						|
				delay: 1000,
 | 
						|
				visibleMobile: false,
 | 
						|
				label: false,
 | 
						|
				easing: 'easeOutBack'
 | 
						|
			},
 | 
						|
 | 
						|
			initialize: function(opts) {
 | 
						|
				initialized = true;
 | 
						|
 | 
						|
				// Don't initialize if the page has Section Scroll
 | 
						|
				if( $('body[data-plugin-section-scroll]').get(0) ) {
 | 
						|
					return;
 | 
						|
				}
 | 
						|
 | 
						|
				this
 | 
						|
					.setOptions(opts)
 | 
						|
					.build()
 | 
						|
					.events();
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			setOptions: function(opts) {
 | 
						|
				this.options = $.extend(true, {}, this.defaults, opts);
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			build: function() {
 | 
						|
				var self = this,
 | 
						|
					$el;
 | 
						|
 | 
						|
				// Base HTML Markup
 | 
						|
				$el = $('<a />')
 | 
						|
					.addClass(self.options.buttonClass)
 | 
						|
					.attr({
 | 
						|
						'href': '#',
 | 
						|
						'aria-label': self.options.buttonAriaLabel
 | 
						|
					})
 | 
						|
					.append(
 | 
						|
						$('<i />')
 | 
						|
						.addClass(self.options.iconClass)
 | 
						|
				);
 | 
						|
 | 
						|
				// Visible Mobile
 | 
						|
				if (!self.options.visibleMobile) {
 | 
						|
					$el.addClass('hidden-mobile');
 | 
						|
				}
 | 
						|
 | 
						|
				// Label
 | 
						|
				if (self.options.label) {
 | 
						|
					$el.append(
 | 
						|
						$('<span />').html(self.options.label)
 | 
						|
					);
 | 
						|
				}
 | 
						|
 | 
						|
				this.options.wrapper.append($el);
 | 
						|
 | 
						|
				this.$el = $el;
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			events: function() {
 | 
						|
				var self = this,
 | 
						|
					_isScrolling = false;
 | 
						|
 | 
						|
				// Click Element Action
 | 
						|
				self.$el.on('click', function(e) {
 | 
						|
					e.preventDefault();
 | 
						|
					$('html').animate({
 | 
						|
						scrollTop: 0
 | 
						|
					}, self.options.delay, self.options.easing);
 | 
						|
					return false;
 | 
						|
				});
 | 
						|
 | 
						|
				// Show/Hide Button on Window Scroll event.
 | 
						|
				$(window).scroll(function() {
 | 
						|
 | 
						|
					if (!_isScrolling) {
 | 
						|
 | 
						|
						_isScrolling = true;
 | 
						|
 | 
						|
						if ($(window).scrollTop() > self.options.offset) {
 | 
						|
 | 
						|
							self.$el.stop(true, true).addClass('visible');
 | 
						|
							_isScrolling = false;
 | 
						|
 | 
						|
						} else {
 | 
						|
 | 
						|
							self.$el.stop(true, true).removeClass('visible');
 | 
						|
							_isScrolling = false;
 | 
						|
 | 
						|
						}
 | 
						|
 | 
						|
					}
 | 
						|
 | 
						|
				});
 | 
						|
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
	});
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Scrollable
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__scrollable';
 | 
						|
 | 
						|
	var PluginScrollable = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginScrollable.updateModals = function() {
 | 
						|
		PluginScrollable.updateBootstrapModal();
 | 
						|
	};
 | 
						|
 | 
						|
	PluginScrollable.updateBootstrapModal = function() {
 | 
						|
		var updateBoostrapModal;
 | 
						|
 | 
						|
		updateBoostrapModal = typeof $.fn.modal !== 'undefined';
 | 
						|
		updateBoostrapModal = updateBoostrapModal && typeof $.fn.modal.Constructor !== 'undefined';
 | 
						|
		updateBoostrapModal = updateBoostrapModal && typeof $.fn.modal.Constructor.prototype !== 'undefined';
 | 
						|
		updateBoostrapModal = updateBoostrapModal && typeof $.fn.modal.Constructor.prototype.enforceFocus !== 'undefined';
 | 
						|
 | 
						|
		if ( !updateBoostrapModal ) {
 | 
						|
			return false;
 | 
						|
		}
 | 
						|
 | 
						|
		var originalFocus = $.fn.modal.Constructor.prototype.enforceFocus;
 | 
						|
		$.fn.modal.Constructor.prototype.enforceFocus = function() {
 | 
						|
			originalFocus.apply( this );
 | 
						|
 | 
						|
			var $scrollable = this.$element.find('.scrollable');
 | 
						|
			if ( $scrollable ) {
 | 
						|
				if ( $.isFunction($.fn['themePluginScrollable'])  ) {
 | 
						|
					$scrollable.themePluginScrollable();
 | 
						|
				}
 | 
						|
 | 
						|
				if ( $.isFunction($.fn['nanoScroller']) ) {
 | 
						|
					$scrollable.nanoScroller();
 | 
						|
				}
 | 
						|
			}
 | 
						|
		};
 | 
						|
	};
 | 
						|
 | 
						|
	PluginScrollable.defaults = {
 | 
						|
		contentClass: 'scrollable-content',
 | 
						|
		paneClass: 'scrollable-pane',
 | 
						|
		sliderClass: 'scrollable-slider',
 | 
						|
		alwaysVisible: true,
 | 
						|
		preventPageScrolling: true
 | 
						|
	};
 | 
						|
 | 
						|
	PluginScrollable.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ( $el.data( instanceName ) ) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginScrollable.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			this.options.wrapper.nanoScroller(this.options);
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginScrollable: PluginScrollable
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginScrollable = function(opts) {
 | 
						|
		return this.each(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginScrollable($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	};
 | 
						|
 | 
						|
	$(function() {
 | 
						|
		PluginScrollable.updateModals();
 | 
						|
	});
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Section Scroll
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__sectionScroll';
 | 
						|
 | 
						|
	var PluginSectionScroll = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginSectionScroll.defaults = {
 | 
						|
		targetClass: '.section',
 | 
						|
		dotsNav: true,
 | 
						|
		changeHeaderLogo: true,
 | 
						|
		headerLogoDark: 'img/logo-default-slim.png',
 | 
						|
		headerLogoLight: 'img/logo-default-slim-dark.png'
 | 
						|
	};
 | 
						|
 | 
						|
	PluginSectionScroll.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build()
 | 
						|
				.events();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginSectionScroll.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this,
 | 
						|
				$el = this.options.wrapper;
 | 
						|
 | 
						|
			// Check type of header and change the target for header (by change header color purpose)
 | 
						|
			if( $('html').hasClass('side-header-overlay-full-screen') ) {
 | 
						|
				self.$header = $('.sticky-wrapper');
 | 
						|
			} else {
 | 
						|
				self.$header = $('#header');
 | 
						|
			}
 | 
						|
 | 
						|
			// Turn the section full height or not depeding on the content size
 | 
						|
			self.updateSectionsHeight();
 | 
						|
 | 
						|
			// Wrap all sections in a section wrapper
 | 
						|
			$( this.options.targetClass ).wrap('<div class="section-wrapper"></div>');
 | 
						|
 | 
						|
			// Set the section wrapper height
 | 
						|
	  		$('.section-wrapper').each(function(){
 | 
						|
	  			$(this).height( $(this).find('.section-scroll').outerHeight() );
 | 
						|
	  		});
 | 
						|
 | 
						|
	  		// Add active class to the first section on page load
 | 
						|
	  		$('.section-wrapper').first().addClass('active');
 | 
						|
			
 | 
						|
	        var	flag = false,
 | 
						|
	            scrollableFlag = false,
 | 
						|
	        	touchDirection = '',
 | 
						|
	        	touchstartY = 0,
 | 
						|
	        	touchendY = 0;
 | 
						|
 | 
						|
	        $(window).on('touchstart', function(event) {
 | 
						|
			    touchstartY = event.changedTouches[0].screenY;
 | 
						|
			});
 | 
						|
 | 
						|
	        var wheelEvent = 'onwheel' in document ? 'wheel' : document.onmousewheel !== undefined ? 'mousewheel' : 'DOMMouseScroll';
 | 
						|
	        if( $(window).width() < 992 && $('html').hasClass('touch') ) {
 | 
						|
	        	wheelEvent = 'onwheel' in document ? 'wheel touchend' : document.onmousewheel !== undefined ? 'mousewheel touchend' : 'DOMMouseScroll touchend';
 | 
						|
	        }
 | 
						|
 | 
						|
        	if( $(window).width() < 992 ) {
 | 
						|
	    		$('html').removeClass('overflow-hidden');
 | 
						|
			    $(window).on('scroll', function(){
 | 
						|
 | 
						|
		    		var index = 0;
 | 
						|
		    		$('.section-scroll').each(function(){
 | 
						|
		    			if( $(this).offset().top <= $(window).scrollTop() + 50 ) {
 | 
						|
		    				var $currentSection2 = $('.section-wrapper').eq( index ).find('.section-scroll');
 | 
						|
 | 
						|
			            	$('.section-scroll-dots-navigation > ul > li').removeClass('active');
 | 
						|
							$('.section-scroll-dots-navigation > ul > li').eq( index ).addClass('active');
 | 
						|
 | 
						|
							$(window).trigger({
 | 
						|
								type: 'section.scroll.mobile.change.header.color',
 | 
						|
								currentSection: $currentSection2
 | 
						|
							});
 | 
						|
		    			}
 | 
						|
 | 
						|
		    			index++;
 | 
						|
		    		});
 | 
						|
		    		
 | 
						|
			    });
 | 
						|
 | 
						|
			    $(window).on('section.scroll.mobile.change.header.color', function(e){
 | 
						|
			    	if( typeof e.currentSection == 'undefined' ) {
 | 
						|
			    		return;
 | 
						|
			    	}
 | 
						|
 | 
						|
			    	var $currentSection = e.currentSection,
 | 
						|
			    		headerColor     = $currentSection.data('section-scroll-header-color');
 | 
						|
								    	
 | 
						|
			    	$('#header .header-nav').removeClass('header-nav-light-text header-nav-dark-text').addClass('header-nav-' + headerColor + '-text');
 | 
						|
			    	$('#header .header-nav-features').removeClass('header-nav-features-dark header-nav-features-light').addClass('header-nav-features-' + headerColor);
 | 
						|
			    	$('#header .header-social-icons').removeClass('social-icons-icon-dark social-icons-icon-light').addClass('social-icons-icon-' + headerColor);
 | 
						|
 | 
						|
			    	// Change Logo
 | 
						|
			    	if( self.options.changeHeaderLogo && headerColor != undefined ) {
 | 
						|
				    	if( headerColor == 'light' ) {
 | 
						|
				    		$('#header .header-logo img').attr('src', self.options.headerLogoLight);
 | 
						|
				    	} else if( headerColor == 'dark' ) {
 | 
						|
				    		$('#header .header-logo img').attr('src', self.options.headerLogoDark);
 | 
						|
				    	}
 | 
						|
			    	}
 | 
						|
 | 
						|
			    	self.$header.css({
 | 
						|
			    		opacity: 1
 | 
						|
			    	});
 | 
						|
 | 
						|
			    });
 | 
						|
        	}
 | 
						|
 | 
						|
	        $(window).on(wheelEvent, function(e){
 | 
						|
	        	if( $(window).width() < 992 ) {
 | 
						|
	        		return;
 | 
						|
	        	}
 | 
						|
 | 
						|
	        	if( $(window).width() < 992 && $('html').hasClass('touch') ) {
 | 
						|
		        	if( $(e.target).closest('.section-scroll-dots-navigation').get(0) || $(e.target).closest('.header-body').get(0) || $(e.target).closest('.owl-carousel').get(0) ) {
 | 
						|
		        		return;
 | 
						|
		        	}
 | 
						|
		        }
 | 
						|
 | 
						|
		        // Side Header Overlay Full Screen
 | 
						|
		        if( $('html.side-header-overlay-full-screen.side-header-hide').get(0) ) {
 | 
						|
		        	return;
 | 
						|
		        }
 | 
						|
 | 
						|
	        	var wheelDirection = e.originalEvent.wheelDelta == undefined ? e.originalEvent.deltaY > 0 : e.originalEvent.wheelDelta < 0;
 | 
						|
	        	if( $(window).width() < 992 && $('html').hasClass('touch') ) {
 | 
						|
		        	touchendY = event.changedTouches[0].screenY;
 | 
						|
	        		
 | 
						|
				    if( touchendY <= touchstartY ) {
 | 
						|
				    	touchDirection = 'up';
 | 
						|
				    }
 | 
						|
 | 
						|
				    if( touchendY >= touchstartY ) {
 | 
						|
				    	touchDirection = 'down';
 | 
						|
				    }
 | 
						|
 | 
						|
				    if( touchendY == touchstartY ) {
 | 
						|
				    	return;
 | 
						|
				    }
 | 
						|
	        	}
 | 
						|
 | 
						|
	        	var $currentSection = $('.section-wrapper').eq( self.getCurrentIndex() ).find('.section-scroll'),
 | 
						|
            		$nextSection = self.getNextSection(wheelDirection, touchDirection),
 | 
						|
            		nextSectionOffsetTop;
 | 
						|
 | 
						|
            	// If is the last section, then change the offsetTop value
 | 
						|
            	if( self.getCurrentIndex() == $('.section-wrapper').length - 1 ) {
 | 
						|
            		nextSectionOffsetTop = $(document).height();
 | 
						|
            	} else {
 | 
						|
            		nextSectionOffsetTop = $nextSection.offset().top;
 | 
						|
            	}
 | 
						|
 | 
						|
			    if( $(window).width() < 992 && $('html').hasClass('touch') ) {
 | 
						|
				    setTimeout(function(){
 | 
						|
					    if( $('.section-wrapper').eq( self.getCurrentIndex() ).find('.section-scroll').hasClass('section-scroll-scrollable') ) {
 | 
						|
					    	$('html').removeClass('overflow-hidden');
 | 
						|
					    } else {
 | 
						|
					    	$('html').addClass('overflow-hidden');
 | 
						|
					    }
 | 
						|
				    }, 1200);
 | 
						|
				}
 | 
						|
 | 
						|
	        	// For non full height sections
 | 
						|
	        	if( $currentSection.hasClass('section-scroll-scrollable') ) {
 | 
						|
	        		if( !flag && !scrollableFlag ) {
 | 
						|
 | 
						|
		        		// Scroll Direction
 | 
						|
		        		if(wheelDirection || touchDirection == 'up') {
 | 
						|
		        			if( ( $(window).scrollTop() + $(window).height() ) >= nextSectionOffsetTop ) {
 | 
						|
		        				flag = true;
 | 
						|
								setTimeout(function(){
 | 
						|
									$(window).trigger('section.scroll.change.header.color');
 | 
						|
 | 
						|
					            	setTimeout(function(){
 | 
						|
										flag = false;
 | 
						|
									}, 500);
 | 
						|
								}, 1000);
 | 
						|
 | 
						|
		        				if( self.getCurrentIndex() == ( $('.section-wrapper').length - 1 )  ) {
 | 
						|
						    		return false;
 | 
						|
						    	}
 | 
						|
 | 
						|
		        				// Move to the next section
 | 
						|
		        				self.moveTo( $currentSection.offset().top + $currentSection.outerHeight() );
 | 
						|
 | 
						|
		        				// Change Section Active Class
 | 
						|
					   			self.changeSectionActiveState( $nextSection );
 | 
						|
 | 
						|
					   			self.$header.css({
 | 
						|
							    	opacity: 0,
 | 
						|
							    	transition: 'ease opacity 500ms'
 | 
						|
							    });
 | 
						|
					        }
 | 
						|
 | 
						|
			        		if( !$('html').hasClass('touch') ) {
 | 
						|
				        		for( var i = 1; i < 100; i++ ) {
 | 
						|
					        		$('body, html').scrollTop( $(window).scrollTop() + 1 );
 | 
						|
 | 
						|
					        		if( ( $(window).scrollTop() + $(window).height() ) >= nextSectionOffsetTop ) {
 | 
						|
					        			scrollableFlag = true;
 | 
						|
										setTimeout(function(){
 | 
						|
											$(window).trigger('section.scroll.change.header.color');
 | 
						|
							            	scrollableFlag = false;
 | 
						|
										}, 500);
 | 
						|
					        			break;
 | 
						|
					        		}
 | 
						|
				        		}
 | 
						|
				        	}
 | 
						|
					    } else {
 | 
						|
					    	if( $(window).scrollTop() <= $currentSection.offset().top ) {
 | 
						|
					    		flag = true;
 | 
						|
								setTimeout(function(){
 | 
						|
									$(window).trigger('section.scroll.change.header.color');
 | 
						|
 | 
						|
					            	setTimeout(function(){
 | 
						|
										flag = false;
 | 
						|
									}, 500);
 | 
						|
								}, 1000);
 | 
						|
 | 
						|
					    		if( self.getCurrentIndex() == 0  ) {
 | 
						|
						    		return false;
 | 
						|
						    	}
 | 
						|
 | 
						|
					   			// Move to the next section
 | 
						|
		        				self.moveTo( $currentSection.offset().top - $(window).height() );
 | 
						|
 | 
						|
		        				// Change Section Active Class
 | 
						|
					   			self.changeSectionActiveState( $nextSection );
 | 
						|
 | 
						|
					   			self.$header.css({
 | 
						|
							    	opacity: 0,
 | 
						|
							    	transition: 'ease opacity 500ms'
 | 
						|
							    });
 | 
						|
					        }
 | 
						|
 | 
						|
					    	if( !$('html').hasClass('touch') ) {
 | 
						|
				        		for( var i = 1; i < 100; i++ ) {
 | 
						|
					        		$('body, html').scrollTop( $(window).scrollTop() - 1 );
 | 
						|
 | 
						|
					        		if( $(window).scrollTop() <= $currentSection.offset().top ) {
 | 
						|
					        			scrollableFlag = true;
 | 
						|
										setTimeout(function(){
 | 
						|
											$(window).trigger('section.scroll.change.header.color');
 | 
						|
							            	scrollableFlag = false;
 | 
						|
										}, 500);
 | 
						|
					        			break;
 | 
						|
					        		}
 | 
						|
				        		}
 | 
						|
				        	}
 | 
						|
					    }
 | 
						|
 | 
						|
			   			// Change Dots Active Class
 | 
						|
				        self.changeDotsActiveState();
 | 
						|
 | 
						|
		        		return;
 | 
						|
 | 
						|
		        	}
 | 
						|
	        	}
 | 
						|
 | 
						|
	        	// For full height sections
 | 
						|
	        	if( !flag && !scrollableFlag ) {
 | 
						|
				    if(wheelDirection || touchDirection == 'up') {
 | 
						|
				    	if( self.getCurrentIndex() == ( $('.section-wrapper').length - 1 )  ) {
 | 
						|
				    		return false;
 | 
						|
				    	}
 | 
						|
 | 
						|
				   		// Change Section Active Class
 | 
						|
			   			self.changeSectionActiveState( $nextSection );
 | 
						|
 | 
						|
				   		setTimeout(function(){
 | 
						|
				   			// Move to the next section
 | 
						|
	        				self.moveTo( $nextSection.offset().top );
 | 
						|
 | 
						|
				   		}, 150);
 | 
						|
				    } else {
 | 
						|
				    	if( self.getCurrentIndex() == 0  ) {
 | 
						|
				    		return false;
 | 
						|
				    	}
 | 
						|
 | 
						|
				   		// Change Section Active Class
 | 
						|
			   			self.changeSectionActiveState( $nextSection );
 | 
						|
 | 
						|
				   		if( $nextSection.height() > $(window).height() ) {
 | 
						|
				   			// Move to the next section
 | 
						|
	        				self.moveTo( $currentSection.offset().top - $(window).height() );
 | 
						|
				   		} else {
 | 
						|
					        setTimeout(function(){
 | 
						|
					   			// Move to the next section
 | 
						|
		        				self.moveTo( $nextSection.offset().top );
 | 
						|
 | 
						|
					   		}, 150);
 | 
						|
				   		}
 | 
						|
				    }
 | 
						|
 | 
						|
				    // Change Dots Active Class
 | 
						|
			        self.changeDotsActiveState();
 | 
						|
 | 
						|
				    self.$header.css({
 | 
						|
				    	opacity: 0,
 | 
						|
				    	transition: 'ease opacity 500ms'
 | 
						|
				    });
 | 
						|
 | 
						|
				    // Style next section
 | 
						|
	            	$nextSection.css({
 | 
						|
	            		position: 'relative',
 | 
						|
	            		opacity: 1,
 | 
						|
	            		'z-index': 1,
 | 
						|
	            		transform: 'translate3d(0,0,0) scale(1)'
 | 
						|
	            	});
 | 
						|
 | 
						|
	            	// Style previous section
 | 
						|
	            	$currentSection.css({
 | 
						|
	            		position: 'fixed',
 | 
						|
	            		width: '100%',
 | 
						|
	            		top: 0,
 | 
						|
	            		left: 0,
 | 
						|
	            		opacity: 0,
 | 
						|
	            		'z-index': 0,
 | 
						|
	            		transform: 'translate3d(0,0,-10px) scale(0.7)',
 | 
						|
	            		transition: 'ease transform 600ms, ease opacity 600ms',
 | 
						|
	            	});
 | 
						|
 | 
						|
					setTimeout(function(){
 | 
						|
						$currentSection.css({
 | 
						|
		            		position: 'relative',
 | 
						|
		            		opacity: 1,
 | 
						|
		            		transform: 'translate3d(0,0,-10px) scale(1)'
 | 
						|
		            	});
 | 
						|
 | 
						|
						$(window).trigger('section.scroll.change.header.color');
 | 
						|
 | 
						|
		            	setTimeout(function(){
 | 
						|
							flag = false;
 | 
						|
						}, 500);
 | 
						|
					}, 1000);
 | 
						|
 | 
						|
					flag = true;
 | 
						|
 | 
						|
				}
 | 
						|
 | 
						|
				return;
 | 
						|
	        });
 | 
						|
 | 
						|
	        // Dots Navigation
 | 
						|
	        if( this.options.dotsNav ) {
 | 
						|
	        	self.dotsNavigation();
 | 
						|
	        }
 | 
						|
 | 
						|
	        // First Load
 | 
						|
	        setTimeout(function(){
 | 
						|
		        if( $(window.location.hash).get(0) ) {
 | 
						|
		        	self.moveTo( $(window.location.hash).parent().offset().top );
 | 
						|
 | 
						|
		        	self.changeSectionActiveState( $(window.location.hash) );
 | 
						|
 | 
						|
		        	// Change Dots Active Class
 | 
						|
			        self.changeDotsActiveState();
 | 
						|
 | 
						|
		        	self.updateHash( true );
 | 
						|
		        } else {
 | 
						|
		        	var hash  = window.location.hash,
 | 
						|
		        		index = hash.replace('#','');
 | 
						|
 | 
						|
		        	if( !hash ) {
 | 
						|
		        		index = 1;
 | 
						|
		        	}
 | 
						|
 | 
						|
		        	self.moveTo( $('.section-wrapper').eq( index - 1 ).offset().top );
 | 
						|
 | 
						|
		        	self.changeSectionActiveState( $('.section-wrapper').eq( index - 1 ).find('.section-scroll') );
 | 
						|
 | 
						|
		        	// Change Dots Active Class
 | 
						|
			        self.changeDotsActiveState();
 | 
						|
 | 
						|
		        	self.updateHash( true );
 | 
						|
		        }
 | 
						|
 | 
						|
				$(window).trigger('section.scroll.ready');
 | 
						|
				$(window).trigger('section.scroll.change.header.color');
 | 
						|
			}, 500);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		updateSectionsHeight: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			$('.section-scroll').css({ height: '' });
 | 
						|
 | 
						|
			$('.section-scroll').each(function(){
 | 
						|
				if( $(this).outerHeight() < ( $(window).height() + 3 ) ) {
 | 
						|
					$(this).css({ height: '100vh' });		
 | 
						|
				} else {
 | 
						|
					$(this).addClass('section-scroll-scrollable');
 | 
						|
				}
 | 
						|
			});
 | 
						|
 | 
						|
			// Set the section wrapper height
 | 
						|
	  		$('.section-wrapper').each(function(){
 | 
						|
	  			$(this).height( $(this).find('.section-scroll').outerHeight() );
 | 
						|
	  		});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		updateHash: function( first_load ){
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if( !window.location.hash ) {
 | 
						|
				window.location.hash = 1;
 | 
						|
			} else {
 | 
						|
				if(!first_load) {
 | 
						|
					var $section = $('.section-wrapper').eq( self.getCurrentIndex() ).find('.section-scroll'),
 | 
						|
						section_id = $section.attr('id') ? $section.attr('id') : $section.parent().index() + 1;
 | 
						|
 | 
						|
					window.location.hash = section_id;
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		getCurrentIndex: function() {
 | 
						|
			var self = this,
 | 
						|
				currentIndex = 0;
 | 
						|
 | 
						|
			currentIndex = $('.section-wrapper.active').index();
 | 
						|
 | 
						|
			return currentIndex;
 | 
						|
		},
 | 
						|
 | 
						|
		moveTo: function( $scrollTopValue, first_load ) {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			$('body, html').animate({
 | 
						|
   				scrollTop: $scrollTopValue
 | 
						|
   			}, 1000, 'easeOutQuint');
 | 
						|
 | 
						|
   			setTimeout(function(){
 | 
						|
	   			self.updateHash();
 | 
						|
   			}, 500);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		getNextSection: function(wheelDirection, touchDirection) {
 | 
						|
			var self = this,
 | 
						|
				$nextSection = '';
 | 
						|
 | 
						|
			// Scroll Direction
 | 
						|
        	if(wheelDirection || touchDirection == 'up') {
 | 
						|
				$nextSection = $('.section-wrapper').eq( self.getCurrentIndex() + 1 ).find('.section-scroll');
 | 
						|
        	} else {
 | 
						|
        		$nextSection = $('.section-wrapper').eq( self.getCurrentIndex() - 1 ).find('.section-scroll');
 | 
						|
        	}
 | 
						|
 | 
						|
			return $nextSection;
 | 
						|
		},
 | 
						|
 | 
						|
		changeSectionActiveState: function( $nextSection ) {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			$('.section-wrapper').removeClass('active');
 | 
						|
	   		$nextSection.parent().addClass('active');
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		changeDotsActiveState: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			$('.section-scroll-dots-navigation > ul > li').removeClass('active');
 | 
						|
			$('.section-scroll-dots-navigation > ul > li').eq( self.getCurrentIndex() ).addClass('active');
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		dotsNavigation: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			var dotsNav = $('<div class="section-scroll-dots-navigation"><ul class="list list-unstyled"></ul></div>'),
 | 
						|
        		currentSectionIndex = self.getCurrentIndex();
 | 
						|
 | 
						|
        	if( self.options.dotsClass ) {
 | 
						|
        		dotsNav.addClass( self.options.dotsClass );
 | 
						|
        	}
 | 
						|
 | 
						|
        	for( var i = 0; i < $('.section-scroll').length; i++ ) {
 | 
						|
        		var title = $('.section-wrapper').eq( i ).find('.section-scroll').data('section-scroll-title');
 | 
						|
 | 
						|
        		dotsNav.find('> ul').append( '<li'+ ( ( currentSectionIndex == i ) ? ' class="active"' : '' ) +'><a href="#'+ i +'" data-nav-id="'+ i +'"><span>'+ title +'</span></a></li>' );
 | 
						|
        	}
 | 
						|
 | 
						|
        	$('.body').append( dotsNav );
 | 
						|
 | 
						|
        	dotsNav.find('a[data-nav-id]').on('click touchstart', function(e){
 | 
						|
        		e.preventDefault();
 | 
						|
        		var $this = $(this);
 | 
						|
 | 
						|
        		$('.section-scroll').css({
 | 
						|
        			opacity: 0,
 | 
						|
        			transition: 'ease opacity 300ms'
 | 
						|
        		});
 | 
						|
 | 
						|
        		self.$header.css({
 | 
						|
			    	opacity: 0,
 | 
						|
			    	transition: 'ease opacity 500ms'
 | 
						|
			    });
 | 
						|
 | 
						|
        		setTimeout(function(){
 | 
						|
	        		self.moveTo( $('.section-wrapper').eq( $this.data('nav-id') ).offset().top )
 | 
						|
 | 
						|
		   			$('.section-wrapper').removeClass('active');
 | 
						|
			   		$('.section-wrapper').eq( $this.data('nav-id') ).addClass('active');
 | 
						|
 | 
						|
	        		$('.section-wrapper').eq( self.getCurrentIndex() ).find('.section-scroll').css({
 | 
						|
	        			opacity: 1
 | 
						|
	        		});
 | 
						|
 | 
						|
	        		setTimeout(function(){
 | 
						|
		        		$('.section-scroll').css({ opacity: 1 });
 | 
						|
 | 
						|
		        		$(window).trigger('section.scroll.change.header.color');
 | 
						|
	        		}, 500);
 | 
						|
 | 
						|
	        		if( $(window).width() > 991 ) {
 | 
						|
		        		self.changeDotsActiveState();
 | 
						|
	        		}
 | 
						|
        		}, 500);
 | 
						|
        	});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		events: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			$(window).on('section.scroll.ready', function(){
 | 
						|
				$(window).scrollTop(0);
 | 
						|
			});
 | 
						|
 | 
						|
			$(window).on('section.scroll.change.header.color', function(){
 | 
						|
		    	var headerColor = $('.section-wrapper').eq( self.getCurrentIndex() ).find('.section-scroll').data('section-scroll-header-color');
 | 
						|
		    	
 | 
						|
		    	$('#header .header-nav').removeClass('header-nav-light-text header-nav-dark-text').addClass('header-nav-' + headerColor + '-text');
 | 
						|
		    	$('#header .header-nav-features').removeClass('header-nav-features-dark header-nav-features-light').addClass('header-nav-features-' + headerColor);
 | 
						|
		    	$('#header .header-social-icons').removeClass('social-icons-icon-dark social-icons-icon-light').addClass('social-icons-icon-' + headerColor);
 | 
						|
 | 
						|
		    	// Change Logo
 | 
						|
		    	if( self.options.changeHeaderLogo && headerColor != undefined ) {
 | 
						|
			    	if( headerColor == 'light' ) {
 | 
						|
			    		$('#header .header-logo img').attr('src', self.options.headerLogoLight);
 | 
						|
			    	} else if( headerColor == 'dark' ) {
 | 
						|
			    		$('#header .header-logo img').attr('src', self.options.headerLogoDark);
 | 
						|
			    	}
 | 
						|
		    	}
 | 
						|
 | 
						|
		    	self.$header.css({
 | 
						|
		    		opacity: 1
 | 
						|
		    	});
 | 
						|
		    });
 | 
						|
 | 
						|
			$(document).ready(function(){
 | 
						|
			    $(window).afterResize(function(){
 | 
						|
			    	self.updateSectionsHeight();
 | 
						|
 | 
						|
			    	if( $(window).width() < 992 ) {
 | 
						|
			    		$('html').removeClass('overflow-hidden');
 | 
						|
			    	}
 | 
						|
			    });
 | 
						|
			});
 | 
						|
 | 
						|
		    return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginSectionScroll: PluginSectionScroll
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginSectionScroll = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginSectionScroll($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	};
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Sort
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__sort';
 | 
						|
 | 
						|
	var PluginSort = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginSort.defaults = {
 | 
						|
		useHash: true,
 | 
						|
		itemSelector: '.isotope-item',
 | 
						|
		layoutMode: 'masonry',
 | 
						|
		filter: '*',
 | 
						|
		filterFieldId: false,
 | 
						|
		filterFieldText: '',
 | 
						|
		hiddenStyle: {
 | 
						|
			opacity: 0
 | 
						|
		},
 | 
						|
		visibleStyle: {
 | 
						|
			opacity: 1
 | 
						|
		},
 | 
						|
		stagger: 30,
 | 
						|
		isOriginLeft: ($('html').attr('dir') == 'rtl' ? false : true)
 | 
						|
	};
 | 
						|
 | 
						|
	PluginSort.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginSort.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			if (!($.isFunction($.fn.isotope))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this,
 | 
						|
				$source = this.options.wrapper,
 | 
						|
				$destination = $('.sort-destination[data-sort-id="' + $source.attr('data-sort-id') + '"]'),
 | 
						|
				$window = $(window);
 | 
						|
 | 
						|
			if ($destination.get(0)) {
 | 
						|
 | 
						|
				self.$source = $source;
 | 
						|
				self.$destination = $destination;
 | 
						|
				self.$loader = false;
 | 
						|
 | 
						|
				self.setParagraphHeight($destination);
 | 
						|
 | 
						|
				if (self.$destination.parents('.sort-destination-loader').get(0)) {
 | 
						|
					self.$loader = self.$destination.parents('.sort-destination-loader');
 | 
						|
					self.createLoader();
 | 
						|
				}
 | 
						|
 | 
						|
				$destination.attr('data-filter', '*');
 | 
						|
 | 
						|
				$destination.one('layoutComplete', function(event, laidOutItems) {
 | 
						|
					self.removeLoader();
 | 
						|
 | 
						|
					// If has data-plugin-sticky on the page we need recalculate sticky position
 | 
						|
					if( $('[data-plugin-sticky]').length ) {
 | 
						|
						setTimeout(function(){
 | 
						|
							$('[data-plugin-sticky]').each(function(){
 | 
						|
								$(this).data('__sticky').build();
 | 
						|
								$(window).trigger('resize');
 | 
						|
							});
 | 
						|
						}, 500);
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				if ( $('#' + self.options.filterFieldId).length ) {
 | 
						|
 | 
						|
					var $filterField = $('#' + self.options.filterFieldId);
 | 
						|
 | 
						|
					$filterField.keyup(function() {
 | 
						|
						self.options.filterFieldText = $(this).val();
 | 
						|
						self.setFilter(self.options.filter);
 | 
						|
					});
 | 
						|
 | 
						|
				}
 | 
						|
 | 
						|
				$destination.waitForImages(function() {
 | 
						|
					$destination.isotope(self.options);
 | 
						|
					self.events();
 | 
						|
				});
 | 
						|
 | 
						|
				setTimeout(function() {
 | 
						|
					self.removeLoader();
 | 
						|
				}, 3000);
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		events: function() {
 | 
						|
			var self = this,
 | 
						|
				filter = null,
 | 
						|
				$window = $(window);
 | 
						|
 | 
						|
			self.$source.find('a').click(function(e) {
 | 
						|
				e.preventDefault();
 | 
						|
 | 
						|
				filter = $(this).parent().data('option-value');
 | 
						|
 | 
						|
				self.setFilter(filter);
 | 
						|
 | 
						|
				if (e.originalEvent) {
 | 
						|
					self.$source.trigger('filtered');
 | 
						|
				}
 | 
						|
 | 
						|
				return this;
 | 
						|
			});
 | 
						|
 | 
						|
			self.$destination.trigger('filtered');
 | 
						|
			self.$source.trigger('filtered');
 | 
						|
 | 
						|
			if (self.options.useHash) {
 | 
						|
				self.hashEvents();
 | 
						|
			}
 | 
						|
 | 
						|
			$window.on('resize sort.resize', function() {
 | 
						|
				setTimeout(function() {
 | 
						|
					self.$destination.isotope('layout');
 | 
						|
				}, 300);
 | 
						|
			});
 | 
						|
 | 
						|
			setTimeout(function() {
 | 
						|
				$window.trigger('sort.resize');
 | 
						|
			}, 300);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setFilter: function(filter) {
 | 
						|
			var self = this,
 | 
						|
				page = false,
 | 
						|
				currentFilter = filter;
 | 
						|
 | 
						|
			self.$source.find('.active').removeClass('active');
 | 
						|
			self.$source.find('li[data-option-value="' + filter + '"], li[data-option-value="' + filter + '"] > a').addClass('active');
 | 
						|
 | 
						|
			self.options.filter = currentFilter;
 | 
						|
 | 
						|
			if (self.$destination.attr('data-current-page')) {
 | 
						|
				currentFilter = currentFilter + '[data-page-rel=' + self.$destination.attr('data-current-page') + ']';
 | 
						|
			}
 | 
						|
 | 
						|
			if (self.options.filterFieldText != '') {
 | 
						|
				currentFilter = currentFilter + '[data-sort-search*=' + self.options.filterFieldText.toLowerCase() + ']';
 | 
						|
			}
 | 
						|
 | 
						|
			self.$destination.attr('data-filter', filter).isotope({
 | 
						|
				filter: currentFilter
 | 
						|
			}).one('arrangeComplete', function( event, filteredItems ) {
 | 
						|
				
 | 
						|
				if (self.options.useHash) {
 | 
						|
					if (window.location.hash != '' || self.options.filter.replace('.', '') != '*') {
 | 
						|
						window.location.hash = self.options.filter.replace('.', '');
 | 
						|
					}
 | 
						|
				}
 | 
						|
				
 | 
						|
				$(window).trigger('scroll');
 | 
						|
 | 
						|
			}).trigger('filtered');
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		hashEvents: function() {
 | 
						|
			var self = this,
 | 
						|
				hash = null,
 | 
						|
				hashFilter = null,
 | 
						|
				initHashFilter = '.' + location.hash.replace('#', '');
 | 
						|
 | 
						|
			// Check if has scroll to section trough URL hash and prevent the sort plugin from show nothing
 | 
						|
			if( $(location.hash).length ) {
 | 
						|
				initHashFilter = '.';
 | 
						|
			}
 | 
						|
 | 
						|
			if (initHashFilter != '.' && initHashFilter != '.*') {
 | 
						|
				self.setFilter(initHashFilter);
 | 
						|
			}
 | 
						|
 | 
						|
			$(window).on('hashchange', function(e) {
 | 
						|
 | 
						|
				hashFilter = '.' + location.hash.replace('#', '');
 | 
						|
				hash = (hashFilter == '.' || hashFilter == '.*' ? '*' : hashFilter);
 | 
						|
 | 
						|
				self.setFilter(hash);
 | 
						|
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setParagraphHeight: function() {
 | 
						|
			var self = this,
 | 
						|
				minParagraphHeight = 0,
 | 
						|
				paragraphs = $('span.thumb-info-caption p', self.$destination);
 | 
						|
 | 
						|
			paragraphs.each(function() {
 | 
						|
				if ($(this).height() > minParagraphHeight) {
 | 
						|
					minParagraphHeight = ($(this).height() + 10);
 | 
						|
				}
 | 
						|
			});
 | 
						|
 | 
						|
			paragraphs.height(minParagraphHeight);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		createLoader: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			var loaderTemplate = [
 | 
						|
				'<div class="bounce-loader">',
 | 
						|
					'<div class="bounce1"></div>',
 | 
						|
					'<div class="bounce2"></div>',
 | 
						|
					'<div class="bounce3"></div>',
 | 
						|
				'</div>'
 | 
						|
			].join('');
 | 
						|
 | 
						|
			self.$loader.append(loaderTemplate);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		removeLoader: function() {
 | 
						|
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if (self.$loader) {
 | 
						|
 | 
						|
				self.$loader.removeClass('sort-destination-loader-showing');
 | 
						|
 | 
						|
				setTimeout(function() {
 | 
						|
					self.$loader.addClass('sort-destination-loader-loaded');
 | 
						|
				}, 300);
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginSort: PluginSort
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginSort = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginSort($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Star Rating
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__starrating';
 | 
						|
 | 
						|
	var PluginStarRating = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginStarRating.defaults = {
 | 
						|
		theme: 'krajee-fas',
 | 
						|
		color: 'primary',
 | 
						|
		showClear: false,
 | 
						|
		showCaption: false
 | 
						|
	};
 | 
						|
 | 
						|
	PluginStarRating.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginStarRating.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
 | 
						|
			if (!($.isFunction($.fn.rating))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			self.options.wrapper
 | 
						|
				.rating(self.options);
 | 
						|
 | 
						|
			self.options.wrapper.parents('.rating-container')
 | 
						|
				.addClass('rating-' + self.options.color);
 | 
						|
 | 
						|
			if( self.options.extraClass ) {
 | 
						|
				self.options.wrapper.parents('.rating-container')
 | 
						|
					.addClass(self.options.extraClass);
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginStarRating: PluginStarRating
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginStarRating = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginStarRating($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Sticky
 | 
						|
(function(theme, $) {
 | 
						|
	
 | 
						|
	theme = theme || {};
 | 
						|
	
 | 
						|
	var instanceName = '__sticky';
 | 
						|
 | 
						|
	var PluginSticky = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginSticky.defaults = {
 | 
						|
		minWidth: 991,
 | 
						|
		activeClass: 'sticky-active'
 | 
						|
	};
 | 
						|
 | 
						|
	PluginSticky.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ( $el.data( instanceName ) ) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build()
 | 
						|
				.events();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginSticky.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			if (!($.isFunction($.fn.pin))) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this,
 | 
						|
				$window = $(window);
 | 
						|
			
 | 
						|
			self.options.wrapper.pin(self.options);
 | 
						|
 | 
						|
			if( self.options.wrapper.hasClass('sticky-wrapper-transparent') ) {
 | 
						|
				self.options.wrapper.parent().addClass('position-absolute w-100');
 | 
						|
			}
 | 
						|
 | 
						|
			$window.afterResize(function() {
 | 
						|
				self.options.wrapper.removeAttr('style').removeData('pin');
 | 
						|
				self.options.wrapper.pin(self.options);
 | 
						|
				$window.trigger('scroll');
 | 
						|
			});
 | 
						|
 | 
						|
			// Change Logo Src
 | 
						|
			if( self.options.wrapper.find('img').attr('data-change-src') ) {
 | 
						|
				var $logo      = self.options.wrapper.find('img'),
 | 
						|
					logoSrc    = $logo.attr('src'),
 | 
						|
					logoNewSrc = $logo.attr('data-change-src');
 | 
						|
 | 
						|
				self.changeLogoSrc = function(activate) {
 | 
						|
					if(activate) {
 | 
						|
						$logo.attr('src', logoNewSrc);
 | 
						|
					} else {
 | 
						|
						$logo.attr('src', logoSrc);
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
			
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		events: function() {
 | 
						|
			var self = this,
 | 
						|
				$window = $(window),
 | 
						|
				$logo = self.options.wrapper.find('img'),
 | 
						|
				sticky_activate_flag = true,
 | 
						|
				sticky_deactivate_flag = false,
 | 
						|
				class_to_check = ( self.options.wrapper.hasClass('sticky-wrapper-effect-1') ) ? 'sticky-effect-active' : 'sticky-active';
 | 
						|
 | 
						|
			$window.on('scroll sticky.effect.active', function(){
 | 
						|
				if( self.options.wrapper.hasClass( class_to_check ) ) {		
 | 
						|
					if( sticky_activate_flag ) {			
 | 
						|
						if( $logo.attr('data-change-src') ) {
 | 
						|
							self.changeLogoSrc(true);
 | 
						|
						}
 | 
						|
 | 
						|
						sticky_activate_flag = false;
 | 
						|
						sticky_deactivate_flag = true;
 | 
						|
					}
 | 
						|
				} else {	
 | 
						|
					if( sticky_deactivate_flag ) {				
 | 
						|
						if( $logo.attr('data-change-src') ) {
 | 
						|
							self.changeLogoSrc(false);
 | 
						|
						}
 | 
						|
 | 
						|
						sticky_deactivate_flag = false;
 | 
						|
						sticky_activate_flag = true;
 | 
						|
					}
 | 
						|
				}
 | 
						|
			});
 | 
						|
 | 
						|
			var is_backing = false;
 | 
						|
			if( self.options.stickyStartEffectAt ) {
 | 
						|
 | 
						|
				// First Load
 | 
						|
				if( self.options.stickyStartEffectAt < $window.scrollTop() ) {
 | 
						|
					self.options.wrapper.addClass('sticky-effect-active');
 | 
						|
 | 
						|
					$window.trigger('sticky.effect.active');
 | 
						|
				}
 | 
						|
 | 
						|
				$window.on('scroll', function(){
 | 
						|
					if( self.options.stickyStartEffectAt < $window.scrollTop() ) {	
 | 
						|
						self.options.wrapper.addClass('sticky-effect-active');
 | 
						|
						is_backing = true;
 | 
						|
 | 
						|
						$window.trigger('sticky.effect.active');
 | 
						|
					} else {	
 | 
						|
						if( is_backing ) {
 | 
						|
							self.options.wrapper.find('.sticky-body').addClass('position-fixed');
 | 
						|
							is_backing = false;
 | 
						|
						}
 | 
						|
 | 
						|
						if( $window.scrollTop() == 0 ) {
 | 
						|
							self.options.wrapper.find('.sticky-body').removeClass('position-fixed');
 | 
						|
						}
 | 
						|
 | 
						|
						self.options.wrapper.removeClass('sticky-effect-active');
 | 
						|
					}
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			// Refresh Sticky Plugin if click in a data-toggle="collapse"
 | 
						|
			if( $('[data-bs-toggle="collapse"]').get(0) ) {
 | 
						|
 | 
						|
				$('[data-bs-toggle="collapse"]').on('click', function(){
 | 
						|
					setTimeout(function(){
 | 
						|
						self.build();
 | 
						|
						$(window).trigger('scroll');
 | 
						|
					}, 1000);
 | 
						|
				});
 | 
						|
 | 
						|
			}
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginSticky: PluginSticky
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginSticky = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginSticky($this, opts);
 | 
						|
			}
 | 
						|
			
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [ window.theme, jQuery ]);
 | 
						|
 | 
						|
// Toggle
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__toggle';
 | 
						|
 | 
						|
	var PluginToggle = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginToggle.defaults = {
 | 
						|
		duration: 350,
 | 
						|
		isAccordion: false
 | 
						|
	};
 | 
						|
 | 
						|
	PluginToggle.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginToggle.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this,
 | 
						|
				$wrapper = this.options.wrapper,
 | 
						|
				$items = $wrapper.find('> .toggle'),
 | 
						|
				$el = null;
 | 
						|
 | 
						|
			$items.each(function() {
 | 
						|
				$el = $(this);
 | 
						|
 | 
						|
				if ($el.hasClass('active')) {
 | 
						|
					$el.find('> p').addClass('preview-active');
 | 
						|
					$el.find('> .toggle-content').slideDown(self.options.duration);
 | 
						|
				}
 | 
						|
 | 
						|
				self.events($el);
 | 
						|
			});
 | 
						|
 | 
						|
			if (self.options.isAccordion) {
 | 
						|
				self.options.duration = self.options.duration / 2;
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		events: function($el) {
 | 
						|
			var self = this,
 | 
						|
				previewParCurrentHeight = 0,
 | 
						|
				previewParAnimateHeight = 0,
 | 
						|
				toggleContent = null;
 | 
						|
 | 
						|
			$el.find('> label, > .toggle-title').click(function(e) {
 | 
						|
 | 
						|
				var $this = $(this),
 | 
						|
					parentSection = $this.parent(),
 | 
						|
					parentWrapper = $this.parents('.toggle'),
 | 
						|
					previewPar = null,
 | 
						|
					closeElement = null;
 | 
						|
 | 
						|
				if (self.options.isAccordion && typeof(e.originalEvent) != 'undefined') {
 | 
						|
					closeElement = parentWrapper.find('.toggle.active > label, .toggle.active > .toggle-title');
 | 
						|
 | 
						|
					if (closeElement[0] == $this[0]) {
 | 
						|
						return;
 | 
						|
					}
 | 
						|
				}
 | 
						|
 | 
						|
				parentSection.toggleClass('active');
 | 
						|
 | 
						|
				// Preview Paragraph
 | 
						|
				if (parentSection.find('> p').get(0)) {
 | 
						|
 | 
						|
					previewPar = parentSection.find('> p');
 | 
						|
					previewParCurrentHeight = previewPar.css('height');
 | 
						|
					previewPar.css('height', 'auto');
 | 
						|
					previewParAnimateHeight = previewPar.css('height');
 | 
						|
					previewPar.css('height', previewParCurrentHeight);
 | 
						|
 | 
						|
				}
 | 
						|
 | 
						|
				// Content
 | 
						|
				toggleContent = parentSection.find('> .toggle-content');
 | 
						|
 | 
						|
				if (parentSection.hasClass('active')) {
 | 
						|
 | 
						|
					$(previewPar).animate({
 | 
						|
						height: previewParAnimateHeight
 | 
						|
					}, self.options.duration, function() {
 | 
						|
						$(this).addClass('preview-active');
 | 
						|
					});
 | 
						|
 | 
						|
					toggleContent.slideDown(self.options.duration, function() {
 | 
						|
						if (closeElement) {
 | 
						|
							closeElement.trigger('click');
 | 
						|
						}
 | 
						|
					});
 | 
						|
 | 
						|
				} else {
 | 
						|
 | 
						|
					$(previewPar).animate({
 | 
						|
						height: 0
 | 
						|
					}, self.options.duration, function() {
 | 
						|
						$(this).removeClass('preview-active');
 | 
						|
					});
 | 
						|
 | 
						|
					toggleContent.slideUp(self.options.duration);
 | 
						|
 | 
						|
				}
 | 
						|
 | 
						|
			});
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginToggle: PluginToggle
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginToggle = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginToggle($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Tweets
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__tweets';
 | 
						|
 | 
						|
	var PluginTweets = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginTweets.defaults = {
 | 
						|
		username: null,
 | 
						|
		count: 2,
 | 
						|
		URL: 'php/twitter-feed.php',
 | 
						|
		iconColor: false
 | 
						|
	};
 | 
						|
 | 
						|
	PluginTweets.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			if ($el.data(instanceName)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginTweets.defaults, opts, {
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			if (this.options.username == null || this.options.username == '') {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			var self = this,
 | 
						|
				$wrapper = this.options.wrapper;
 | 
						|
 | 
						|
			$.ajax({
 | 
						|
				type: 'GET',
 | 
						|
				data: {
 | 
						|
					twitter_screen_name: self.options.username,
 | 
						|
					tweets_to_display: self.options.count,
 | 
						|
					icon_color: self.options.iconColor
 | 
						|
				},
 | 
						|
				url: self.options.URL,
 | 
						|
			}).done(function(html) {
 | 
						|
				$wrapper.html(html).find('a').attr('target','_blank');
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginTweets: PluginTweets
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginTweets = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginTweets($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Validation
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	$.extend(theme, {
 | 
						|
 | 
						|
		PluginValidation: {
 | 
						|
 | 
						|
			defaults: {
 | 
						|
				formClass: 'needs-validation',
 | 
						|
				validator: {
 | 
						|
					highlight: function(element) {
 | 
						|
						$(element)
 | 
						|
							.addClass('is-invalid')
 | 
						|
							.removeClass('is-valid')
 | 
						|
							.parent()
 | 
						|
							.removeClass('has-success')
 | 
						|
							.addClass('has-danger');
 | 
						|
					},
 | 
						|
					success: function(label, element) {
 | 
						|
						$(element)
 | 
						|
							.removeClass('is-invalid')
 | 
						|
							.addClass('is-valid')
 | 
						|
							.parent()
 | 
						|
							.removeClass('has-danger')
 | 
						|
							.addClass('has-success')
 | 
						|
							.find('label.error')
 | 
						|
							.remove();
 | 
						|
					},
 | 
						|
					errorPlacement: function(error, element) {
 | 
						|
						if (element.attr('type') == 'radio' || element.attr('type') == 'checkbox') {
 | 
						|
							error.appendTo(element.parent().parent());
 | 
						|
						} else {
 | 
						|
							error.insertAfter(element);
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}
 | 
						|
			},
 | 
						|
 | 
						|
			initialize: function(opts) {
 | 
						|
				initialized = true;
 | 
						|
 | 
						|
				this
 | 
						|
					.setOptions(opts)
 | 
						|
					.build();
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			setOptions: function(opts) {
 | 
						|
				this.options = $.extend(true, {}, this.defaults, opts);
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			build: function() {
 | 
						|
				var self = this;
 | 
						|
 | 
						|
				if (!($.isFunction($.validator))) {
 | 
						|
					return this;
 | 
						|
				}
 | 
						|
 | 
						|
				self.setMessageGroups();
 | 
						|
 | 
						|
				$.validator.setDefaults(self.options.validator);
 | 
						|
 | 
						|
				$('.' + self.options.formClass).validate();
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			setMessageGroups: function() {
 | 
						|
 | 
						|
				$('.checkbox-group[data-msg-required], .radio-group[data-msg-required]').each(function() {
 | 
						|
					var message = $(this).data('msg-required');
 | 
						|
					$(this).find('input').attr('data-msg-required', message);
 | 
						|
				});
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
	});
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Video Background
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var instanceName = '__videobackground';
 | 
						|
 | 
						|
	var PluginVideoBackground = function($el, opts) {
 | 
						|
		return this.initialize($el, opts);
 | 
						|
	};
 | 
						|
 | 
						|
	PluginVideoBackground.defaults = {
 | 
						|
		overlay: false,
 | 
						|
		volume: 1,
 | 
						|
		playbackRate: 1,
 | 
						|
		muted: true,
 | 
						|
		loop: true,
 | 
						|
		autoplay: true,
 | 
						|
		position: '50% 50%',
 | 
						|
		posterType: 'detect',
 | 
						|
		className: 'vide-video-wrapper'
 | 
						|
	};
 | 
						|
 | 
						|
	PluginVideoBackground.prototype = {
 | 
						|
		initialize: function($el, opts) {
 | 
						|
			this.$el = $el;
 | 
						|
 | 
						|
			this
 | 
						|
				.setData()
 | 
						|
				.setOptions(opts)
 | 
						|
				.build()
 | 
						|
				.events();
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setData: function() {
 | 
						|
			this.$el.data(instanceName, this);
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		setOptions: function(opts) {
 | 
						|
			this.options = $.extend(true, {}, PluginVideoBackground.defaults, opts, {
 | 
						|
				path: this.$el.data('video-path'),
 | 
						|
				wrapper: this.$el
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		build: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			if (!($.isFunction($.fn.vide)) || (!this.options.path)) {
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			if (this.options.overlay) {
 | 
						|
 | 
						|
				var overlayClass = this.options.overlayClass;
 | 
						|
 | 
						|
				this.options.wrapper.prepend(
 | 
						|
					$('<div />').addClass(overlayClass)
 | 
						|
				);
 | 
						|
			}
 | 
						|
 | 
						|
			this.options.wrapper
 | 
						|
				.vide(this.options.path, this.options)
 | 
						|
				.first()
 | 
						|
				.css('z-index', 0);
 | 
						|
 | 
						|
			// Change Poster
 | 
						|
			self.changePoster();
 | 
						|
 | 
						|
			// Initialize Vide inside a carousel
 | 
						|
			if( self.options.wrapper.closest('.owl-carousel').get(0) ) {
 | 
						|
				self.options.wrapper.closest('.owl-carousel').on('initialized.owl.carousel', function(){
 | 
						|
					$('.owl-item.cloned')
 | 
						|
						.find('[data-plugin-video-background] .vide-video-wrapper')
 | 
						|
						.remove();
 | 
						|
 | 
						|
					$('.owl-item.cloned')
 | 
						|
						.find('[data-plugin-video-background]')
 | 
						|
						.vide(self.options.path, self.options)
 | 
						|
						.first()
 | 
						|
						.css('z-index', 0);
 | 
						|
 | 
						|
					self.changePoster( self.options.wrapper.closest('.owl-carousel') );
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			// Play Video Button
 | 
						|
			var $playButton = self.options.wrapper.find('.video-background-play');
 | 
						|
 | 
						|
			if( $playButton.get(0) ) {
 | 
						|
				var $playWrapper = self.options.wrapper.find('.video-background-play-wrapper');
 | 
						|
 | 
						|
				self.options.wrapper.find('.video-background-play').on('click', function(e){
 | 
						|
					e.preventDefault();
 | 
						|
 | 
						|
					if( $playWrapper.get(0) ) {
 | 
						|
						$playWrapper.animate({
 | 
						|
							opacity: 0
 | 
						|
						}, 300, function(){
 | 
						|
							$playWrapper.parent().height( $playWrapper.outerHeight() );
 | 
						|
							$playWrapper.remove();
 | 
						|
						});
 | 
						|
					} else {
 | 
						|
						$playButton.animate({
 | 
						|
							opacity: 0
 | 
						|
						}, 300, function(){
 | 
						|
							$playButton.remove();
 | 
						|
						});
 | 
						|
					}
 | 
						|
 | 
						|
					setTimeout(function(){
 | 
						|
						self.options.wrapper.find('video')[0].play();
 | 
						|
					}, 500)
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			$(window).trigger('vide.video.inserted.on.dom');
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		changePoster: function( $carousel ) {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			// If it's inside carousel
 | 
						|
			if( $carousel && self.options.changePoster ) {
 | 
						|
				$carousel.find('.owl-item [data-plugin-video-background] .vide-video-wrapper').css({
 | 
						|
					'background-image': 'url(' + self.options.changePoster + ')'
 | 
						|
				});
 | 
						|
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
			if( self.options.changePoster ) {
 | 
						|
				self.options.wrapper.find('.vide-video-wrapper').css({
 | 
						|
					'background-image': 'url(' + self.options.changePoster + ')'
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
			return this;
 | 
						|
		},
 | 
						|
 | 
						|
		events: function() {
 | 
						|
			var self = this;
 | 
						|
 | 
						|
			// Initialize
 | 
						|
			self.options.wrapper.on('video.background.initialize', function(){
 | 
						|
				self.build();
 | 
						|
			});
 | 
						|
 | 
						|
			return this;
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	// expose to scope
 | 
						|
	$.extend(theme, {
 | 
						|
		PluginVideoBackground: PluginVideoBackground
 | 
						|
	});
 | 
						|
 | 
						|
	// jquery plugin
 | 
						|
	$.fn.themePluginVideoBackground = function(opts) {
 | 
						|
		return this.map(function() {
 | 
						|
			var $this = $(this);
 | 
						|
 | 
						|
			if ($this.data(instanceName)) {
 | 
						|
				return $this.data(instanceName);
 | 
						|
			} else {
 | 
						|
				return new PluginVideoBackground($this, opts);
 | 
						|
			}
 | 
						|
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Account
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var initialized = false;
 | 
						|
 | 
						|
	$.extend(theme, {
 | 
						|
 | 
						|
		Account: {
 | 
						|
 | 
						|
			defaults: {
 | 
						|
				wrapper: $('#headerAccount')
 | 
						|
			},
 | 
						|
 | 
						|
			initialize: function($wrapper, opts) {
 | 
						|
				if (initialized) {
 | 
						|
					return this;
 | 
						|
				}
 | 
						|
 | 
						|
				initialized = true;
 | 
						|
				this.$wrapper = ($wrapper || this.defaults.wrapper);
 | 
						|
 | 
						|
				this
 | 
						|
					.setOptions(opts)
 | 
						|
					.events();
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			setOptions: function(opts) {
 | 
						|
				this.options = $.extend(true, {}, this.defaults, opts, theme.fn.getOptions(this.$wrapper.data('plugin-options')));
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			events: function() {
 | 
						|
				var self = this;
 | 
						|
 | 
						|
				$(window).on('load', function(){
 | 
						|
					$(document).ready(function(){
 | 
						|
						setTimeout(function(){
 | 
						|
 | 
						|
							self.$wrapper.find('input').on('focus', function() {
 | 
						|
								self.$wrapper.addClass('open');
 | 
						|
 | 
						|
								$(document).mouseup(function(e) {
 | 
						|
									if (!self.$wrapper.is(e.target) && self.$wrapper.has(e.target).length === 0) {
 | 
						|
										self.$wrapper.removeClass('open');
 | 
						|
									}
 | 
						|
								});
 | 
						|
							});
 | 
						|
 | 
						|
						}, 1500);
 | 
						|
					});
 | 
						|
				});
 | 
						|
 | 
						|
				$('#headerSignUp').on('click', function(e) {
 | 
						|
					e.preventDefault();
 | 
						|
					self.$wrapper.addClass('signup').removeClass('signin').removeClass('recover');
 | 
						|
					self.$wrapper.find('.signup-form input:first').focus();
 | 
						|
				});
 | 
						|
 | 
						|
				$('#headerSignIn').on('click', function(e) {
 | 
						|
					e.preventDefault();
 | 
						|
					self.$wrapper.addClass('signin').removeClass('signup').removeClass('recover');
 | 
						|
					self.$wrapper.find('.signin-form input:first').focus();
 | 
						|
				});
 | 
						|
 | 
						|
				$('#headerRecover').on('click', function(e) {
 | 
						|
					e.preventDefault();
 | 
						|
					self.$wrapper.addClass('recover').removeClass('signup').removeClass('signin');
 | 
						|
					self.$wrapper.find('.recover-form input:first').focus();
 | 
						|
				});
 | 
						|
 | 
						|
				$('#headerRecoverCancel').on('click', function(e) {
 | 
						|
					e.preventDefault();
 | 
						|
					self.$wrapper.addClass('signin').removeClass('signup').removeClass('recover');
 | 
						|
					self.$wrapper.find('.signin-form input:first').focus();
 | 
						|
				});
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
	});
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Nav
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var initialized = false;
 | 
						|
 | 
						|
	$.extend(theme, {
 | 
						|
 | 
						|
		Nav: {
 | 
						|
 | 
						|
			defaults: {
 | 
						|
				wrapper: $('#mainNav'),
 | 
						|
				scrollDelay: 600,
 | 
						|
				scrollAnimation: 'easeOutQuad'
 | 
						|
			},
 | 
						|
 | 
						|
			initialize: function($wrapper, opts) {
 | 
						|
				if (initialized) {
 | 
						|
					return this;
 | 
						|
				}
 | 
						|
 | 
						|
				initialized = true;
 | 
						|
				this.$wrapper = ($wrapper || this.defaults.wrapper);
 | 
						|
 | 
						|
				this
 | 
						|
					.setOptions(opts)
 | 
						|
					.build()
 | 
						|
					.events();
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			setOptions: function(opts) {
 | 
						|
				this.options = $.extend(true, {}, this.defaults, opts, theme.fn.getOptions(this.$wrapper.data('plugin-options')));
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			build: function() {
 | 
						|
				var self = this,
 | 
						|
					$html = $('html'),
 | 
						|
					$header = $('#header'),
 | 
						|
					$headerNavMain = $('#header .header-nav-main'),
 | 
						|
					thumbInfoPreview;
 | 
						|
 | 
						|
				// Preview Thumbs
 | 
						|
				if( self.$wrapper.find('a[data-thumb-preview]').length ) {
 | 
						|
					self.$wrapper.find('a[data-thumb-preview]').each(function() {
 | 
						|
						thumbInfoPreview = $('<span />').addClass('thumb-info thumb-info-preview')
 | 
						|
												.append($('<span />').addClass('thumb-info-wrapper')
 | 
						|
													.append($('<span />').addClass('thumb-info-image').css('background-image', 'url(' + $(this).data('thumb-preview') + ')')
 | 
						|
											   )
 | 
						|
										   );
 | 
						|
 | 
						|
						$(this).append(thumbInfoPreview);
 | 
						|
					});
 | 
						|
				}
 | 
						|
 | 
						|
				// Side Header / Side Header Hamburguer Sidebar (Reverse Dropdown)
 | 
						|
				if($html.hasClass('side-header') || $html.hasClass('side-header-hamburguer-sidebar')) {
 | 
						|
					
 | 
						|
					// Side Header Right / Side Header Hamburguer Sidebar Right
 | 
						|
					if($html.hasClass('side-header-right') || $html.hasClass('side-header-hamburguer-sidebar-right')) {
 | 
						|
						if(!$html.hasClass('side-header-right-no-reverse')) {
 | 
						|
							$header.find('.dropdown-submenu').addClass('dropdown-reverse');
 | 
						|
						}
 | 
						|
					}
 | 
						|
 | 
						|
				} else {
 | 
						|
					
 | 
						|
					// Reverse
 | 
						|
					var checkReverseFlag = false;
 | 
						|
					self.checkReverse = function() {
 | 
						|
						if( !checkReverseFlag ) {
 | 
						|
							self.$wrapper.find('.dropdown, .dropdown-submenu').removeClass('dropdown-reverse');
 | 
						|
 | 
						|
							self.$wrapper.find('.dropdown:not(.manual):not(.dropdown-mega), .dropdown-submenu:not(.manual)').each(function() {
 | 
						|
								if(!$(this).find('.dropdown-menu').visible( false, true, 'horizontal' )  ) {
 | 
						|
									$(this).addClass('dropdown-reverse');
 | 
						|
								}
 | 
						|
							});
 | 
						|
 | 
						|
							checkReverseFlag = true;
 | 
						|
						}
 | 
						|
					}
 | 
						|
 | 
						|
					$(window).on('resize', function(){
 | 
						|
						checkReverseFlag = false;
 | 
						|
					});
 | 
						|
 | 
						|
					$header.on('mouseover', function(){
 | 
						|
						self.checkReverse();
 | 
						|
					});
 | 
						|
 | 
						|
				}
 | 
						|
 | 
						|
				// Clone Items
 | 
						|
				if($headerNavMain.hasClass('header-nav-main-clone-items')) {
 | 
						|
 | 
						|
			    	$headerNavMain.find('nav > ul > li > a').each(function(){
 | 
						|
				    	var parent = $(this).parent(),
 | 
						|
				    		clone  = $(this).clone(),
 | 
						|
				    		clone2 = $(this).clone(),
 | 
						|
				    		wrapper = $('<span class="wrapper-items-cloned"></span>');
 | 
						|
 | 
						|
				    	// Config Classes
 | 
						|
				    	$(this).addClass('item-original');
 | 
						|
				    	clone2.addClass('item-two');
 | 
						|
 | 
						|
				    	// Insert on DOM
 | 
						|
				    	parent.prepend(wrapper);
 | 
						|
				    	wrapper.append(clone).append(clone2);
 | 
						|
				    });
 | 
						|
 | 
						|
				}
 | 
						|
 | 
						|
				// Floating
 | 
						|
				if($('#header.header-floating-icons').length && $(window).width() > 991) {
 | 
						|
 | 
						|
					var menuFloatingAnim = {
 | 
						|
						$menuFloating: $('#header.header-floating-icons .header-container > .header-row'),
 | 
						|
 | 
						|
						build: function() {
 | 
						|
							var self = this;
 | 
						|
 | 
						|
							self.init();
 | 
						|
						},
 | 
						|
						init: function(){
 | 
						|
							var self  = this,
 | 
						|
								divisor = 0;
 | 
						|
 | 
						|
							$(window).scroll(function() {
 | 
						|
							    var scrollPercent = 100 * $(window).scrollTop() / ($(document).height() - $(window).height()),
 | 
						|
							    	st = $(this).scrollTop();
 | 
						|
 | 
						|
								divisor = $(document).height() / $(window).height();
 | 
						|
 | 
						|
							    self.$menuFloating.find('.header-column > .header-row').css({
 | 
						|
							    	transform : 'translateY( calc('+ scrollPercent +'vh - '+ st / divisor +'px) )' 
 | 
						|
							    });
 | 
						|
							});
 | 
						|
						}
 | 
						|
					}
 | 
						|
 | 
						|
					menuFloatingAnim.build();
 | 
						|
 | 
						|
				}
 | 
						|
 | 
						|
				// Slide
 | 
						|
				if($('.header-nav-links-vertical-slide').length) {
 | 
						|
					var slideNavigation = {
 | 
						|
						$mainNav: $('#mainNav'),
 | 
						|
						$mainNavItem: $('#mainNav li'),
 | 
						|
 | 
						|
						build: function(){
 | 
						|
							var self = this;
 | 
						|
 | 
						|
							self.menuNav();
 | 
						|
						},
 | 
						|
						menuNav: function(){
 | 
						|
							var self = this;
 | 
						|
 | 
						|
							self.$mainNavItem.on('click', function(e){
 | 
						|
								var currentMenuItem 	= $(this),
 | 
						|
									currentMenu 		= $(this).parent(),
 | 
						|
									nextMenu        	= $(this).find('ul').first(),
 | 
						|
									prevMenu        	= $(this).closest('.next-menu'),
 | 
						|
									isSubMenu       	= currentMenuItem.hasClass('dropdown') || currentMenuItem.hasClass('dropdown-submenu'),
 | 
						|
									isBack          	= currentMenuItem.hasClass('back-button'),
 | 
						|
									nextMenuHeightDiff  = ( ( nextMenu.find('> li').length * nextMenu.find('> li').outerHeight() ) - nextMenu.outerHeight() ),
 | 
						|
									prevMenuHeightDiff  = ( ( prevMenu.find('> li').length * prevMenu.find('> li').outerHeight() ) - prevMenu.outerHeight() );
 | 
						|
 | 
						|
								if( isSubMenu ) {
 | 
						|
									currentMenu.addClass('next-menu');
 | 
						|
									nextMenu.addClass('visible');
 | 
						|
									currentMenu.css({
 | 
						|
										overflow: 'visible',
 | 
						|
										'overflow-y': 'visible'
 | 
						|
									});
 | 
						|
									
 | 
						|
									if( nextMenuHeightDiff > 0 ) {
 | 
						|
										nextMenu.css({
 | 
						|
											overflow: 'hidden',
 | 
						|
											'overflow-y': 'scroll'
 | 
						|
										});
 | 
						|
									}
 | 
						|
 | 
						|
									for( i = 0; i < nextMenu.find('> li').length; i++ ) {
 | 
						|
										if( nextMenu.outerHeight() < ($('.header-row-side-header').outerHeight() - 100) ) {
 | 
						|
											nextMenu.css({
 | 
						|
												height: nextMenu.outerHeight() + nextMenu.find('> li').outerHeight()
 | 
						|
											});
 | 
						|
										}
 | 
						|
									}
 | 
						|
 | 
						|
									nextMenu.css({
 | 
						|
										'padding-top': nextMenuHeightDiff + 'px'
 | 
						|
									});
 | 
						|
								}
 | 
						|
 | 
						|
								if( isBack ) {
 | 
						|
									currentMenu.parent().parent().removeClass('next-menu');
 | 
						|
									currentMenu.removeClass('visible');
 | 
						|
 | 
						|
									if( prevMenuHeightDiff > 0 ) {
 | 
						|
										prevMenu.css({
 | 
						|
											overflow: 'hidden',
 | 
						|
											'overflow-y': 'scroll'
 | 
						|
										});
 | 
						|
									}
 | 
						|
								}
 | 
						|
 | 
						|
								e.stopPropagation();
 | 
						|
							});
 | 
						|
						}
 | 
						|
					}
 | 
						|
 | 
						|
					$(window).trigger('resize');
 | 
						|
					
 | 
						|
					if( $(window).width() > 991 ) {
 | 
						|
						slideNavigation.build();
 | 
						|
					}
 | 
						|
 | 
						|
					$(document).ready(function(){
 | 
						|
						$(window).afterResize(function(){
 | 
						|
							if( $(window).width() > 991 ) {
 | 
						|
								slideNavigation.build();
 | 
						|
							}
 | 
						|
						});
 | 
						|
					});
 | 
						|
				}
 | 
						|
 | 
						|
				// Header Nav Main Mobile Dark
 | 
						|
				if($('.header-nav-main-mobile-dark').length) {
 | 
						|
					$('#header:not(.header-transparent-dark-bottom-border):not(.header-transparent-light-bottom-border)').addClass('header-no-border-bottom');
 | 
						|
				}
 | 
						|
 | 
						|
				// Keyboard Navigation / Accessibility
 | 
						|
				if( $(window).width() > 991 ) {
 | 
						|
					var focusFlag = false;
 | 
						|
					$header.find('.header-nav-main nav > ul > li > a').on('focus', function(){
 | 
						|
						
 | 
						|
						if( $(window).width() > 991 ) {
 | 
						|
							if( !focusFlag ) {
 | 
						|
								focusFlag = true;
 | 
						|
								$(this).trigger('blur');
 | 
						|
								
 | 
						|
								self.focusMenuWithChildren();
 | 
						|
							}
 | 
						|
						}
 | 
						|
 | 
						|
					});
 | 
						|
				}
 | 
						|
				
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			focusMenuWithChildren: function() {
 | 
						|
				// Get all the link elements within the primary menu.
 | 
						|
				var links, i, len,
 | 
						|
					menu = document.querySelector( 'html:not(.side-header):not(.side-header-hamburguer-sidebar):not(.side-header-overlay-full-screen) .header-nav-main > nav' );
 | 
						|
 | 
						|
				if ( ! menu ) {
 | 
						|
					return false;
 | 
						|
				}
 | 
						|
 | 
						|
				links = menu.getElementsByTagName( 'a' );
 | 
						|
 | 
						|
				// Each time a menu link is focused or blurred, toggle focus.
 | 
						|
				for ( i = 0, len = links.length; i < len; i++ ) {
 | 
						|
					links[i].addEventListener( 'focus', toggleFocus, true );
 | 
						|
					links[i].addEventListener( 'blur', toggleFocus, true );
 | 
						|
				}
 | 
						|
 | 
						|
				//Sets or removes the .focus class on an element.
 | 
						|
				function toggleFocus() {
 | 
						|
					var self = this;
 | 
						|
 | 
						|
					// Move up through the ancestors of the current link until we hit .primary-menu.
 | 
						|
					while ( -1 === self.className.indexOf( 'header-nav-main' ) ) {
 | 
						|
						// On li elements toggle the class .focus.
 | 
						|
						if ( 'li' === self.tagName.toLowerCase() ) {
 | 
						|
							if ( -1 !== self.className.indexOf( 'accessibility-open' ) ) {
 | 
						|
								self.className = self.className.replace( ' accessibility-open', '' );
 | 
						|
							} else {
 | 
						|
								self.className += ' accessibility-open';
 | 
						|
							}
 | 
						|
						}
 | 
						|
						self = self.parentElement;
 | 
						|
					}
 | 
						|
				}
 | 
						|
			},
 | 
						|
 | 
						|
			events: function() {
 | 
						|
				var self    = this,
 | 
						|
					$html   = $('html'),
 | 
						|
					$header = $('#header'),
 | 
						|
					$window = $(window),
 | 
						|
					headerBodyHeight = $('.header-body').outerHeight();
 | 
						|
 | 
						|
				if( $header.hasClass('header') ) {
 | 
						|
					$header = $('.header');
 | 
						|
				}
 | 
						|
 | 
						|
				$header.find('a[href="#"]').on('click', function(e) {
 | 
						|
					e.preventDefault();
 | 
						|
				});
 | 
						|
 | 
						|
				// Mobile Arrows
 | 
						|
				if( $html.hasClass('side-header-hamburguer-sidebar') ) {
 | 
						|
					$header.find('.dropdown-toggle, .dropdown-submenu > a')
 | 
						|
						.append('<i class="fas fa-chevron-down fa-chevron-right"></i>');
 | 
						|
				} else {
 | 
						|
					$header.find('.dropdown-toggle, .dropdown-submenu > a')
 | 
						|
						.append('<i class="fas fa-chevron-down"></i>');
 | 
						|
				}
 | 
						|
				
 | 
						|
				$header.find('.dropdown-toggle[href="#"], .dropdown-submenu a[href="#"], .dropdown-toggle[href!="#"] .fa-chevron-down, .dropdown-submenu a[href!="#"] .fa-chevron-down').on('click', function(e) {
 | 
						|
					e.preventDefault();
 | 
						|
					if ($window.width() < 992) {
 | 
						|
						$(this).closest('li').toggleClass('open');
 | 
						|
 | 
						|
						// Adjust Header Body Height
 | 
						|
						var height = ( $header.hasClass('header-effect-shrink') && $html.hasClass('sticky-header-active') ) ? theme.StickyHeader.options.stickyHeaderContainerHeight : headerBodyHeight;
 | 
						|
						$('.header-body').animate({
 | 
						|
					 		height: ($('.header-nav-main nav').outerHeight(true) + height) + 10
 | 
						|
					 	}, 0);
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				$header.find('li a.active').addClass('current-page-active');
 | 
						|
 | 
						|
				// Add Open Class
 | 
						|
				$header.find('.header-nav-click-to-open .dropdown-toggle[href="#"], .header-nav-click-to-open .dropdown-submenu a[href="#"], .header-nav-click-to-open .dropdown-toggle > i').on('click', function(e) {
 | 
						|
					if( !$('html').hasClass('side-header-hamburguer-sidebar') && $window.width() > 991 ) {
 | 
						|
						e.preventDefault();
 | 
						|
						e.stopPropagation();
 | 
						|
					}
 | 
						|
 | 
						|
					if ($window.width() > 991) {
 | 
						|
						e.preventDefault();
 | 
						|
						e.stopPropagation();
 | 
						|
 | 
						|
						$header.find('li a.active').removeClass('active');
 | 
						|
 | 
						|
						if( $(this).prop('tagName') == 'I' ) {
 | 
						|
							$(this).parent().addClass('active');
 | 
						|
						} else {
 | 
						|
							$(this).addClass('active');
 | 
						|
						}
 | 
						|
 | 
						|
						if (!$(this).closest('li').hasClass('open')) {
 | 
						|
 | 
						|
							var $li = $(this).closest('li'),
 | 
						|
								isSub = false;
 | 
						|
 | 
						|
							if( $(this).prop('tagName') == 'I' ) {
 | 
						|
								$('#header .dropdown.open').removeClass('open');
 | 
						|
								$('#header .dropdown-menu .dropdown-submenu.open').removeClass('open');
 | 
						|
							}
 | 
						|
 | 
						|
							if ( $(this).parent().hasClass('dropdown-submenu') ) {
 | 
						|
								isSub = true;
 | 
						|
							}
 | 
						|
 | 
						|
							$(this).closest('.dropdown-menu').find('.dropdown-submenu.open').removeClass('open');
 | 
						|
							$(this).parent('.dropdown').parent().find('.dropdown.open').removeClass('open');
 | 
						|
 | 
						|
							if (!isSub) {
 | 
						|
								$(this).parent().find('.dropdown-submenu.open').removeClass('open');
 | 
						|
							}
 | 
						|
 | 
						|
							$li.addClass('open');
 | 
						|
 | 
						|
							$(document).off('click.nav-click-to-open').on('click.nav-click-to-open', function (e) {
 | 
						|
								if (!$li.is(e.target) && $li.has(e.target).length === 0) {
 | 
						|
									$li.removeClass('open');
 | 
						|
									$li.parents('.open').removeClass('open');
 | 
						|
									$header.find('li a.active').removeClass('active');
 | 
						|
									$header.find('li a.current-page-active').addClass('active');
 | 
						|
								}
 | 
						|
							});
 | 
						|
 | 
						|
						} else {
 | 
						|
							$(this).closest('li').removeClass('open');
 | 
						|
							$header.find('li a.active').removeClass('active');
 | 
						|
							$header.find('li a.current-page-active').addClass('active');
 | 
						|
						}
 | 
						|
 | 
						|
						$window.trigger({
 | 
						|
							type: 'resize',
 | 
						|
							from: 'header-nav-click-to-open'
 | 
						|
						});
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				// Collapse Nav
 | 
						|
				$header.find('[data-collapse-nav]').on('click', function(e) {
 | 
						|
					$(this).parents('.collapse').removeClass('show');
 | 
						|
				});
 | 
						|
 | 
						|
				// Top Features
 | 
						|
				$header.find('.header-nav-features-toggle').on('click', function(e) {
 | 
						|
					e.preventDefault();
 | 
						|
 | 
						|
					var $toggleParent = $(this).parent();
 | 
						|
 | 
						|
					if (!$(this).siblings('.header-nav-features-dropdown').hasClass('show')) {
 | 
						|
 | 
						|
						var $dropdown = $(this).siblings('.header-nav-features-dropdown');
 | 
						|
 | 
						|
						$('.header-nav-features-dropdown.show').removeClass('show');
 | 
						|
 | 
						|
						$dropdown.addClass('show');
 | 
						|
 | 
						|
						$(document).off('click.header-nav-features-toggle').on('click.header-nav-features-toggle', function (e) {
 | 
						|
							if (!$toggleParent.is(e.target) && $toggleParent.has(e.target).length === 0) {
 | 
						|
								$('.header-nav-features-dropdown.show').removeClass('show');
 | 
						|
							}
 | 
						|
						});
 | 
						|
 | 
						|
						if ($(this).attr('data-focus')) {
 | 
						|
							$('#' + $(this).attr('data-focus')).focus();
 | 
						|
						}
 | 
						|
 | 
						|
					} else {
 | 
						|
						$(this).siblings('.header-nav-features-dropdown').removeClass('show');
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				// Hamburguer Menu
 | 
						|
				var $hamburguerMenuBtn = $('.hamburguer-btn:not(.side-panel-toggle)'),
 | 
						|
					$hamburguerSideHeader = $('#header.side-header, #header.side-header-overlay-full-screen');
 | 
						|
				
 | 
						|
				$hamburguerMenuBtn.on('click', function(){
 | 
						|
					if($(this).attr('data-set-active') != 'false') {
 | 
						|
						$(this).toggleClass('active');
 | 
						|
					}
 | 
						|
					$hamburguerSideHeader.toggleClass('side-header-hide');
 | 
						|
					$html.toggleClass('side-header-hide');
 | 
						|
 | 
						|
					$window.trigger('resize');
 | 
						|
				});
 | 
						|
 | 
						|
				// Toggle Side Header
 | 
						|
				$('.toggle-side-header').on('click', function(){
 | 
						|
					$('.hamburguer-btn-side-header.active').trigger('click');
 | 
						|
				});
 | 
						|
 | 
						|
				$('.hamburguer-close:not(.side-panel-toggle)').on('click', function(){
 | 
						|
					$('.hamburguer-btn:not(.hamburguer-btn-side-header-mobile-show)').trigger('click');
 | 
						|
				});				
 | 
						|
				
 | 
						|
				// Set Header Body Height when open mobile menu
 | 
						|
				$('.header-nav-main nav').on('show.bs.collapse', function () {
 | 
						|
				 	$(this).removeClass('closed');
 | 
						|
 | 
						|
				 	// Add Mobile Menu Opened Class
 | 
						|
				 	$('html').addClass('mobile-menu-opened');
 | 
						|
 | 
						|
			 		$('.header-body').animate({
 | 
						|
				 		height: ($('.header-body').outerHeight() + $('.header-nav-main nav').outerHeight(true)) + 10
 | 
						|
				 	});
 | 
						|
 | 
						|
				 	// Header Below Slider / Header Bottom Slider - Scroll to menu position
 | 
						|
				 	if( $('#header').is('.header-bottom-slider, .header-below-slider') && !$('html').hasClass('sticky-header-active') ) {
 | 
						|
				 		self.scrollToTarget( $('#header'), 0 );
 | 
						|
				 	}
 | 
						|
				});
 | 
						|
 | 
						|
				// Set Header Body Height when collapse mobile menu
 | 
						|
				$('.header-nav-main nav').on('hide.bs.collapse', function () {
 | 
						|
				 	$(this).addClass('closed');
 | 
						|
 | 
						|
				 	// Remove Mobile Menu Opened Class
 | 
						|
				 	$('html').removeClass('mobile-menu-opened');
 | 
						|
 | 
						|
			 		$('.header-body').animate({
 | 
						|
				 		height: ($('.header-body').outerHeight() - $('.header-nav-main nav').outerHeight(true))
 | 
						|
				 	}, function(){
 | 
						|
				 		$(this).height('auto');
 | 
						|
				 	});
 | 
						|
				});
 | 
						|
 | 
						|
				// Header Effect Shrink - Adjust header body height on mobile
 | 
						|
				$window.on('stickyHeader.activate', function(){
 | 
						|
					if( $window.width() < 992 && $header.hasClass('header-effect-shrink') ) {
 | 
						|
						if( $('.header-btn-collapse-nav').attr('aria-expanded') == 'true' ) {
 | 
						|
							$('.header-body').animate({
 | 
						|
						 		height: ( $('.header-nav-main nav').outerHeight(true) + theme.StickyHeader.options.stickyHeaderContainerHeight ) + ( ($('.header-nav-bar').length) ? $('.header-nav-bar').outerHeight() : 0 ) 
 | 
						|
						 	});
 | 
						|
						}
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				$window.on('stickyHeader.deactivate', function(){
 | 
						|
					if( $window.width() < 992 && $header.hasClass('header-effect-shrink') ) {
 | 
						|
						if( $('.header-btn-collapse-nav').attr('aria-expanded') == 'true' ) {
 | 
						|
							$('.header-body').animate({
 | 
						|
						 		height: headerBodyHeight + $('.header-nav-main nav').outerHeight(true) + 10
 | 
						|
						 	});
 | 
						|
						}
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				// Remove Open Class on Resize		
 | 
						|
				$window.on('resize.removeOpen', function(e) {
 | 
						|
					if( e.from == 'header-nav-click-to-open' ) {
 | 
						|
						return;
 | 
						|
					}
 | 
						|
					
 | 
						|
					setTimeout(function() {
 | 
						|
						if( $window.width() > 991 ) {
 | 
						|
							$header.find('.dropdown.open').removeClass('open');
 | 
						|
						}
 | 
						|
					}, 100);
 | 
						|
				});
 | 
						|
 | 
						|
				// Side Header - Change value of initial header body height
 | 
						|
				$(document).ready(function(){
 | 
						|
					if( $window.width() > 991 ) {
 | 
						|
						var flag = false;
 | 
						|
						
 | 
						|
						$window.on('resize', function(e) {
 | 
						|
							if( e.from == 'header-nav-click-to-open' ) {
 | 
						|
								return;
 | 
						|
							}
 | 
						|
 | 
						|
							$header.find('.dropdown.open').removeClass('open');
 | 
						|
 | 
						|
							if( $window.width() < 992 && flag == false ) {
 | 
						|
								headerBodyHeight = $('.header-body').outerHeight();
 | 
						|
								flag = true;
 | 
						|
 | 
						|
								setTimeout(function(){
 | 
						|
									flag = false;
 | 
						|
								}, 500);
 | 
						|
							}
 | 
						|
						});
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				// Side Header - Set header height on mobile
 | 
						|
				if( $html.hasClass('side-header') ) {
 | 
						|
					if( $window.width() < 992 ) {
 | 
						|
						$header.css({
 | 
						|
							height: $('.header-body .header-container').outerHeight() + (parseInt( $('.header-body').css('border-top-width') ) + parseInt( $('.header-body').css('border-bottom-width') ))
 | 
						|
						});
 | 
						|
					}
 | 
						|
 | 
						|
					$(document).ready(function(){
 | 
						|
						$window.afterResize(function(){
 | 
						|
							if( $window.width() < 992 ) {
 | 
						|
								$header.css({
 | 
						|
									height: $('.header-body .header-container').outerHeight() + (parseInt( $('.header-body').css('border-top-width') ) + parseInt( $('.header-body').css('border-bottom-width') ))
 | 
						|
								});
 | 
						|
							} else {
 | 
						|
								$header.css({
 | 
						|
									height: ''
 | 
						|
								});
 | 
						|
							}
 | 
						|
						});
 | 
						|
					});
 | 
						|
				}
 | 
						|
 | 
						|
				// Anchors Position
 | 
						|
				if( $('[data-hash]').length ) {
 | 
						|
					$('[data-hash]').on('mouseover', function(){
 | 
						|
						var $this = $(this);
 | 
						|
 | 
						|
						if( !$this.data('__dataHashBinded') ) {
 | 
						|
							var target = $this.attr('href'),
 | 
						|
								offset = ($this.is("[data-hash-offset]") ? $this.data('hash-offset') : 0),
 | 
						|
								delay  = ($this.is("[data-hash-delay]") ? $this.data('hash-delay') : 0),
 | 
						|
								force  = ($this.is("[data-hash-force]") ? true : false),
 | 
						|
								windowWidth = $(window).width();
 | 
						|
 | 
						|
							// Hash Offset SM
 | 
						|
							if ($this.is("[data-hash-offset-sm]") && windowWidth > 576) {
 | 
						|
								offset = $this.data('hash-offset-sm');
 | 
						|
							}
 | 
						|
							
 | 
						|
							// Hash Offset MD
 | 
						|
							if ($this.is("[data-hash-offset-md]") && windowWidth > 768) {
 | 
						|
								offset = $this.data('hash-offset-md');
 | 
						|
							}
 | 
						|
							
 | 
						|
							// Hash Offset LG
 | 
						|
							if ($this.is("[data-hash-offset-lg]") && windowWidth > 992) {
 | 
						|
								offset = $this.data('hash-offset-lg');
 | 
						|
							}
 | 
						|
							
 | 
						|
							// Hash Offset XL
 | 
						|
							if ($this.is("[data-hash-offset-xl]") && windowWidth > 1200) {
 | 
						|
								offset = $this.data('hash-offset-xl');
 | 
						|
							}
 | 
						|
							
 | 
						|
							// Hash Offset XXL
 | 
						|
							if ($this.is("[data-hash-offset-xxl]") && windowWidth > 1400) {
 | 
						|
								offset = $this.data('hash-offset-xxl');
 | 
						|
							}
 | 
						|
 | 
						|
							if( !$(target).length ) {
 | 
						|
								target = target.split('#');
 | 
						|
								target = '#'+target[1];
 | 
						|
							}
 | 
						|
 | 
						|
							if( target.indexOf('#') != -1 && $(target).length) {
 | 
						|
								$this.on('click', function(e) {
 | 
						|
									e.preventDefault();
 | 
						|
 | 
						|
									if( !$(e.target).is('i') || force ) {
 | 
						|
 | 
						|
										setTimeout(function(){
 | 
						|
 | 
						|
											// Close Collapse if open
 | 
						|
											$this.parents('.collapse.show').collapse('hide');
 | 
						|
 | 
						|
											// Close Side Header
 | 
						|
											$hamburguerSideHeader.addClass('side-header-hide');
 | 
						|
											$html.addClass('side-header-hide');
 | 
						|
											
 | 
						|
											$window.trigger('resize');
 | 
						|
 | 
						|
											self.scrollToTarget(target, offset);
 | 
						|
 | 
						|
											// Data Hash Trigger Click
 | 
						|
											if( $this.data('hash-trigger-click') ) {
 | 
						|
 | 
						|
												var $clickTarget = $( $this.data('hash-trigger-click') ),
 | 
						|
													clickDelay = $this.data('hash-trigger-click-delay') ? $this.data('hash-trigger-click-delay') : 0;
 | 
						|
 | 
						|
												if( $clickTarget.length ) {
 | 
						|
 | 
						|
													setTimeout(function(){
 | 
						|
														// If is a "Tabs" plugin link
 | 
						|
														if( $clickTarget.closest('.nav-tabs').length ) {
 | 
						|
															new bootstrap.Tab( $clickTarget[0] ).show();
 | 
						|
														} else {
 | 
						|
															$clickTarget.trigger('click');
 | 
						|
														}
 | 
						|
														
 | 
						|
													}, clickDelay);
 | 
						|
												}
 | 
						|
 | 
						|
											}
 | 
						|
 | 
						|
										}, delay);
 | 
						|
										
 | 
						|
									}
 | 
						|
 | 
						|
									return;
 | 
						|
								});
 | 
						|
							}
 | 
						|
 | 
						|
							$(this).data('__dataHashBinded', true);
 | 
						|
						}
 | 
						|
					});
 | 
						|
				}
 | 
						|
 | 
						|
				// Floating
 | 
						|
				if($('#header.header-floating-icons').length) {
 | 
						|
 | 
						|
					$('#header.header-floating-icons [data-hash]').off().each(function() {
 | 
						|
 | 
						|
						var target = $(this).attr('href'),
 | 
						|
							offset = ($(this).is("[data-hash-offset]") ? $(this).data('hash-offset') : 0);
 | 
						|
 | 
						|
						if($(target).length) {
 | 
						|
							$(this).on('click', function(e) {
 | 
						|
								e.preventDefault();
 | 
						|
 | 
						|
									$('html, body').animate({
 | 
						|
										scrollTop: $(target).offset().top - offset
 | 
						|
									}, 600, 'easeOutQuad', function() {
 | 
						|
 | 
						|
									});
 | 
						|
 | 
						|
								return;
 | 
						|
							});
 | 
						|
						}
 | 
						|
 | 
						|
					});
 | 
						|
 | 
						|
				}
 | 
						|
 | 
						|
				// Side Panel Toggle
 | 
						|
				if( $('.side-panel-toggle').length ) {
 | 
						|
					var init_html_class = $('html').attr('class');
 | 
						|
 | 
						|
					$('.side-panel-toggle').on('click', function(e){
 | 
						|
						var extra_class = $(this).data('extra-class'),
 | 
						|
							delay       = ( extra_class ) ? 100 : 0,
 | 
						|
							isActive    = $(this).data('is-active') ? $(this).data('is-active') : false;
 | 
						|
 | 
						|
						e.preventDefault();
 | 
						|
 | 
						|
						if( isActive ) {
 | 
						|
							$('html').removeClass('side-panel-open');
 | 
						|
							$(this).data('is-active', false);
 | 
						|
							return false;
 | 
						|
						}
 | 
						|
 | 
						|
						if( extra_class ) {
 | 
						|
							$('.side-panel-wrapper').css('transition','none');
 | 
						|
							$('html')
 | 
						|
								.removeClass()
 | 
						|
								.addClass( init_html_class )
 | 
						|
								.addClass( extra_class );
 | 
						|
						}
 | 
						|
						setTimeout(function(){
 | 
						|
							$('.side-panel-wrapper').css('transition','');
 | 
						|
							$('html').toggleClass('side-panel-open');
 | 
						|
						}, delay);
 | 
						|
 | 
						|
						$(this).data('is-active', true);						
 | 
						|
					});
 | 
						|
 | 
						|
					$(document).on('click', function(e){
 | 
						|
						if( !$(e.target).closest('.side-panel-wrapper').length && !$(e.target).hasClass('side-panel-toggle') ) {
 | 
						|
							$('.hamburguer-btn.side-panel-toggle:not(.side-panel-close)').removeClass('active');
 | 
						|
							$('html').removeClass('side-panel-open');
 | 
						|
							$('.side-panel-toggle').data('is-active', false);
 | 
						|
						}
 | 
						|
					});
 | 
						|
				}
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			scrollToTarget: function(target, offset) {
 | 
						|
				var self = this,
 | 
						|
					targetPosition = $(target).offset().top;
 | 
						|
 | 
						|
				$('body').addClass('scrolling');
 | 
						|
 | 
						|
				$('html, body').animate({
 | 
						|
					scrollTop: $(target).offset().top - offset
 | 
						|
				}, self.options.scrollDelay, self.options.scrollAnimation, function() {
 | 
						|
					$('body').removeClass('scrolling');
 | 
						|
 | 
						|
					// If by some reason the scroll finishes in a wrong position, this code will run the scrollToTarget() again until get the correct position
 | 
						|
					// We need do it just one time to prevent infinite recursive loop at scrollToTarget() function
 | 
						|
					if( $(target).offset().top !=  targetPosition) {
 | 
						|
						$('html, body').animate({
 | 
						|
							scrollTop: $(target).offset().top - offset
 | 
						|
						}, 1, self.options.scrollAnimation, function() {});
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				return this;
 | 
						|
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
	});
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
 | 
						|
// Newsletter
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var initialized = false;
 | 
						|
 | 
						|
	$.extend(theme, {
 | 
						|
 | 
						|
		Newsletter: {
 | 
						|
 | 
						|
			defaults: {
 | 
						|
				wrapper: $('#newsletterForm')
 | 
						|
			},
 | 
						|
 | 
						|
			initialize: function($wrapper, opts) {
 | 
						|
				if (initialized) {
 | 
						|
					return this;
 | 
						|
				}
 | 
						|
 | 
						|
				initialized = true;
 | 
						|
				this.$wrapper = ($wrapper || this.defaults.wrapper);
 | 
						|
 | 
						|
				this
 | 
						|
					.setOptions(opts)
 | 
						|
					.build();
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			setOptions: function(opts) {
 | 
						|
				this.options = $.extend(true, {}, this.defaults, opts, theme.fn.getOptions(this.$wrapper.data('plugin-options')));
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			build: function() {
 | 
						|
				if (!($.isFunction($.fn.validate))) {
 | 
						|
					return this;
 | 
						|
				}
 | 
						|
 | 
						|
				var self = this,
 | 
						|
					$email = self.$wrapper.find('#newsletterEmail'),
 | 
						|
					$success = $('#newsletterSuccess'),
 | 
						|
					$error = $('#newsletterError');
 | 
						|
 | 
						|
				self.$wrapper.validate({
 | 
						|
					submitHandler: function(form) {
 | 
						|
 | 
						|
						$.ajax({
 | 
						|
							type: 'POST',
 | 
						|
							url: self.$wrapper.attr('action'),
 | 
						|
							data: {
 | 
						|
								'email': $email.val()
 | 
						|
							},
 | 
						|
							dataType: 'json',
 | 
						|
							success: function(data) {
 | 
						|
								if (data.response == 'success') {
 | 
						|
 | 
						|
									$success.removeClass('d-none');
 | 
						|
									$error.addClass('d-none');
 | 
						|
 | 
						|
									$email
 | 
						|
										.val('')
 | 
						|
										.blur()
 | 
						|
										.closest('.control-group')
 | 
						|
										.removeClass('success')
 | 
						|
										.removeClass('error');
 | 
						|
 | 
						|
								} else {
 | 
						|
 | 
						|
									$error.html(data.message);
 | 
						|
									$error.removeClass('d-none');
 | 
						|
									$success.addClass('d-none');
 | 
						|
 | 
						|
									$email
 | 
						|
										.blur()
 | 
						|
										.closest('.control-group')
 | 
						|
										.removeClass('success')
 | 
						|
										.addClass('error');
 | 
						|
 | 
						|
								}
 | 
						|
							}
 | 
						|
						});
 | 
						|
 | 
						|
					},
 | 
						|
					rules: {
 | 
						|
						newsletterEmail: {
 | 
						|
							required: true,
 | 
						|
							email: true
 | 
						|
						}
 | 
						|
					},
 | 
						|
					errorPlacement: function(error, element) {
 | 
						|
 | 
						|
					}
 | 
						|
				});
 | 
						|
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
	});
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Search
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var initialized = false;
 | 
						|
 | 
						|
	$.extend(theme, {
 | 
						|
 | 
						|
		Search: {
 | 
						|
 | 
						|
			defaults: {
 | 
						|
				wrapper: $('#searchForm')
 | 
						|
			},
 | 
						|
 | 
						|
			initialize: function($wrapper, opts) {
 | 
						|
				if (initialized) {
 | 
						|
					return this;
 | 
						|
				}
 | 
						|
 | 
						|
				initialized = true;
 | 
						|
				this.$wrapper = ($wrapper || this.defaults.wrapper);
 | 
						|
 | 
						|
				this
 | 
						|
					.setOptions(opts)
 | 
						|
					.build();
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			setOptions: function(opts) {
 | 
						|
				this.options = $.extend(true, {}, this.defaults, opts, theme.fn.getOptions(this.$wrapper.data('plugin-options')));
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			build: function() {
 | 
						|
				if (!($.isFunction($.fn.validate))) {
 | 
						|
					return this;
 | 
						|
				}
 | 
						|
 | 
						|
				this.$wrapper.validate({
 | 
						|
					errorPlacement: function(error, element) {}
 | 
						|
				});
 | 
						|
 | 
						|
				// Search Reveal
 | 
						|
				theme.fn.execOnceTroughEvent( '#header', 'mouseover.search.reveal', function(){
 | 
						|
					$('.header-nav-features-search-reveal').each(function() {
 | 
						|
						var $el = $(this),
 | 
						|
							$header = $('#header'),
 | 
						|
							$html = $('html');
 | 
						|
 | 
						|
						$el.find('.header-nav-features-search-show-icon').on('click', function() {
 | 
						|
							$el.addClass('show');
 | 
						|
							$header.addClass('search-show');
 | 
						|
							$html.addClass('search-show');
 | 
						|
							$('#headerSearch').focus();
 | 
						|
						});
 | 
						|
 | 
						|
						$el.find('.header-nav-features-search-hide-icon').on('click', function() {
 | 
						|
							$el.removeClass('show');
 | 
						|
							$header.removeClass('search-show');
 | 
						|
							$html.removeClass('search-show');
 | 
						|
						});
 | 
						|
					});
 | 
						|
				} );
 | 
						|
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
	});
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]);
 | 
						|
 | 
						|
// Sticky Header
 | 
						|
(function(theme, $) {
 | 
						|
 | 
						|
	theme = theme || {};
 | 
						|
 | 
						|
	var initialized = false;
 | 
						|
 | 
						|
	$.extend(theme, {
 | 
						|
 | 
						|
		StickyHeader: {
 | 
						|
 | 
						|
			defaults: {
 | 
						|
				wrapper: $('#header'),
 | 
						|
				headerBody: $('#header .header-body'),
 | 
						|
				stickyEnabled: true,
 | 
						|
				stickyEnableOnBoxed: true,
 | 
						|
				stickyEnableOnMobile: false,
 | 
						|
				stickyStartAt: 0,
 | 
						|
				stickyStartAtElement: false,
 | 
						|
				stickySetTop: 0,
 | 
						|
				stickyEffect: '',
 | 
						|
				stickyHeaderContainerHeight: false,
 | 
						|
				stickyChangeLogo: false,
 | 
						|
				stickyChangeLogoWrapper: true,
 | 
						|
				stickyForce: false,
 | 
						|
				stickyScrollUp: false,
 | 
						|
				stickyScrollValue: 0
 | 
						|
			},
 | 
						|
 | 
						|
			initialize: function($wrapper, opts) {
 | 
						|
				if (initialized) {
 | 
						|
					return this;
 | 
						|
				}				
 | 
						|
 | 
						|
				initialized = true;
 | 
						|
				this.$wrapper = ($wrapper || this.defaults.wrapper);
 | 
						|
 | 
						|
				if( this.$wrapper.hasClass('header') ) {
 | 
						|
					this.$wrapper = $('.header[data-plugin-options]');
 | 
						|
				}
 | 
						|
 | 
						|
				this
 | 
						|
					.setOptions(opts)
 | 
						|
					.build()
 | 
						|
					.events();
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			setOptions: function(opts) {
 | 
						|
				this.options = $.extend(true, {}, this.defaults, opts, theme.fn.getOptions(this.$wrapper.data('plugin-options')));
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			build: function() {
 | 
						|
				if( $(window).width() < 992 && this.options.stickyEnableOnMobile == false ) {
 | 
						|
					$('html').addClass('sticky-header-mobile-disabled');
 | 
						|
					return this;
 | 
						|
				}
 | 
						|
 | 
						|
				if (!this.options.stickyEnableOnBoxed && $('html').hasClass('boxed') || $('html').hasClass('side-header-hamburguer-sidebar') && !this.options.stickyForce || !this.options.stickyEnabled) {
 | 
						|
					return this;
 | 
						|
				}
 | 
						|
 | 
						|
				var self = this;
 | 
						|
 | 
						|
				if( self.options.wrapper.hasClass('header') ) {
 | 
						|
					self.options.wrapper = $('.header');
 | 
						|
					self.options.headerBody = $('.header .header-body');
 | 
						|
				}
 | 
						|
				
 | 
						|
				var	$html = $('html'),
 | 
						|
					$window = $(window),
 | 
						|
					sideHeader = $html.hasClass('side-header'),
 | 
						|
					initialHeaderTopHeight = self.options.wrapper.find('.header-top').outerHeight(),
 | 
						|
					initialHeaderContainerHeight = self.options.wrapper.find('.header-container').outerHeight(),
 | 
						|
					minHeight;
 | 
						|
 | 
						|
				// HTML Classes
 | 
						|
				$html.addClass('sticky-header-enabled');
 | 
						|
 | 
						|
				if (parseInt(self.options.stickySetTop) < 0) {
 | 
						|
					$html.addClass('sticky-header-negative');
 | 
						|
				}
 | 
						|
 | 
						|
				if (self.options.stickyScrollUp) {
 | 
						|
					$html.addClass('sticky-header-scroll-direction');
 | 
						|
				}				
 | 
						|
 | 
						|
				// Notice Top Bar First Load
 | 
						|
				if( $('.notice-top-bar').get(0) ) {
 | 
						|
					if (parseInt(self.options.stickySetTop) == 1 || self.options.stickyEffect == 'shrink') {
 | 
						|
						$('.body').on('transitionend webkitTransitionEnd oTransitionEnd', function () {
 | 
						|
						    setTimeout(function(){
 | 
						|
								if( !$html.hasClass('sticky-header-active') ) {
 | 
						|
								    self.options.headerBody.animate({
 | 
						|
								    	top: $('.notice-top-bar').outerHeight()
 | 
						|
								    }, 300, function(){
 | 
						|
								    	if( $html.hasClass('sticky-header-active') ) {
 | 
						|
								    		self.options.headerBody.css('top', 0);
 | 
						|
								    	}
 | 
						|
								    });
 | 
						|
								}
 | 
						|
						    }, 0);
 | 
						|
						});
 | 
						|
					}					
 | 
						|
				}
 | 
						|
 | 
						|
				// Set Start At
 | 
						|
				if(self.options.stickyStartAtElement) {
 | 
						|
 | 
						|
					var $stickyStartAtElement = $(self.options.stickyStartAtElement);
 | 
						|
 | 
						|
					$(window).on('scroll resize sticky.header.resize', function() {
 | 
						|
						self.options.stickyStartAt = $stickyStartAtElement.offset().top;
 | 
						|
					});
 | 
						|
 | 
						|
					$(window).trigger('sticky.header.resize');
 | 
						|
				}
 | 
						|
 | 
						|
				// Define Min Height value
 | 
						|
				if( self.options.wrapper.find('.header-top').get(0) ) {
 | 
						|
					minHeight = ( initialHeaderTopHeight + initialHeaderContainerHeight );
 | 
						|
				} else {
 | 
						|
					minHeight = initialHeaderContainerHeight;
 | 
						|
				}
 | 
						|
 | 
						|
				// Set Wrapper Min-Height
 | 
						|
				if( !sideHeader ) {
 | 
						|
					if( !$('.header-logo-sticky-change').get(0) ) {
 | 
						|
						self.options.wrapper.css('height', self.options.headerBody.outerHeight());
 | 
						|
					} else {
 | 
						|
						$window.on('stickyChangeLogo.loaded', function(){
 | 
						|
							self.options.wrapper.css('height', self.options.headerBody.outerHeight());
 | 
						|
						});
 | 
						|
					}
 | 
						|
 | 
						|
					if( self.options.stickyEffect == 'shrink' ) {
 | 
						|
						
 | 
						|
						// Prevent wrong visualization of header when reload on middle of page
 | 
						|
						$(document).ready(function(){
 | 
						|
							if( $window.scrollTop() >= self.options.stickyStartAt ) {
 | 
						|
								self.options.wrapper.find('.header-container').on('transitionend webkitTransitionEnd oTransitionEnd', function(){
 | 
						|
									self.options.headerBody.css('position', 'fixed');
 | 
						|
								});
 | 
						|
							} else {
 | 
						|
								if( !$html.hasClass('boxed') ) {
 | 
						|
									self.options.headerBody.css('position', 'fixed');
 | 
						|
								}
 | 
						|
							}
 | 
						|
						});
 | 
						|
 | 
						|
						self.options.wrapper.find('.header-container').css('height', initialHeaderContainerHeight);
 | 
						|
						self.options.wrapper.find('.header-top').css('height', initialHeaderTopHeight);
 | 
						|
					}
 | 
						|
				}
 | 
						|
 | 
						|
				// Sticky Header Container Height
 | 
						|
				if( self.options.stickyHeaderContainerHeight ) {
 | 
						|
					self.options.wrapper.find('.header-container').css('height', self.options.wrapper.find('.header-container').outerHeight());
 | 
						|
				}
 | 
						|
 | 
						|
				// Boxed
 | 
						|
				if($html.hasClass('boxed') && self.options.stickyEffect == 'shrink') {
 | 
						|
					self.boxedLayout();
 | 
						|
				}
 | 
						|
 | 
						|
				// Check Sticky Header / Flags prevent multiple runs at same time
 | 
						|
				var activate_flag   	 = true,
 | 
						|
					deactivate_flag 	 = false,
 | 
						|
					initialStickyStartAt = self.options.stickyStartAt;
 | 
						|
 | 
						|
				self.checkStickyHeader = function() {
 | 
						|
 | 
						|
					// Notice Top Bar
 | 
						|
					var $noticeTopBar = $('.notice-top-bar');
 | 
						|
					if ( $noticeTopBar.get(0) ) {
 | 
						|
						self.options.stickyStartAt = ( $noticeTopBar.data('sticky-start-at') ) ? $noticeTopBar.data('sticky-start-at') : $('.notice-top-bar').outerHeight();
 | 
						|
					} else {
 | 
						|
						if( $html.hasClass('boxed') ) {
 | 
						|
							self.options.stickyStartAt = initialStickyStartAt + 25;
 | 
						|
						} else {
 | 
						|
							self.options.stickyStartAt = initialStickyStartAt;
 | 
						|
						}
 | 
						|
					}
 | 
						|
 | 
						|
					if( $window.width() > 991 && $html.hasClass('side-header') ) {
 | 
						|
						$html.removeClass('sticky-header-active');
 | 
						|
						activate_flag = true;
 | 
						|
						return;
 | 
						|
					}
 | 
						|
 | 
						|
					if ($window.scrollTop() >= parseInt(self.options.stickyStartAt)) {
 | 
						|
						if( activate_flag ) {
 | 
						|
							self.activateStickyHeader();
 | 
						|
							activate_flag = false;
 | 
						|
							deactivate_flag = true;
 | 
						|
						}
 | 
						|
					} else {
 | 
						|
						if( deactivate_flag ) {
 | 
						|
							self.deactivateStickyHeader();
 | 
						|
							deactivate_flag = false;
 | 
						|
							activate_flag = true;
 | 
						|
						}
 | 
						|
					}
 | 
						|
 | 
						|
					// Scroll Up
 | 
						|
					if (self.options.stickyScrollUp) {
 | 
						|
						
 | 
						|
					    // Get the new Value
 | 
						|
					    self.options.stickyScrollNewValue = window.pageYOffset;
 | 
						|
 | 
						|
					    //Subtract the two and conclude
 | 
						|
					    if(self.options.stickyScrollValue - self.options.stickyScrollNewValue < 0){
 | 
						|
					        $html.removeClass('sticky-header-scroll-up').addClass('sticky-header-scroll-down');
 | 
						|
					    } else if(self.options.stickyScrollValue - self.options.stickyScrollNewValue > 0){
 | 
						|
					        $html.removeClass('sticky-header-scroll-down').addClass('sticky-header-scroll-up');
 | 
						|
					    }
 | 
						|
 | 
						|
					    // Update the old value
 | 
						|
					    self.options.stickyScrollValue = self.options.stickyScrollNewValue;
 | 
						|
 | 
						|
					}
 | 
						|
				};
 | 
						|
				
 | 
						|
				// Activate Sticky Header
 | 
						|
				self.activateStickyHeader = function() {
 | 
						|
					if ($window.width() < 992) {
 | 
						|
						if (self.options.stickyEnableOnMobile == false) {
 | 
						|
							self.deactivateStickyHeader();
 | 
						|
							self.options.headerBody.css({
 | 
						|
								position: 'relative'
 | 
						|
							});
 | 
						|
							return false;
 | 
						|
						}
 | 
						|
					} else {
 | 
						|
						if (sideHeader) {
 | 
						|
							self.deactivateStickyHeader();
 | 
						|
							return;
 | 
						|
						}
 | 
						|
					}
 | 
						|
 | 
						|
					$html.addClass('sticky-header-active');
 | 
						|
 | 
						|
					// Sticky Effect - Reveal
 | 
						|
					if( self.options.stickyEffect == 'reveal' ) {
 | 
						|
 | 
						|
						self.options.headerBody.css('top','-' + self.options.stickyStartAt + 'px');
 | 
						|
 | 
						|
						self.options.headerBody.animate({
 | 
						|
							top: self.options.stickySetTop
 | 
						|
						}, 400, function() {});
 | 
						|
 | 
						|
					}
 | 
						|
 | 
						|
					// Sticky Effect - Shrink
 | 
						|
					if( self.options.stickyEffect == 'shrink' ) {
 | 
						|
 | 
						|
						// If Header Top
 | 
						|
						if( self.options.wrapper.find('.header-top').get(0) ) {
 | 
						|
							self.options.wrapper.find('.header-top').css({
 | 
						|
								height: 0,
 | 
						|
								'min-height': 0,
 | 
						|
								overflow: 'hidden'
 | 
						|
							});
 | 
						|
						}
 | 
						|
 | 
						|
						// Header Container
 | 
						|
						if( self.options.stickyHeaderContainerHeight ) {
 | 
						|
							self.options.wrapper.find('.header-container').css({
 | 
						|
								height: self.options.stickyHeaderContainerHeight,
 | 
						|
								'min-height': 0
 | 
						|
							});
 | 
						|
						} else {
 | 
						|
							self.options.wrapper.find('.header-container').css({
 | 
						|
								height: (initialHeaderContainerHeight / 3) * 2, // two third of container height
 | 
						|
								'min-height': 0
 | 
						|
							});
 | 
						|
 | 
						|
							var y = initialHeaderContainerHeight - ((initialHeaderContainerHeight / 3) * 2);
 | 
						|
							$('.main').css({
 | 
						|
								transform: 'translate3d(0, -'+ y +'px, 0)',
 | 
						|
								transition: 'ease transform 300ms'
 | 
						|
							}).addClass('has-sticky-header-transform');
 | 
						|
 | 
						|
							if($html.hasClass('boxed')) {
 | 
						|
								self.options.headerBody.css('position','fixed');
 | 
						|
							}
 | 
						|
						}
 | 
						|
 | 
						|
					}
 | 
						|
 | 
						|
					self.options.headerBody.css('top', self.options.stickySetTop);
 | 
						|
 | 
						|
					if (self.options.stickyChangeLogo) {
 | 
						|
						self.changeLogo(true);
 | 
						|
					}
 | 
						|
 | 
						|
					// Set Elements Style
 | 
						|
					if( $('[data-sticky-header-style]').length ) {
 | 
						|
						$('[data-sticky-header-style]').each(function() {
 | 
						|
							var $el = $(this),
 | 
						|
								css = theme.fn.getOptions($el.data('sticky-header-style-active')),
 | 
						|
								opts = theme.fn.getOptions($el.data('sticky-header-style'));
 | 
						|
 | 
						|
							if( $window.width() > opts.minResolution ) {
 | 
						|
								$el.css(css);
 | 
						|
							}
 | 
						|
						});
 | 
						|
					}
 | 
						|
 | 
						|
					$.event.trigger({
 | 
						|
						type: 'stickyHeader.activate'
 | 
						|
					});
 | 
						|
				};
 | 
						|
 | 
						|
				// Deactivate Sticky Header
 | 
						|
				self.deactivateStickyHeader = function() {
 | 
						|
					$html.removeClass('sticky-header-active');
 | 
						|
 | 
						|
					if ( $(window).width() < 992 && self.options.stickyEnableOnMobile == false) {
 | 
						|
						return false;
 | 
						|
					}
 | 
						|
 | 
						|
					// Sticky Effect - Shrink
 | 
						|
					if( self.options.stickyEffect == 'shrink' ) {
 | 
						|
 | 
						|
						// Boxed Layout
 | 
						|
						if( $html.hasClass('boxed') ) {
 | 
						|
 | 
						|
							// Set Header Body Position Absolute
 | 
						|
							self.options.headerBody.css('position','absolute');
 | 
						|
 | 
						|
							if( $window.scrollTop() > $('.body').offset().top ) {
 | 
						|
								// Set Header Body Position Fixed
 | 
						|
								self.options.headerBody.css('position','fixed');								
 | 
						|
							}
 | 
						|
 | 
						|
						} else {
 | 
						|
							// Set Header Body Position Fixed
 | 
						|
							self.options.headerBody.css('position','fixed');
 | 
						|
						}
 | 
						|
 | 
						|
						// If Header Top
 | 
						|
						if( self.options.wrapper.find('.header-top').get(0) ) {
 | 
						|
							self.options.wrapper.find('.header-top').css({
 | 
						|
								height: initialHeaderTopHeight,
 | 
						|
								overflow: 'visible'
 | 
						|
							});
 | 
						|
 | 
						|
							// Fix [data-icon] issue when first load is on middle of the page
 | 
						|
							if( self.options.wrapper.find('.header-top [data-icon]').length ) {
 | 
						|
								theme.fn.intObsInit( '.header-top [data-icon]:not(.svg-inline--fa)', 'themePluginIcon' );
 | 
						|
							}
 | 
						|
						}
 | 
						|
 | 
						|
						// Header Container
 | 
						|
						self.options.wrapper.find('.header-container').css({
 | 
						|
							height: initialHeaderContainerHeight
 | 
						|
						});
 | 
						|
 | 
						|
					}
 | 
						|
 | 
						|
					self.options.headerBody.css('top', 0);
 | 
						|
 | 
						|
					if (self.options.stickyChangeLogo) {
 | 
						|
						self.changeLogo(false);
 | 
						|
					}
 | 
						|
 | 
						|
					// Set Elements Style
 | 
						|
					if( $('[data-sticky-header-style]').length ) {
 | 
						|
						$('[data-sticky-header-style]').each(function() {
 | 
						|
							var $el = $(this),
 | 
						|
								css = theme.fn.getOptions($el.data('sticky-header-style-deactive')),
 | 
						|
								opts = theme.fn.getOptions($el.data('sticky-header-style'));
 | 
						|
 | 
						|
							if( $window.width() > opts.minResolution ) {
 | 
						|
								$el.css(css);
 | 
						|
							}
 | 
						|
						});
 | 
						|
					}
 | 
						|
 | 
						|
					$.event.trigger({
 | 
						|
						type: 'stickyHeader.deactivate'
 | 
						|
					});
 | 
						|
				};
 | 
						|
 | 
						|
				// Always Sticky
 | 
						|
				if (parseInt(self.options.stickyStartAt) <= 0) {
 | 
						|
					self.activateStickyHeader();
 | 
						|
				}
 | 
						|
 | 
						|
				// Set Logo
 | 
						|
				if (self.options.stickyChangeLogo) {
 | 
						|
 | 
						|
					var $logoWrapper = self.options.wrapper.find('.header-logo'),
 | 
						|
						$logo = $logoWrapper.find('img'),
 | 
						|
						logoWidth = $logo.attr('width'),
 | 
						|
						logoHeight = $logo.attr('height'),
 | 
						|
						logoSmallTop = parseInt($logo.attr('data-sticky-top') ? $logo.attr('data-sticky-top') : 0),
 | 
						|
						logoSmallWidth = parseInt($logo.attr('data-sticky-width') ? $logo.attr('data-sticky-width') : 'auto'),
 | 
						|
						logoSmallHeight = parseInt($logo.attr('data-sticky-height') ? $logo.attr('data-sticky-height') : 'auto');
 | 
						|
 | 
						|
					if (self.options.stickyChangeLogoWrapper) {
 | 
						|
						$logoWrapper.css({
 | 
						|
							'width': $logo.outerWidth(true),
 | 
						|
							'height': $logo.outerHeight(true)
 | 
						|
						});
 | 
						|
					}
 | 
						|
 | 
						|
					self.changeLogo = function(activate) {
 | 
						|
						if(activate) {
 | 
						|
							
 | 
						|
							$logo.css({
 | 
						|
								'top': logoSmallTop,
 | 
						|
								'width': logoSmallWidth,
 | 
						|
								'height': logoSmallHeight
 | 
						|
							});
 | 
						|
 | 
						|
						} else {
 | 
						|
							
 | 
						|
							$logo.css({
 | 
						|
								'top': 0,
 | 
						|
								'width': logoWidth,
 | 
						|
								'height': logoHeight
 | 
						|
							});
 | 
						|
 | 
						|
						}
 | 
						|
					}
 | 
						|
 | 
						|
					$.event.trigger({
 | 
						|
						type: 'stickyChangeLogo.loaded'
 | 
						|
					});
 | 
						|
 | 
						|
				}
 | 
						|
 | 
						|
				// Side Header
 | 
						|
				var headerBodyHeight,
 | 
						|
					flag = false;
 | 
						|
 | 
						|
				self.checkSideHeader = function() {
 | 
						|
					if($window.width() < 992 && flag == false) {
 | 
						|
						headerBodyHeight = self.options.headerBody.height();
 | 
						|
						flag = true;
 | 
						|
					}
 | 
						|
 | 
						|
					if(self.options.stickyStartAt == 0 && sideHeader) {
 | 
						|
						self.options.wrapper.css('min-height', 0);
 | 
						|
					}
 | 
						|
 | 
						|
					if(self.options.stickyStartAt > 0 && sideHeader && $window.width() < 992) {
 | 
						|
						self.options.wrapper.css('min-height', headerBodyHeight);
 | 
						|
					}
 | 
						|
				}
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			events: function() {
 | 
						|
				var self = this;
 | 
						|
 | 
						|
				if( $(window).width() < 992 && this.options.stickyEnableOnMobile == false ) {
 | 
						|
					return this;
 | 
						|
				}
 | 
						|
 | 
						|
				if (!this.options.stickyEnableOnBoxed && $('body').hasClass('boxed') || $('html').hasClass('side-header-hamburguer-sidebar') && !this.options.stickyForce || !this.options.stickyEnabled) {
 | 
						|
					return this;
 | 
						|
				}
 | 
						|
 | 
						|
				if (!self.options.alwaysStickyEnabled) {
 | 
						|
					$(window).on('scroll resize', function() {
 | 
						|
						if ( $(window).width() < 992 && self.options.stickyEnableOnMobile == false) {
 | 
						|
							self.options.headerBody.css({
 | 
						|
								position: ''
 | 
						|
							});
 | 
						|
 | 
						|
							if( self.options.stickyEffect == 'shrink' ) {
 | 
						|
								self.options.wrapper.find('.header-top').css({
 | 
						|
									height: ''
 | 
						|
								});
 | 
						|
							}
 | 
						|
 | 
						|
							self.deactivateStickyHeader();
 | 
						|
						} else {
 | 
						|
							self.checkStickyHeader();
 | 
						|
						}
 | 
						|
					});
 | 
						|
				} else {
 | 
						|
					self.activateStickyHeader();
 | 
						|
				}
 | 
						|
 | 
						|
				$(window).on('load resize', function(){
 | 
						|
					self.checkSideHeader();
 | 
						|
				});
 | 
						|
 | 
						|
				$(window).on('layout.boxed', function(){
 | 
						|
					self.boxedLayout();
 | 
						|
				});
 | 
						|
 | 
						|
				return this;
 | 
						|
			},
 | 
						|
 | 
						|
			boxedLayout: function(){
 | 
						|
				var self = this,
 | 
						|
					$window = $(window);
 | 
						|
 | 
						|
				if($('html').hasClass('boxed') && self.options.stickyEffect == 'shrink') {
 | 
						|
					if( (parseInt(self.options.stickyStartAt) == 0) && $window.width() > 991) {
 | 
						|
						self.options.stickyStartAt = 30;
 | 
						|
					}
 | 
						|
 | 
						|
					// Set Header Body Position Absolute
 | 
						|
					self.options.headerBody.css({
 | 
						|
						position: 'absolute',
 | 
						|
						top: 0
 | 
						|
					});
 | 
						|
 | 
						|
					// Set position absolute because top margin from boxed layout
 | 
						|
					$window.on('scroll', function(){
 | 
						|
						if( $window.scrollTop() > $('.body').offset().top ) {
 | 
						|
							self.options.headerBody.css({
 | 
						|
								'position' : 'fixed',
 | 
						|
								'top' : 0
 | 
						|
							});								
 | 
						|
						} else {
 | 
						|
							self.options.headerBody.css({
 | 
						|
								'position' : 'absolute',
 | 
						|
								'top' : 0
 | 
						|
							});
 | 
						|
						}
 | 
						|
					});
 | 
						|
				}
 | 
						|
 | 
						|
				return this;
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
	});
 | 
						|
 | 
						|
}).apply(this, [window.theme, jQuery]); |