%PDF- %PDF-
Direktori : /var/www/projetos/spanish.ongrace.com/wp-content/plugins/gallery-videos/JS/ |
Current File : /var/www/projetos/spanish.ongrace.com/wp-content/plugins/gallery-videos/JS/jquery.fs.boxer.js |
;(function ($, window) { "use strict"; var $body = null, data = {}, trueMobile = /webOS/i.test((window.navigator.userAgent||window.navigator.vendor||window.opera)), transitionEvent, 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: false, opacity: 0.75, retina: false, requestKey: "boxer", top: 0, videoRatio: 0.5625, videoWidth: 600 }; 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/embed") > -1 || source.indexOf("player.vimeo.com/video") > -1 || source.indexOf("wistia") > -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"), $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 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 = ''; if (!data.isMobile) { html += '<div id="boxer-overlay" class="' + data.customClass + '"></div>'; } html += '<div id="boxer" 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.$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); } 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") { data.$boxer.on(transitionEvent, function(e) { killEvent(e); if ($(e.target).is(data.$boxer)) { data.$boxer.off(transitionEvent); data.$overlay.remove(); data.$boxer.remove(); // reset data data = {}; } }).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: (!data.fixed) ? position.top : 0 }); } if (!data.isMobile) { var wistia_container = data.$boxer[0].children[2]; var wistia_url = jQuery(wistia_container).find('iframe').attr('src'); if(wistia_url.indexOf('wistia')!=-1){ data.$boxer.css({ height: data.contentHeight + data.paddingVertical, width: data.contentWidth + data.paddingHorizontal, top: (!data.fixed) ? position.top : 0 }); } } // 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 = (jQuery(window).height() - (data.contentHeight + data.paddingVertical))/2; //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) { data.$videoWrapper = $('<div class="boxer-video-wrapper" />'); data.$video = $('<iframe class="boxer-video" seamless="seamless" frameborder="0" webkitAllowFullScreen mozallowfullscreen allowFullScreen/>'); if(source.indexOf('start')===-1){ data.$video.attr("src", source+'?autoplay=1;rel=0;iv_load_policy=3') .addClass("boxer-video") .prependTo(data.$videoWrapper); data.$content.prepend(data.$videoWrapper); sizeVideo(); open(); } else{ data.$video.attr("src", source+'&autoplay=1;rel=0;iv_load_policy=3') .addClass("boxer-video") .prependTo(data.$videoWrapper); data.$content.prepend(data.$videoWrapper); sizeVideo(); open(); } // data.$video = $('<iframe class="boxer-video" seamless="seamless" frameborder="0" webkitAllowFullScreen mozallowfullscreen allowFullScreen/>'); // data.$video.attr("src", source+'?autoplay=1;rel=0;iv_load_policy=3') /*****----*/ } /** * @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/embed") < 0 && source.indexOf("player.vimeo.com/video") < 0 || source.indexOf("wistia") < 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/embed") < 0 && source.indexOf("player.vimeo.com/video") < 0 || source.indexOf("wistia") < 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/embed") > -1 || source.indexOf("player.vimeo.com/video") > -1 || source.indexOf("wistia") > -1 || source.indexOf(".mp4") > -1); if (isVideo) { loadVideo(source); } 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 !== "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', /* 'MSTransitionEnd': 'msTransition', */ /* 'msTransition': 'MSTransitionEnd' */ '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);