(function($) { "use strict"; // ------------------------------------------------------------------------------------------- // ligthbox activation // ------------------------------------------------------------------------------------------- $.avia_utilities = $.avia_utilities || {}; $.avia_utilities.av_popup = { type: 'image', mainclass: 'avia-popup mfp-zoom-in', tloading: '', tclose: '', removaldelay: 300, //delay removal by x to allow out-animation closebtninside: true, closeoncontentclick:false, midclick: true, fixedcontentpos: false, // allows scrolling when lightbox is open but also removes any jumping because of scrollbar removal iframe: { patterns: { youtube: { index: 'youtube.com/watch', id: function(url) { //fetch the id var m = url.match(/[\\?\\&]v=([^\\?\\&]+)/), id, params; if ( !m || !m[1] ) return null; id = m[1]; //fetch params params = url.split('/watch'); params = params[1]; return id + params; }, src: '//www.youtube.com/embed/%id%' } } }, image: { titlesrc: function(item){ var title = item.el.attr('title'); if(!title) title = item.el.find('img').attr('title'); if(!title) title = item.el.parent().next('.wp-caption-text').html(); if(typeof title == "undefined") return ""; return title; } }, gallery: { // delegate: options.autolinkelements, tprev: '', tnext: '', tcounter: '%curr% / %total%', enabled: true, preload: [1,1] // will preload 1 - before current, and 1 after the current image }, callbacks: { beforeopen: function() { //add custom css class for different styling if( this.st.el && this.st.el.data('fixed-content') ) { this.fixedcontentpos = true; } }, open: function() { //overwrite default prev + next function. add timeout for crossfade animation $.magnificpopup.instance.next = function() { var self = this; self.wrap.removeclass('mfp-image-loaded'); settimeout(function() { $.magnificpopup.proto.next.call(self); }, 120); }; $.magnificpopup.instance.prev = function() { var self = this; self.wrap.removeclass('mfp-image-loaded'); settimeout(function() { $.magnificpopup.proto.prev.call(self); }, 120); }; //add custom css class for different styling if( this.st.el && this.st.el.data('av-extra-class') ) { this.wrap.addclass( this.curritem.el.data('av-extra-class') ); } }, imageloadcomplete: function() { var self = this; settimeout(function() { self.wrap.addclass('mfp-image-loaded'); }, 16); }, change: function() { if( this.curritem.el ) { var current = this.curritem.el; this.content.find( '.av-extra-modal-content, .av-extra-modal-markup' ).remove(); if( current.data('av-extra-content') ) { var extra = current.data('av-extra-content'); this.content.append( "
" ); } if( current.data('av-extra-markup') ) { var markup = current.data('av-extra-markup'); this.wrap.append( "