HEX
Server: Apache/2.4.54 (Unix) OpenSSL/1.0.2k-fips
System: Linux f17.eelserver.com 3.10.0-1160.80.1.el7.x86_64 #1 SMP Tue Nov 8 15:48:59 UTC 2022 x86_64
User: zulfiqar (1155)
PHP: 8.2.0
Disabled: mail, exec, system, popen, proc_open, shell_exec, passthru, show_source
Upload Files
File: /home/zulfiqar/public_html/wp-content/plugins/gallery-videos/public/js/jquery.fs.boxer.js
; (function ($, window) {
	if (/Android|webOS|iPhone|iPad|iPod|BlackBerry|BB|PlayBook|IEMobile|Windows Phone|Kindle|Silk|Opera Mini/i.test(navigator.userAgent)) {
		gadget = true;
	} else {
		gadget = false;
	}
	"use strict";
	var $body = null,
		data = {},
		trueMobile = /webOS/i.test((window.navigator.userAgent || window.navigator.vendor || window.opera)),
		transitionEvent,
		displayResolution = $(window).width(),
		transitionSupported;
	var options = {
		callback: $.noop,
		customClass: "",
		extensions: ["jpg", "sjpg", "jpeg", "png", "gif"],
		fixed: false,
		formatter: $.noop,
		labels: {
			close: "Close",
			count: "of",
			next: "Next",
			previous: "Previous"
		},
		margin: 50,
		minHeight: 100,
		minWidth: 100,
		mobile: gadget,
		opacity: 0.75,
		retina: false,
		requestKey: "boxer",
		top: 0,
		videoRatio: 0.5625,
		videoWidth: displayResolution >= 3840 ? 2800 : displayResolution >= 2048 ? 1400 : 700
	};
	var pub = {
		close: function () {
			if (typeof data.$boxer !== "undefined") {
				data.$boxer.off(".boxer");
				data.$overlay.trigger("click");
			}
		},
		defaults: function (opts) {
			options = $.extend(options, opts || {});
			return (typeof this === 'object') ? $(this) : false;
		},
		destroy: function () {
			return $(this).off(".boxer");
		},
		resize: function (e) {
			if (typeof data.$boxer !== "undefined") {
				if (typeof e !== "object") {
					data.targetHeight = arguments[0];
					data.targetWidth = arguments[1];
				}
				if (data.type === "element") {
					sizeContent(data.$content.find(">:first-child"));
				} else if (data.type === "image") {
					sizeImage();
				} else if (data.type === "video") {
					sizeVideo();
				}
				size();
			}
			return $(this);
		}
	};
	function init(opts) {
		options.formatter = formatCaption;
		$body = $("body");
		transitionEvent = getTransitionEvent();
		transitionSupported = (transitionEvent !== false);
		// no transitions :(
		if (!transitionSupported) {
			transitionEvent = "transitionend.boxer";
		}
		return $(this).on("click.boxer", $.extend({}, options, opts || {}), build);
	}
	function build(e) {
		if (typeof data.$boxer === "undefined") {
			// Check target type
			var $target = $(this),
				$object = e.data.$object,
				source = ($target[0].href) ? $target[0].href || "" : "",
				hash = ($target[0].hash) ? $target[0].hash || "" : "",
				sourceParts = source.toLowerCase().split(".").pop().split(/\#|\?/),
				extension = sourceParts[0],
				type = $target.data("boxer-type") || "",
				isImage = ((type === "image") || ($.inArray(extension, e.data.extensions) > -1 || source.substr(0, 10) === "data:image")),
				isVideo = (source.indexOf("youtube.com") > -1 || source.indexOf("player.vimeo.com/video") > -1 || source.indexOf("wistia") > -1 || source.indexOf("rumble.com") > -1 || source.indexOf(".mp4") > -1),
				isUrl = ((type === "url") || (!isImage && !isVideo && source.substr(0, 4) === "http" && !hash)),
				isElement = ((type === "element") || (!isImage && !isVideo && !isUrl && (hash.substr(0, 1) === "#"))),
				isObject = ((typeof $object !== "undefined"));
			if (isElement) {
				source = hash;
			}
			if ($("#boxer").length > 1 || !(isImage || isVideo || isUrl || isElement || isObject)) {
				return;
			}
			killEvent(e);
			data = $.extend(
				{},
				{
					$window: $(window),
					$body: $("body"),
					tsvgId: e.data.tsvgId,
					$target: $target,
					$object: $object,
					visible: false,
					resizeTimer: null,
					touchTimer: null,
					gallery: {
						active: false
					},
					isMobile: (trueMobile || e.data.mobile),
					isAnimating: true,
					oldContentHeight: 0,
					oldContentWidth: 0
				},
				e.data
			);
			data.margin *= 2;
			if (isImage) {
				data.type = "image";
			} else if (isVideo) {
				data.type = "video";
			} else {
				data.type = "element";
			}
			if (isImage || isVideo) {
				// Check for gallery
				var id = data.$target.data("gallery") || data.$target.attr("rel"); // backwards compatibility
				var key_id = data.$target.data("id");
				if (typeof id !== "undefined" && id !== false) {
					data.gallery.active = true;
					data.gallery.id = id;
					data.gallery.$items = $("a[data-gallery= " + data.gallery.id + "], a[rel= " + data.gallery.id + "]"); // backwards compatibility
					data.gallery.index = data.gallery.$items.index(data.$target);
					data.gallery.total = data.gallery.$items.length - 1;
				}
			}
			// Assemble HTML
			var html = '';
			var titl_position = jQuery(".tsvg-th-blocks-container-" + key_id).attr('data-tsvg-titl_position');
			var titl_bacg = jQuery(".tsvg-th-blocks-container-" + key_id).attr('data-tsvg-titl_bacg');
			var popup_bacg = jQuery(".tsvg-th-blocks-container-" + key_id).attr('data-tsvg-popup_bacg');
			var show_numbers = jQuery(".tsvg-th-blocks-container-" + key_id).attr('data-tsvg-show-num');
			var show_navigation = jQuery(".tsvg-th-blocks-container-" + key_id).attr('data-tsvg-show-navigation');
			if (!data.isMobile) {
				html += '<div id="boxer-overlay" class="' + data.customClass + '"></div>';
			}
			html += '<div id="boxer" data-tsvg-show-num="' + show_numbers + '" data-tsvg-titl_position="' + titl_position + '" data-tsvg-show-navigation="' + show_navigation + '" data-tsvg-titl_bacg="' + titl_bacg + '" data-tsvg-popup_bacg="' + popup_bacg + '"  class="loading animating ' + data.customClass;
			if (data.fixed) {
				html += ' fixed';
			}
			if (data.isMobile) {
				html += ' mobile';
			}
			if (isUrl) {
				html += ' iframe';
			}
			if (isElement || isObject) {
				html += ' inline';
			}
			html += '">';
			html += '<span class="boxer-close">' + data.labels.close + '</span>';
			html += '<span class="boxer-loading"></span>';
			html += '<div class="boxer-container">';
			html += '<div class="boxer-content">';
			if (isImage || isVideo) {
				html += '<div class="boxer-meta">';
				if (data.gallery.active) {
					html += '<div class="boxer-control previous">' + data.labels.previous + '</div>';
					html += '<div class="boxer-control next">' + data.labels.next + '</div>';
					html += '<p class="boxer-position"';
					if (data.gallery.total < 1) {
						html += ' style="display: none;"';
					}
					html += '>';
					html += '<span class="current">' + (data.gallery.index + 1) + '</span> ' + data.labels.count + ' <span class="total">' + (data.gallery.total + 1) + '</span>';
					html += '</p>';
					html += '<div class="boxer-caption gallery">';
				} else {
					html += '<div class="boxer-caption">';
				}
				html += data.formatter.apply(data.$body, [data.$target]);
				html += '</div></div>'; // caption, meta
			}
			html += '</div></div></div>'; // container, content, boxer
			// Modify Dom
			data.$body.append(html);
			// Cache jquery objects
			data.$overlay = $("#boxer-overlay");
			data.$boxer = $("#boxer");
			data.$overlay.addClass("tsvg-boxer-overlay-" + data.tsvgId);
			data.$boxer.addClass("tsvg-boxer-" + data.tsvgId);
			data.$container = data.$boxer.find(".boxer-container");
			data.$content = data.$boxer.find(".boxer-content");
			data.$meta = data.$boxer.find(".boxer-meta");
			data.$position = data.$boxer.find(".boxer-position");
			data.$caption = data.$boxer.find(".boxer-caption");
			data.$controls = data.$boxer.find(".boxer-control");
			data.paddingVertical = (!data.isMobile) ? (parseInt(data.$boxer.css("paddingTop"), 10) + parseInt(data.$boxer.css("paddingBottom"), 10)) : (data.$boxer.find(".boxer-close").outerHeight() / 2);
			data.paddingHorizontal = (!data.isMobile) ? (parseInt(data.$boxer.css("paddingLeft"), 10) + parseInt(data.$boxer.css("paddingRight"), 10)) : 0;
			data.contentHeight = data.$boxer.outerHeight() - data.paddingVertical;
			data.contentWidth = data.$boxer.outerWidth() - data.paddingHorizontal;
			data.controlHeight = data.$controls.outerHeight();
			// Center
			center();
			// Update gallery
			if (data.gallery.active) {
				updateControls();
				touch();
			}
			// Bind events
			data.$window.on("resize.boxer", pub.resize)
				.on("keydown.boxer", onKeypress);
			data.$body.on("touchstart.boxer click.boxer", "#boxer-overlay, #boxer .boxer-close", onClose)
				.on("touchmove.boxer", killEvent);
			data.$body.on("touchstart.boxer click.boxer", "#boxer-overlay, #boxer .boxer-close", onClose)
				.on("touchmove.boxer", onTouchStart);
			data.$body.on("touchstart.boxer click.boxer", "#boxer-overlay, #boxer .boxer-close", onClose)
				.on("touchmove.boxer", onTouchMove);
			if (data.gallery.active) {
				data.$boxer.on("touchstart.boxer click.boxer", ".boxer-control", advanceGallery);
				data.$boxer.on("touchstart.boxer click.boxer", ".boxer-control", touch);
				data.$boxer.on("touchstart.boxer click.boxer", ".boxer-control", onTouchStart);
			}
			data.$boxer.on(
				transitionEvent,
				function (e) {
					killEvent(e);
					if ($(e.target).is(data.$boxer)) {
						data.$boxer.off(transitionEvent);
						if (isImage) {
							loadImage(source);
						} else if (isVideo) {
							loadVideo(source, key_id);
						} else if (isUrl) {
							loadURL(source);
						} else if (isElement) {
							cloneElement(source);
						} else if (isObject) {
							appendObject(data.$object);
						} else {
							$.error("BOXER: '" + source + "' is not valid.");
						}
					}
				}
			);
			$body.addClass("boxer-open");
			if (!transitionSupported) {
				data.$boxer.trigger(transitionEvent);
			}
			if (isObject) {
				return data.$boxer;
			}
		}
	}
	function onClose(e) {
		killEvent(e);
		if (typeof data.$boxer !== "undefined") {
			setTimeout(
				() => {
					if (typeof data.$overlay !== "undefined" && data.$overlay !== null) {
						data.$overlay.remove();
					}
					if (typeof data.$boxer !== "undefined" && data.$boxer !== null) {
						data.$boxer.remove();
					}
					data = {};
				},
				250
			);
			data.$boxer.addClass("animating");
			$body.removeClass("boxer-open");
			if (!transitionSupported) {
				data.$boxer.trigger(transitionEvent);
			}
			clearTimer(data.resizeTimer);
			// Clean up
			data.$window.off("resize.boxer")
				.off("keydown.boxer");
			data.$body.off(".boxer")
				.removeClass("boxer-open");
			if (data.gallery.active) {
				data.$boxer.off(".boxer");
			}
			if (data.isMobile) {
				if (data.type === "image" && data.gallery.active) {
					data.$container.off(".boxer");
				}
			}
			data.$window.trigger("close.boxer");
		}
	}
	function open() {
		var position = calculatePosition(),
			durration = data.isMobile ? 0 : data.duration;
		if (!data.isMobile) {
			data.$controls.css(
				{
					marginTop: ((data.contentHeight - data.controlHeight - data.metaHeight) / 2),
					marginBottom: ((data.contentHeight - data.controlHeight - data.metaHeight) / 2)
				}
			);
		}
		if (!data.visible && data.isMobile && data.gallery.active) {
			data.$content.on("touchstart.boxer", ".boxer-image", onTouchStart);
		}
		if (data.isMobile || data.fixed) {
			data.$body.addClass("boxer-open");
		}
		data.$boxer.on(
			transitionEvent,
			function (e) {
				killEvent(e);
				if ($(e.target).is(data.$boxer)) {
					data.$boxer.off(transitionEvent);
					data.$container.on(
						transitionEvent,
						function (e) {
							killEvent(e);
							if ($(e.target).is(data.$container)) {
								data.$container.off(transitionEvent);
								data.$boxer.removeClass("animating");
								data.isAnimating = false;
							}
						}
					);
					data.$boxer.removeClass("loading");
					if (!transitionSupported) {
						data.$content.trigger(transitionEvent);
					}
					data.visible = true;
					// Fire callback + event
					data.callback.apply(data.$boxer);
					data.$window.trigger("open.boxer");
					// Start preloading
					if (data.gallery.active) {
						preloadGallery();
					}
				}
			}
		);
		if (!data.isMobile) {
			data.$boxer.css(
				{
					height: data.contentHeight + data.paddingVertical,
					width: data.contentWidth + data.paddingHorizontal,
					// top: Math.floor( $(window).height() - Math.floor(data.contentHeight + data.paddingVertical) ) / 2
				}
			);
		}
		// Trigger event in case the content size hasn't changed
		var contentHasChanged = (data.oldContentHeight !== data.contentHeight || data.oldContentWidth !== data.contentWidth);
		if (data.isMobile || !transitionSupported || !contentHasChanged) {
			data.$boxer.trigger(transitionEvent);
		}
		// Track content size changes
		data.oldContentHeight = data.contentHeight;
		data.oldContentWidth = data.contentWidth;
	}
	/**
	 * @method private
	 * @name size
	 * @description Sizes active instance
	 */
	function size() {
		if (data.visible && !data.isMobile) {
			var position = calculatePosition();
			data.$controls.css(
				{
					marginTop: ((data.contentHeight - data.controlHeight - data.metaHeight) / 2)
				}
			);
			data.$boxer.css(
				{
					height: data.contentHeight + data.paddingVertical,
					width: data.contentWidth + data.paddingHorizontal,
					// top: (!data.fixed) ? position.top : 0
				}
			);
		}
	}
	function center() {
		var position = calculatePosition();
		data.$boxer.css(
			{
				// top: (!data.fixed) ? position.top : 0
			}
		);
	}
	function calculatePosition() {
		if (data.isMobile) {
			return {
				left: 0,
				top: 0
			};
		}
		var pos = {
			left: (data.$window.width() - data.contentWidth - data.paddingHorizontal) / 2,
			top: (data.top <= 0) ? ((data.$window.height() - data.contentHeight - data.paddingVertical) / 2) : data.top
		};
		// if (data.fixed !== true) {
		// 	pos.top = data.$window.scrollTop();
		// }
		return pos;
	}
	function formatCaption($target) {
		var title = $target.attr("title");
		return (title !== undefined && title.trim() !== "") ? '<p class="caption">' + title.trim() + '</p>' : "";
	}
	function loadImage(source) {
		// Cache current image
		data.$image = $("<img />");
		data.$image.load(
			function () {
				data.$image.off("load, error");
				var naturalSize = calculateNaturalSize(data.$image);
				data.naturalHeight = naturalSize.naturalHeight;
				data.naturalWidth = naturalSize.naturalWidth;
				if (data.retina) {
					data.naturalHeight /= 2;
					data.naturalWidth /= 2;
				}
				data.$content.prepend(data.$image);
				if (data.$caption.html() === "") {
					data.$caption.hide();
				} else {
					data.$caption.show();
				}
				// Size content to be sure it fits the viewport
				sizeImage();
				open();
			}
		).error(loadError)
			.attr("src", source)
			.addClass("boxer-image");
		// If image has already loaded into cache, trigger load event
		if (data.$image[0].complete || data.$image[0].readyState === 4) {
			data.$image.trigger("load");
		}
	}
	function sizeImage() {
		var count = 0;
		data.windowHeight = data.viewportHeight = data.$window.height() - data.paddingVertical;
		data.windowWidth = data.viewportWidth = data.$window.width() - data.paddingHorizontal;
		data.contentHeight = Infinity;
		data.contentWidth = Infinity;
		data.imageMarginTop = 0;
		data.imageMarginLeft = 0;
		while (data.contentHeight > data.viewportHeight && count < 2) {
			data.imageHeight = (count === 0) ? data.naturalHeight : data.$image.outerHeight();
			data.imageWidth = (count === 0) ? data.naturalWidth : data.$image.outerWidth();
			data.metaHeight = (count === 0) ? 0 : data.metaHeight;
			if (count === 0) {
				data.ratioHorizontal = data.imageHeight / data.imageWidth;
				data.ratioVertical = data.imageWidth / data.imageHeight;
				data.isWide = (data.imageWidth > data.imageHeight);
			}
			// Double check min and max
			if (data.imageHeight < data.minHeight) {
				data.minHeight = data.imageHeight;
			}
			if (data.imageWidth < data.minWidth) {
				data.minWidth = data.imageWidth;
			}
			if (data.isMobile) {
				// Get meta height before sizing
				data.$meta.css(
					{
						width: data.windowWidth
					}
				);
				data.metaHeight = data.$meta.outerHeight(true);
				// Content match viewport
				data.contentHeight = data.viewportHeight - data.paddingVertical;
				data.contentWidth = data.viewportWidth - data.paddingHorizontal;
				fitImage();
				data.imageMarginTop = (data.contentHeight - data.targetImageHeight - data.metaHeight) / 2;
				data.imageMarginLeft = (data.contentWidth - data.targetImageWidth) / 2;
			} else {
				// Viewport should match window, less margin, padding and meta
				if (count === 0) {
					data.viewportHeight -= (data.margin + data.paddingVertical);
					data.viewportWidth -= (data.margin + data.paddingHorizontal);
				}
				data.viewportHeight -= data.metaHeight;
				fitImage();
				data.contentHeight = data.targetImageHeight;
				data.contentWidth = data.targetImageWidth;
			}
			// Modify DOM
			data.$meta.css(
				{
					width: data.contentWidth
				}
			);
			data.$image.css(
				{
					height: data.targetImageHeight,
					width: data.targetImageWidth,
					marginTop: data.imageMarginTop,
					marginLeft: data.imageMarginLeft
				}
			);
			if (!data.isMobile) {
				data.metaHeight = data.$meta.outerHeight(true);
				data.contentHeight += data.metaHeight;
			}
			count++;
		}
	}
	function fitImage() {
		var height = (!data.isMobile) ? data.viewportHeight : data.contentHeight - data.metaHeight,
			width = (!data.isMobile) ? data.viewportWidth : data.contentWidth;
		if (data.isWide) {
			// WIDE
			data.targetImageWidth = width;
			data.targetImageHeight = data.targetImageWidth * data.ratioHorizontal;
			if (data.targetImageHeight > height) {
				data.targetImageHeight = height;
				data.targetImageWidth = data.targetImageHeight * data.ratioVertical;
			}
		} else {
			// TALL
			data.targetImageHeight = height;
			data.targetImageWidth = data.targetImageHeight * data.ratioVertical;
			if (data.targetImageWidth > width) {
				data.targetImageWidth = width;
				data.targetImageHeight = data.targetImageWidth * data.ratioHorizontal;
			}
		}
		// MAX
		if (data.targetImageWidth > data.imageWidth || data.targetImageHeight > data.imageHeight) {
			data.targetImageHeight = data.imageHeight;
			data.targetImageWidth = data.imageWidth;
		}
		// MIN
		if (data.targetImageWidth < data.minWidth || data.targetImageHeight < data.minHeight) {
			if (data.targetImageWidth < data.minWidth) {
				data.targetImageWidth = data.minWidth;
				data.targetImageHeight = data.targetImageWidth * data.ratioHorizontal;
			} else {
				data.targetImageHeight = data.minHeight;
				data.targetImageWidth = data.targetImageHeight * data.ratioVertical;
			}
		}
	}
	function loadVideo(source, id) {
		var tsvg_autoplay = jQuery('.tsvg-main-content-' + id).attr('data-tsvg-autoplay');
		var isvideomp4 = "false";
		if (source.indexOf('youtube.com') > -1) {
			if (source.indexOf('shorts')) {
				source = source.replace("shorts", "embed");
			}
			if (tsvg_autoplay == "true") {
				source = source + '?autoplay=1&mute=1';
			}
		}
		else if (source.indexOf('player.vimeo.com/video/') > -1) {
			if (tsvg_autoplay == "true") {
				source = source + '?autoplay=1&muted=1';
			}
		}
		else if (source.indexOf('.mp4') > -1) {
			isvideomp4 = 'true';
		}
		else if (source.indexOf('fast.wistia.net/embed/iframe/') > -1) {
			if (tsvg_autoplay == "true") {
				source = source + '?wvideo=hashedid';
			}
		}
		data.$videoWrapper = $('<div class="boxer-video-wrapper" />');
		if (isvideomp4 == "true") {
			let autoplay_bool = tsvg_autoplay == "true" ? "autoplay" : "";
			data.$video = '<video class="tsvg_mp4_player" controls="" ' + autoplay_bool + ' name="media" width="100%"><source src="' + source + '" type="video/mp4"></video>';
			data.$videoWrapper.prepend(data.$video)
		} else {
			if (source.indexOf("rumble.com") > -1) {
				data.$video = $('<iframe class="boxer-video" seamless="seamless" frameborder="0" sandbox="allow-scripts" webkitAllowFullScreen mozallowfullscreen allowFullScreen/>');
			} else {
				data.$video = $('<iframe class="boxer-video" seamless="seamless" frameborder="0" webkitAllowFullScreen mozallowfullscreen allowFullScreen/>');
			}
			data.$video.attr("src", source).addClass("boxer-video");
			data.$video.prependTo(data.$videoWrapper);
		}
		data.$content.prepend(data.$videoWrapper);
		sizeVideo();
		open();
	}
	/**
	 * @method private
	 * @name sizeVideo
	 * @description Sizes video to fit in viewport
	 */
	function sizeVideo() {
		// Set initial vars
		data.windowHeight = data.viewportHeight = data.contentHeight = data.$window.height() - data.paddingVertical;
		data.windowWidth = data.viewportWidth = data.contentWidth = data.$window.width() - data.paddingHorizontal;
		data.videoMarginTop = 0;
		data.videoMarginBottom = 0;
		data.videoMarginLeft = 0;
		if (data.isMobile) {
			data.$meta.css(
				{
					width: data.windowWidth
				}
			);
			data.metaHeight = data.$meta.outerHeight(true);
			data.viewportHeight -= data.metaHeight;
			data.targetVideoWidth = data.viewportWidth;
			data.targetVideoHeight = data.targetVideoWidth * data.videoRatio;
			if (data.targetVideoHeight > data.viewportHeight) {
				data.targetVideoHeight = data.viewportHeight - 40 * data.videoRatio;
				data.targetVideoWidth = data.targetVideoHeight / data.videoRatio;
				data.videoMarginTop = 0;
				data.videoMarginBottom = 0;
				data.videoMarginLeft = (data.viewportWidth - data.targetVideoWidth) / 2;
			} else {
				data.videoMarginTop = (data.viewportHeight - data.targetVideoHeight) / 2;
				data.videoMarginBottom = (data.viewportHeight - data.targetVideoHeight) / 2;
				data.videoMarginLeft = (data.viewportWidth - data.targetVideoWidth) / 2;
			}
		} else {
			data.viewportHeight = data.windowHeight - data.margin;
			data.viewportWidth = data.windowWidth - data.margin;
			data.targetVideoWidth = (data.videoWidth > data.viewportWidth) ? data.viewportWidth + 80 : data.videoWidth;
			if (data.targetVideoWidth < data.minWidth) {
				data.targetVideoWidth = data.minWidth;
			}
			data.targetVideoHeight = data.targetVideoWidth * data.videoRatio;
			data.contentHeight = data.targetVideoHeight;
			data.contentWidth = data.targetVideoWidth;
		}
		// Update dom
		data.$meta.css(
			{
				width: data.contentWidth
			}
		);
		data.$videoWrapper.css(
			{
				height: data.targetVideoHeight,
				width: data.targetVideoWidth,
				marginTop: data.videoMarginTop,
				marginBottom: data.videoMarginBottom,
				marginLeft: data.videoMarginLeft
			}
		);
		if (!data.isMobile) {
			data.metaHeight = data.$meta.outerHeight(true);
			data.contentHeight = data.targetVideoHeight + data.metaHeight;
		}
	}
	function preloadGallery(e) {
		var source = '';
		if (data.gallery.index > 0) {
			source = data.gallery.$items.eq(data.gallery.index - 1).attr("href");
			if (source.indexOf("youtube.com") < 0 && source.indexOf("vimeo.com/video") < 0 || source.indexOf("wistia") < 0 || source.indexOf("rumble.com") < 0) {
				$('<img src="' + source + '">');
			}
		}
		if (data.gallery.index < data.gallery.total) {
			source = data.gallery.$items.eq(data.gallery.index + 1).attr("href");
			if (source.indexOf("youtube.com") < 0 && source.indexOf("vimeo.com/video") < 0 || source.indexOf("wistia") < 0 || source.indexOf("rumble.com") < 0) {
				$('<img src="' + source + '">');
			}
		}
	}
	function advanceGallery(e) {
		killEvent(e);
		var $control = $(this);
		if (!data.isAnimating && !$control.hasClass("disabled")) {
			data.isAnimating = true;
			data.gallery.index += ($control.hasClass("next")) ? 1 : -1;
			if (data.gallery.index > data.gallery.total) {
				data.gallery.index = data.gallery.total;
			}
			if (data.gallery.index < 0) {
				data.gallery.index = 0;
			}
			data.$container.on(
				transitionEvent,
				function (e) {
					killEvent(e);
					if ($(e.target).is(data.$container)) {
						data.$container.off(transitionEvent);
						if (typeof data.$image !== 'undefined') {
							data.$image.remove();
						}
						if (typeof data.$videoWrapper !== 'undefined') {
							data.$videoWrapper.remove();
						}
						data.$target = data.gallery.$items.eq(data.gallery.index);
						data.$caption.html(data.formatter.apply(data.$body, [data.$target]));
						data.$position.find(".current").html(data.gallery.index + 1);
						var source = data.$target.attr("href"),
							isVideo = (source.indexOf("youtube.com") > -1 || source.indexOf("vimeo.com/video") > -1 || source.indexOf("wistia") > -1 || source.indexOf("rumble.com") > -1 || source.indexOf(".mp4") > -1),
							gallery_id_ = data.$target.attr("data-id");
						if (isVideo) {
							loadVideo(source, gallery_id_);
						} else {
							loadImage(source);
						}
						updateControls();
					}
				}
			);
			data.$boxer.addClass("loading animating");
			if (!transitionSupported) {
				data.$content.trigger(transitionEvent);
			}
		}
	}
	/**
	 * @method private
	 * @name updateControls
	 * @description Updates gallery control states
	 */
	function updateControls() {
		data.$controls.removeClass("disabled");
		if (data.gallery.index === 0) {
			data.$controls.filter(".previous").addClass("disabled");
		}
		if (data.gallery.index === data.gallery.total) {
			data.$controls.filter(".next").addClass("disabled");
		}
	}
	function onKeypress(e) {
		if (data.gallery.active && (e.keyCode === 37 || e.keyCode === 39)) {
			killEvent(e);
			data.$controls.filter((e.keyCode === 37) ? ".previous" : ".next").trigger("click");
		} else if (e.keyCode === 27) {
			data.$boxer.find(".boxer-close").trigger("click");
		}
	}
	// touch
	function touch(e) {
		// setTimeout(function(){
		// setTimeout(function(){
		// jQuery(document).on('swipeleft', '#boxer, .boxer-video-wrapper', function(event){
		// data.$controls.filter( (data.delta <= data.leftPosition) ? ".previous" : ".next" ).trigger("click");
		// return false;});
		// jQuery(document).on('swiperight', '#boxer, .boxer-video-wrapper', function(event){
		// data.$controls.filter( (data.delta <= data.leftPosition) ? ".next" : ".previous" ).trigger("click");
		// return false;});
		// },400);
		// },1500);
	}
	/**
	 * @method private
	 * @name cloneElement
	 * @description Clones target inline element
	 * @param id [string] "Target element id"
	 */
	function cloneElement(id) {
		var $clone = $(id).find(">:first-child").clone();
		appendObject($clone);
	}
	/**
	 * @method private
	 * @name loadURL
	 * @description Load URL into iframe
	 * @param source [string] "Target URL"
	 */
	function loadURL(source) {
		source = source + ((source.indexOf("?") > -1) ? "&" + options.requestKey + "=true" : "?" + options.requestKey + "=true");
		var $iframe = $('<iframe class="boxer-iframe" src="' + source + '" />');
		appendObject($iframe);
	}
	function appendObject($object) {
		data.$content.append($object);
		sizeContent($object);
		open();
	}
	function sizeContent($object) {
		data.windowHeight = data.$window.height() - data.paddingVertical;
		data.windowWidth = data.$window.width() - data.paddingHorizontal;
		data.objectHeight = $object.outerHeight(true);
		data.objectWidth = $object.outerWidth(true);
		data.targetHeight = data.targetHeight || data.$target.data("boxer-height");
		data.targetWidth = data.targetWidth || data.$target.data("boxer-width");
		data.maxHeight = (data.windowHeight < 0) ? options.minHeight : data.windowHeight;
		data.isIframe = $object.is("iframe");
		data.objectMarginTop = 0;
		data.objectMarginLeft = 0;
		if (!data.isMobile) {
			data.windowHeight -= data.margin;
			data.windowWidth -= data.margin;
		}
		data.contentHeight = (data.targetHeight !== undefined) ? data.targetHeight : (data.isIframe || data.isMobile) ? data.windowHeight : data.objectHeight;
		data.contentWidth = (data.targetWidth !== undefined) ? data.targetWidth : (data.isIframe || data.isMobile) ? data.windowWidth : data.objectWidth;
		if ((data.isIframe || data.isObject) && data.isMobile) {
			data.contentHeight = data.windowHeight;
			data.contentWidth = data.windowWidth;
		} else if (data.isObject) {
			data.contentHeight = (data.contentHeight > data.windowHeight) ? data.windowHeight : data.contentHeight;
			data.contentWidth = (data.contentWidth > data.windowWidth) ? data.windowWidth : data.contentWidth;
		}
	}
	function loadError(e) {
		var $error = $('<div class="boxer-error"><p>Error Loading Resource</p></div>');
		// Clean up
		data.type = "element";
		data.$meta.remove();
		data.$image.off("load, error");
		appendObject($error);
	}
	function onTouchStart(e) {
		killEvent(e);
		clearTimer(data.touchTimer);
		// if (!data.isAnimating) {
		var touch = (typeof e.originalEvent.targetTouches !== "undefined") ? e.originalEvent.targetTouches[0] : null;
		data.xStart = (touch) ? touch.pageX : e.clientX;
		// data.xStart = (touch) ? touch.pageY : e.clientY;
		data.leftPosition = 0;
		data.touchMax = Infinity;
		data.touchMin = -Infinity;
		data.edge = data.contentWidth * 0.25;
		if (data.gallery.index === 0) {
			data.touchMax = 0;
		}
		if (data.gallery.index === data.gallery.total) {
			data.touchMin = 0;
		}
		data.$boxer.on("touchmove.boxer", onTouchMove)
			.one("touchend.boxer", onTouchEnd);
		// }
	}
	/**
	 * @method private
	 * @name onTouchMove
	 * @description Handles touchmove event
	 * @param e [object] "Event data"
	 */
	function onTouchMove(e) {
		var touch = (typeof e.originalEvent.targetTouches !== "undefined") ? e.originalEvent.targetTouches[0] : null;
		if (touch.pageY) {
			data.delta = data.xStart - ((touch) ? touch.pageY : e.clientY);
		}
		if (touch.pageX) {
			data.delta = data.xStart - ((touch) ? touch.pageX : e.clientX);
		}
		// data.delta = data.xStart - ((touch) ? touch.pageY : e.clientY);
		// Only prevent event if trying to swipe
		if (data.delta > 20) {
			killEvent(e);
		}
		data.canSwipe = true;
		var newLeft = -data.delta;
		if (newLeft < data.touchMin) {
			newLeft = data.touchMin;
			data.canSwipe = false;
		}
		if (newLeft > data.touchMax) {
			newLeft = data.touchMax;
			data.canSwipe = false;
		}
		// data.$video.css({ transform: "translate3D("+newLeft+"px,0,0)" });
		// data.$video.css({ transform: "translate3D("+newRight+"px,0,0)" });
		data.touchTimer = startTimer(
			data.touchTimer,
			300,
			function () {
				onTouchEnd(e);
			}
		);
	}
	/**
	 * @method private
	 * @name onTouchEnd
	 * @description Handles touchend event
	 * @param e [object] "Event data"
	 */
	function onTouchEnd(e) {
		killEvent(e);
		clearTimer(data.touchTimer);
		data.$boxer.off("touchmove.boxer touchend.boxer");
		if (data.delta || data.delta == 0) {
			data.$boxer.addClass("animated");
			data.swipe = false;
			if (data.canSwipe && (data.delta > data.edge || data.delta < -data.edge)) {
				data.swipe = true;
				if (data.delta == data.leftPosition) {
					data.$video.css({ transform: "translate3D(" + (data.contentWidth) + "px,0,0)" });
				} else {
					data.$video.css({ transform: "translate3D(" + (-data.contentWidth) + "px,0,0)" });
				}
			} else {
				data.$video.css({ transform: "translate3D(0,0,0)" });
			}
			// if (data.swipe) {
			data.$controls.filter((data.delta <= data.leftPosition) ? ".previous" : ".next").trigger("click");
			// }
			startTimer(
				data.resetTimer,
				data.duration,
				function () {
					data.$boxer.removeClass("animated");
				}
			);
		}
	}
	function calculateNaturalSize($img) {
		var node = $img[0],
			img = new Image();
		if (typeof node.naturalHeight !== "undefined") {
			return {
				naturalHeight: node.naturalHeight,
				naturalWidth: node.naturalWidth
			};
		} else {
			if (node.tagName.toLowerCase() === 'img') {
				img.src = node.src;
				return {
					naturalHeight: img.height,
					naturalWidth: img.width
				};
			}
		}
		return false;
	}
	function killEvent(e) {
		if (e.preventDefault) {
			e.stopPropagation();
			e.preventDefault();
		}
	}
	function startTimer(timer, time, callback) {
		clearTimer(timer);
		return setTimeout(callback, time);
	}
	function clearTimer(timer) {
		if (timer) {
			clearTimeout(timer);
			timer = null;
		}
	}
	function getTransitionEvent() {
		var transitions = {
			'WebkitTransition': 'webkitTransitionEnd',
			'MozTransition': 'transitionend',
			'OTransition': 'oTransitionEnd',
			'transition': 'transitionend'
		},
			test = document.createElement('div');
		for (var type in transitions) {
			if (transitions.hasOwnProperty(type) && type in test.style) {
				return transitions[type];
			}
		}
		return false;
	}
	$.fn.boxer = function (method) {
		if (pub[method]) {
			return pub[method].apply(this, Array.prototype.slice.call(arguments, 1));
		} else if (typeof method === 'object' || !method) {
			return init.apply(this, arguments);
		}
		return this;
	};
	$.boxer = function ($target, opts) {
		if (pub[$target]) {
			return pub[$target].apply(window, Array.prototype.slice.call(arguments, 1));
		} else {
			if ($target instanceof $) {
				return build.apply(
					window,
					[{
						data: $.extend(
							{
								$object: $target
							},
							options,
							opts || {}
						)
					}]
				);
			}
		}
	};
})(jQuery, window);