');
$(document).on({
mouseenter: function () {
$colorboxtooltip.addClass('active');
},
mouseleave: function () {
setTimeout(function() {
$colorboxtooltip.removeClass('active');
}, 400);
}
}, '#colorbox.' + $this.data('popup-theme') + ' #cboxTitle');
$(document).one('cbox_complete', function(event){
if (!$('#sggCboxTooltip').length) {
$("#cboxWrapper").append($colorboxtooltip);
}
});
$(document).on('cbox_complete', function(event) {
$colorboxtooltip.html($("#cboxTitle").html());
if($('#colorbox').width() < 300) {
$('#colorbox').filter('.theme_1').find('#cboxSlideshow').css('bottom', '30px');
}
});
}
}
this.initColorbox = true;
var colorBoxConfig = {
fadeOut: this.$container.data('popup-fadeOut'),
fixed: true,
maxHeight: getImageDimension().height,
maxWidth: getImageDimension().width,
scalePhotos: true,
scrolling: false,
returnFocus: false,
slideshow: slidePlay && this.$container.data('popup-slideshow-speed'),
slideshowAuto: slidePlayAuto,
slideshowSpeed: slideshowSpeed,
rel: this.$container.attr('id'),
slideshowStart: self.popupTranslates.start_slideshow,
slideshowStop: self.popupTranslates.stop_slideshow,
current: self.popupTranslates.image + " {current} " + self.popupTranslates.of + " {total}",
previous: self.popupTranslates.previous,
next: self.popupTranslates.next,
close: self.popupTranslates.close,
'isDisableRightClick': this.$container.attr('data-disable-right-click') == 'true',
title: function() {
return self.getPopupTitle($(this));
},
speed: 350,
transition: 'elastic',
onComplete: function(e) {
self.changePopUpHash($(e.el).attr('id') || $(e.el).attr('data-id'));
self.addSocialShareToPopUp($(e.el), $('#cboxContent'), 'popup');
self.$container.find('.grid-gallery-photos > .gg-colorbox, .hi-icon.gg-colorbox')
.colorbox.resize();
$("#cboxLoadedContent").append("
");
},
onLoad: function(e){
if(self.popup_opened_image == e.el) return;
self.popup_opened_image = e.el;
var dimensions = getColorboxImageDimension();
$(self.popup_opened_image).data('colorbox').maxWidth = dimensions.width;
$(self.popup_opened_image).data('colorbox').maxHeight = dimensions.height;
},
onOpen: function(e) {
//Enable/Disable stop slideshow on mouse hover
if(popupHoverStop){
var timeoutId = 0;
$('#cboxContent').hover(function(){
clearTimeout(timeoutId);
$('.cboxSlideshow_on #cboxSlideshow').click();
},function(){
if(slidePlayAuto) {
clearTimeout(timeoutId);
timeoutId = setTimeout(function(){
$('.cboxSlideshow_off #cboxSlideshow').click();
},slideshowSpeed);
}
})
}
},
onClosed: function(){
self.popup_opened_image = false;
self.clearPopUpHash();
}
};
if(popupPlacementType == 1 || popupPlacementType == 2) {
colorBoxConfig['maxWidth'] = '100%';
colorBoxConfig['imgPlaceType'] = popupPlacementType;
}
this.$container.find(colorBoxItemSelector).off('click').colorbox(colorBoxConfig);
$(window).resize(function(){
self.resizeColorbox();
});
$('#cboxOverlay').removeClass().addClass($this.data('popup-theme')+'-overlay');
$('#colorbox').removeClass().addClass($this.data('popup-theme'));
generateOverlayColor('#cboxOverlay', popupBackground, popupOverlayTransper, true);
}
if(popupType == 'pretty-photo') {
// simple selector
var prettyPhotoItemSelector = '.grid-gallery-photos > a[data-rel^="prettyPhoto"]:visible,'
+ ' .grid-gallery-photos .gg-mosaic-wrapper a[data-rel^="prettyPhoto"],' // mosaic selector
+ ' .grid-gallery-photos .hi-icon-wrap > a[data-rel^="prettyPhoto"]:visible'; // icon selector
// for popup "Display only first image"
if(this.$container.hasClass('one-photo') || this.$container.hasClass('hidden-item')) {
prettyPhotoItemSelector = '.grid-gallery-photos > a[data-rel^="prettyPhoto"],'
+ ' .grid-gallery-photos .gg-mosaic-wrapper a[data-rel^="prettyPhoto"],' // mosaic selector
+ ' .grid-gallery-photos .hi-icon-wrap > a[data-rel^="prettyPhoto"]'; // icon selector
}
if(!this.$prettyPhoto) {
if(hideLongTooltipTitles == 0) {
var $prettyPhotoTooltip = $('
');
$(document).on({
mouseenter: function () {
$prettyPhotoTooltip.addClass('active');
},
mouseleave: function () {
setTimeout(function () {
$prettyPhotoTooltip.removeClass('active');
}, 400);
}
}, '.pp_content_container .pp_description');
}
if(this.$container.attr('data-show-buttonlink-in-popup') == 1 && window.prettyPhotoDetailLink) {
this.loadButtonsFontFamily(this.$container.attr('data-buttonlink-font'), null);
}
this.$prettyPhoto = this.$container
.find(prettyPhotoItemSelector)
.off('click')
.ggPrettyPhoto({
hook: 'data-rel',
theme: 'light_square',
allow_resize: true,
allow_expand: true,
deeplinking: false,
slideshow: slidePlay && this.$container.data('popup-slideshow-speed'),
autoplay_slideshow: slidePlayAuto,
social_tools: '',
default_width: popupMaxWidth,
default_height: popupMaxHeight,
getImageDimensions : getImageDimension,
'is_lazy_load': isLazyLoad,
'ppTranslates': self.popupTranslates,
'isDisableRightClick': this.$container.attr('data-disable-right-click') == 'true',
'isShowRotateBtn': this.$container.attr('data-show-rotate-btn-in-popup') == 1,
'isShowAttributes': this.$container.attr('data-show-attributes-in-popup') == 1,
'attributesPosition': this.$container.attr('data-attributes-position'),
'attributesWidth': this.$container.attr('data-attributes-width'),
'isShowButtonLink': this.$container.attr('data-show-buttonlink-in-popup') == 1,
'buttonLinkStyle': this.$container.attr('data-buttonlink-style'),
'isShowLinkBtn': this.$container.attr('data-show-link-btn-in-popup') == 1,
'isShowHovThumbnail': this.$container.attr('data-show-thumb-hov-in-popup') == 1,
'galleryId': this.$container.attr('data-gg-id'),
'getTitle': function() {},
'setImageTitleForPrepare': function($element) {
var imgTile = self.getPopupTitle($element);
return imgTile;
},
'popup_border_type': this.$container.attr('data-popup-border-type'),
'popup_border_color': this.$container.attr('data-popup-border-color'),
'popup_border_width': this.$container.attr('data-popup-border-width'),
'popup_border_enable': this.$container.attr('data-popup-border-enable') == 'on',
changepicturecallback: function(element){
self.changePopUpHash(element.attr('id') || element.attr('data-id'));
self.popup_opened_image = element;
$('.pp_description').html(self.getPopupTitle(element)).show();
//add social share buttons if enabled
self.addSocialShareToPopUp(element,$('.pp_hoverContainer'),'popup');
if(!slidePlay){
$('.pp_play').hide();
}
// change detail link url
if(self.$container.attr('data-show-link-btn-in-popup') == 1 && window.prettyPhotoDetailLink) {
window.prettyPhotoDetailLink(element);
}
if(self.$container.attr('data-show-attributes-in-popup') == 1 && window.prettyPhotoAttributes)
{
window.prettyPhotoAttributes(element, self.$container);
}
//Enable/Disable stop slideshow on mouse hover
if(popupHoverStop){
$('.pp_hoverContainer').hover(function(){
$('.pp_nav .pp_pause').click();
},function(){
if(slidePlayAuto) {
$('.pp_nav .pp_play').click();
}
})
}
var $_desc = $('.pp_description'),
desc_height = parseInt($_desc.height()),
desc_line_height = parseInt($_desc.css('font-size'));
if(desc_line_height < desc_height){
$('.pp_content').height($('.pp_fade').outerHeight(true) + $('.pp_details').outerHeight(true));
}
if(hideLongTooltipTitles == 0) {
if (!$('#sggPrettyPhototooltip').length) {
$(".pp_content_container .pp_content").append($prettyPhotoTooltip);
}
$prettyPhotoTooltip.html($(".pp_content_container .pp_description").html());
}
},
callback: function(){
self.popup_opened_image = false;
self.clearPopUpHash();
}
});
$(window).resize(function(){
if(!self.popup_opened_image || !self.$prettyPhoto) return;
//if(self.$prettyPhoto[0].closest('div') != self.popup_opened_image[0].closest('div')) return;
self.$prettyPhoto.open(self.popup_opened_image);
});
} else {
this.$prettyPhoto.refresh(this.$container.find(prettyPhotoItemSelector));
}
generateOverlayColor('.pp_overlay', popupBackground, popupOverlayTransper, true);
}
if(popupType == 'photobox') {
var photoBoxItemSelector = 'a.pbox:visible'
, photoBoxConfig = null;
// for popup "Display only first image"
if(this.$container.hasClass('one-photo') || this.$container.hasClass('hidden-item') || this.$container.data('gridType') == '4') {
photoBoxItemSelector = 'a.pbox';
}
if (this.initPhotobox) {
this.$container.find('.grid-gallery-photos').photobox('destroy');
}
this.initPhotobox = true;
photoBoxConfig = {
autoplay: slidePlayAuto,
'isDisableRightClick': this.$container.attr('data-disable-right-click') == 'true',
thumb: function(link) {
if(self.$container.data('caption-buider') == '1' && self.$container.data('caption-builder-icons') == 1) {
return link.closest('.grid-gallery-caption').find('img')[0];
} else if(self.$container.data('icons')) {
return link.closest('.grid-gallery-caption').find('img')[0];
}
return null;
},
getTitle: function(el){
var nameTitle = self.getPopupTitle($(el));
return nameTitle;
},
beforeShow: function(element){
self.changePopUpHash($(element).attr('id') || $(element).attr('data-id'));
self.addSocialShareToPopUp($(element),$('#pbCaption'),'photobox',true);
},
afterClose: function(){
self.clearPopUpHash();
}
};
if(isLazyLoad) {
photoBoxConfig['thumbAttr'] = 'data-gg-real-image-href';
}
this.$container.find('.grid-gallery-photos').off('click').photobox(photoBoxItemSelector, photoBoxConfig);
//Hide autoplay button when slideshow = false
if(!this.$container.data('popup-slideshow')){
$("#pbAutoplayBtn").hide();
}
//Enable/Disable stop slideshow on mouse hover
if(popupHoverStop){
$('.pbWrapper img').hover(function(){
$('#pbOverlay .playing').click();
},function(){
if(slidePlayAuto) {
$('#pbOverlay .play').click();
}
})
}
generateOverlayColor('#pbOverlay', popupBackground, popupOverlayTransper);
}
//===========|Popup gallery scripts|===========//
});
Gallery.prototype.preventImages = (function() {
var popupType = this.$container.data('popup-type');
if (popupType == 'disable') {
this.$container.find('a.gg-link').off('click');
this.$container.find('a.gg-link:not([data-type=link])').addClass('disabled');
this.$container.on('click', 'a.gg-link', function(event) {
if ($(this).data('type') !== 'link') {
event.preventDefault();
event.stopPropagation();
}
});
}
});
Gallery.prototype.getResponsiveColumnsNumber = function() {
var columnsData = this.$container.data('responsive-colums'),
settings = [],
columnsNumber = parseInt(this.$container.data('columns-number'));
for (var key in columnsData) {
settings.push(columnsData[key]);
}
settings.sort(function(a, b) {
a.width = Number(a.width);
b.width = Number(b.width);
if (a.width > b.width) {
return 1;
} else if (a.width < b.width) {
return -1;
} else {
return 0;
}
});
for (var i = 0,
len = settings.length,
windowWidth = $(window).width(),
minBreakpoint = 0; i < len; i++) {
if (windowWidth > minBreakpoint && windowWidth <= settings[i].width) {
columnsNumber = Number(settings[i].columns);
break;
}
minBreakpoint = settings[i].width;
};
return columnsNumber;
};
Gallery.prototype.initRowsMode = function() {
var columnsNumber = parseInt(this.$container.data('columns-number'));
if (this.$container.data('horizontal-scroll')) {
return;
}
if (typeof this.$container.data('responsive-colums') == 'object') {
columnsNumber = this.getResponsiveColumnsNumber();
}
if (columnsNumber) {
var containerWidth = parseInt(this.$container.width()),
spacing = parseInt(this.$container.data('offset')),
scaleHeight = parseInt(this.$container.data('width')) / parseInt(this.$container.data('height')),
elementWidth = null,
elementHeight = null;
elementWidth = Math.floor((this.$container.width() - (columnsNumber - 1) * spacing) / columnsNumber);
elementHeight = Math.floor(elementWidth / scaleHeight);
this.$elements.each(function() {
var $this = $(this);
if (!$this.find('.post-feed-crop').length) {
$this.css('width', elementWidth);
if (!isNaN(elementHeight)) {
$this.css('height', elementHeight);
} else {
$this.css('height', 'auto');
}
} else {
$this.find('figcaption').css('width', elementWidth);
}
});
this.$elements.find('.crop').css({
width: 'auto',
height: 'auto'
});
}
};
Gallery.prototype.setImagesHeight = (function () {
var $images = this.$container.find('img');
if ($images != undefined && $images.length > 0) {
$images.each(function () {
var $image = $(this),
$wrapper = $image.parent();
if ($image.height() < $wrapper.height()) {
$wrapper.css('height', $image.height());
}
});
}
});
Gallery.prototype.setOverlayTransparency = (function () {
this.$elements.find('figcaption, [class*="caption-with-icons"]').each(function () {
var $caption = $(this),
alpha = (10 - parseInt($caption.data('alpha'), 10)) / 10,
rgb = $caption.css('background-color'),
rgba = rgb.replace(')', ', ' + alpha + ')').replace('rgb', 'rgba');
$caption.css('background', rgba);
});
});
Gallery.prototype.setIconsPosition = (function () {
var self = this;
this.$elements.each(function () {
var $element = $(this),
isCaptionBuilderUsed = self.$container.data('caption-buider'),
$wrapper = $element.find('div.hi-icon-wrap'),
$icons = $element.find('a.hi-icon');
$icons.each(function () {
var $icon = $(this),
marginData = {},
marginY = ($element.height() / 2) - ($icon.height() / 2) - 10,
marginX = $wrapper.data('margin');
if(marginX && !isCaptionBuilderUsed) {
marginData['margin-left'] = marginX;
marginData['margin-right'] = marginX;
}
if(marginY && !isCaptionBuilderUsed) {
marginData['margin-top'] = Math.abs(marginY);
}
$icon.css(marginData);
});
});
});
Gallery.prototype.initCategories = (function () {
var $defaultElement = this.$navigation.find('a[data-tag="__all__"]'),
$elements = this.$navigation.find('a'),
$defaultBackground = $elements.first().css('background-color');
function shadeColor(color, percent) {
var f=parseInt(color.slice(1),16),t=percent<0?0:255,p=percent<0?percent*-1:percent,R=f>>16,G=f>>8&0x00FF,B=f&0x0000FF;
return "#" + (0x1000000+(Math.round((t-R)*p)+R)*0x10000+(Math.round((t-G)*p)+G)*0x100+(Math.round((t-B)*p)+B)).toString(16).slice(1);
}
bg = shadeColor('#' + this.rgb2hex($elements.first().css('borderTopColor')), 0.3);
this.$navigation.find('a').on('click', $.proxy(function (event) {
event.preventDefault();
var $category = $(event.currentTarget),
requested = String($category.data('tag')),
_defaultTag = '__all__',
currentGallery = this.$navigation.parent().attr('id');
$elements.css('background-color', $defaultBackground);
$category.css('background-color', bg);
if (requested == _defaultTag) {
this.$elements.each(function () {
if ($(this).parent().attr('rel')) {
$(this).parent().attr('rel', 'prettyPhoto['+currentGallery+']');
}
}).fadeIn();
this.correctMargin();
this.initWookmark();
if (!this.isFluidHeight() && this.$qsEnable) {
this.callQuicksand(this.$qsHolder, this.$qsData, this.$qsDuration);
}
return false;
}
if (!this.isFluidHeight() && this.$qsEnable) {
var $filteredData = this.$qsData.filter(function () {
var tags = $(this).children().data('tags');
if (typeof tags !== 'undefined') {
tags = tags.split('|');
}
return ($.inArray(requested, tags) > -1);
});
this.callQuicksand(this.$qsHolder, $filteredData, this.$qsDuration);
} else {
$hidden = $();
$visible = $();
this.$elements.each(function () {
var $element = $(this),
tags = $element.data('tags');
if (typeof tags != 'string') {
tags = String(tags);
}
if (tags != undefined) {
tags = tags.split('|');
}
if ($.inArray(requested, tags) > -1) {
if ($element.parent().attr('rel')) {
$element.parent().attr('rel', 'prettyPhoto['+currentGallery+'-'+requested+']');
}
$visible.push(this);
} else {
$hidden.push(this);
}
});
$.when($hidden.fadeOut()).done($.proxy(function(){
$visible.fadeIn().css({'height':''});
this.correctMargin();
this.initWookmark();
}, this));
}
}, this));
var firstTag = $elements.first().data('tag');
this.$container.find('a[data-tag="'+ firstTag+ '"]').trigger('click');
});
Gallery.prototype.callQuicksand = function($holder, $filteredData, duration) {
self = this;
$filteredData.find('figure.grid-gallery-caption').css('margin', this.initialMargin).parent().css('clear', 'none');
$holder.quicksand($filteredData, {
duration: Number(duration),
easing: 'swing',
attribute: 'href',
}, function() {
$holder.css({
width: 'auto',
height: 'auto'
}).append('
');
self.initPopup();
self.correctMargin();
if(self.$container.data('lazyload-enable') == '1') {
// images area removed and filled new images
self.initLazyLoad();
}
}
);
};
Gallery.prototype.hidePopupCaptions = function() {
//never show alternative text for popup theme 6 on top of popup
$('').appendTo("head");
if (this.$container.data('popup-captions') == 'hide') {
$('').appendTo("head");
}
};
Gallery.prototype.hidePaginationControls = (function () {
return false;
});
Gallery.prototype.setImageOverlay = (function() {
if(this.isImageOverlay()) {
this.$container.find('.grid-gallery-caption').each(function () {
var image = $(this).find('img');
var crop = $(this).find('.image-overlay');
image.css('opacity', '0.2');
crop.css('background-color', '#424242');
$(this).on('mouseenter', function () {
image.css('opacity', '1.0');
crop.css('background-color', 'inherit');
}
);
$(this).on('mouseleave', function () {
image.css('opacity', '0.2');
crop.css('background-color', '#424242');
});
});
}
});
Gallery.prototype.setMouseShadow = (function() {
var shadow = null,
$selector = null,
$captions = this.$container.find('.grid-gallery-caption'),
self = this,
showOver = function(event) {
if (event.type === 'mouseenter') {
$(this).css('box-shadow', self.mouseOverBoxShadow);
} else {
$(this).css('box-shadow', 'none');
}
},
hideOver = function(event) {
if (event.type === 'mouseenter') {
$(this).css('box-shadow', 'none');
} else {
$(this).css('box-shadow', self.mouseOverBoxShadow);
}
};
// only first Init elem has correct value
if(!self.mouseOverBoxShadow) {
self.mouseOverBoxShadow = $captions.filter(':first').css('box-shadow');
}
if ($captions.is('.shadow-show')) {
$captions.css('box-shadow', 'none');
$captions.off('hover').on('hover', showOver);
} else if ($captions.is('.shadow-hide')) {
$captions.off('hover').on('hover', hideOver);
}
});
Gallery.prototype.initPagination = (function () {
var perPage = parseInt(this.$container.find('.grid-gallery-photos').data('per-page'), 10),
buffer = [],
page = 1,
offset = 0
self = this;
if (isNaN(perPage)) {
this.$elements.fadeIn();
return false;
}
if(this.$container.data('gridType') == 4 && this.$container.data('show-mosaic-all-img') != 1) {
this.$elements.fadeIn();
this.pagination.wrapper.hide();
return false;
}
var showCurrentPage = (function (gallery) {
gallery.$elements.removeClass('current-page').hide(350);
$.each(buffer[gallery.pagination.currentPage], function () {
$(this).addClass('current-page').css({height:gallery.$container.data('height'),width:gallery.$container.data('width')}).show(function () {
gallery.setIconsPosition();
self.correctMargin();
});
});
/*
if (!gallery.isFluidHeight()) {
$('.current-page .crop').css('height', function () {
var height = null;
$('.crop img').each(function () {
if($(this).height() && !height) {
height = $(this).height();
}
});
return height;
});
}
*/
});
this.pagination.limit = perPage;
this.$elements.each($.proxy(function (index, el) {
var currentIndex = index + 1;
if ((currentIndex - offset) <= this.pagination.limit) {
if (!$.isArray(buffer[page])) {
buffer[page] = [];
}
buffer[page].push(el);
} else {
offset += this.pagination.limit;
page += 1;
buffer[page] = [el];
}
}, this)).hide();
this.pagination.pages = Math.ceil(this.pagination.total / this.pagination.limit);
var element=this.pagination.$wrapper.find('a.grid-gallery-page[data-page="1"]');
element.css('font-size','19pt');
this.pagination.$wrapper.find('a.grid-gallery-page').on('click', $.proxy(function (e) {
e.preventDefault();
var element = $(e.currentTarget);
var galery = Gallery.prototype;
this.pagination.$wrapper.find('a.grid-gallery-page').each(function() {
$(this).css('font-size','inherit');
});
galery.selectedCategory = element.data('page');
element.css('font-size','19pt');
var $anchor = $(e.currentTarget),
requestedPage = $anchor.data('page');
this.pagination.currentPage = requestedPage;
showCurrentPage(this);
return false;
}, this));
showCurrentPage(this);
});
Gallery.prototype.hex=function(x) {
return isNaN(x) ? "00" : hexDigits[(x - x % 16) / 16] + hexDigits[x % 16];
};
Gallery.prototype.rgb2hex = function(rgb) {
if(rgb) {
rgb = rgb.match(/^rgba?\((\d+),\s*(\d+),\s*(\d+)(?:,\s*(0\.\d+))?\)$/);
function hex(x) {
return ("0" + parseInt(x).toString(16)).slice(-2);
}
return hex(rgb[1]) + hex(rgb[2]) + hex(rgb[3]);
}
};
Gallery.prototype.hex2rgb = function(hex) {
var shorthandRegex = /^#?([a-f\d])([a-f\d])([a-f\d])$/i;
hex = hex.replace(shorthandRegex, function(m, r, g, b) {
return r + r + g + g + b + b;
});
var result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
return result ? {
r: parseInt(result[1], 16),
g: parseInt(result[2], 16),
b: parseInt(result[3], 16)
} : null;
};
Gallery.prototype.importFontFamily = (function(familyName) {
var styleId = 'sggFontFamilyStyle',
$style = $('#' + styleId);
if (!$style.length) {
$style = $('', { id: styleId });
$('head').append($style);
}
familyName = familyName.replace(/\s+/g, '+').replace(/"/g, '');
var obj = document.getElementById(styleId),
sheet = obj.sheet || obj.styleSheet;
if(this.loadedFonts.indexOf(familyName) === -1) {
if(sheet.insertRule) {
sheet.insertRule('@import url("//fonts.googleapis.com/css?family=' + familyName + '"); ', 0);
} else if(sheet.addImport) {
sheet.addImport('//fonts.googleapis.com/css?family=' + familyName);
}
this.loadedFonts.push(familyName);
}
});
Gallery.prototype.loadFontFamily = (function () {
font = this.$container.data('caption-font-family');
if(typeof font !== "undefined") {
if(window && window.sggStandartFontsList && $.inArray(font.replace(/\"/g, ''), window.sggStandartFontsList) != -1) {
return false;
}
if (font && font !== 'Default') {
this.importFontFamily(font);
}
} else {
return false;
}
});
Gallery.prototype.initCaptionCalculations = (function () {
var self = this;
this.$container.find('.grid-gallery-caption').each(function () {
wrap = $(this).find('div.grid-gallery-figcaption-wrap');
figcaption = $(this).find('figcaption');
wrap.css({
'display': 'table-cell',
'text-align': figcaption.css('text-align')
});
wrap.wrap($('
', {
css: {
display:'table',
height:'100%',
width:'100%'
}
}));
});
});
Gallery.prototype.checkDirection = function($element, e) {
var w = $element.width(),
h = $element.height(),
x = ( e.pageX - $element.offset().left - ( w / 2 )) * ( w > h ? ( h / w ) : 1 ),
y = ( e.pageY - $element.offset().top - ( h / 2 )) * ( h > w ? ( w / h ) : 1 );
return Math.round(( ( ( Math.atan2(y, x) * (180 / Math.PI) ) + 180 ) / 90 ) + 3) % 4;
};
Gallery.prototype.generateOverlayCaptionColor = (function (overlayColor, alpha) {
if(typeof(overlayColor) == 'string'){
overlayColor = overlayColor.split(')');
if(overlayColor.length > 0) {
overlayColor = overlayColor[0].split('(');
if(overlayColor.length > 1) {
var chanels = overlayColor[1].split(',');
if(chanels.length == 4) { // it is already rgba (fix for IE)
overlayColor[0] = overlayColor[0].replace('a', '');
chanels.splice(-1,1);
overlayColor[1] = chanels.join(',');
}
return overlayColor[0] + 'a(' + overlayColor[1] + ', ' + (1 - alpha/10) + ')';
}
}
}
return overlayColor;
});
Gallery.prototype.initCaptionEffects = (function () {
var self = this,
allwaysShowCaptionOnMobile = this.$container.data('caption-mobile'),
disableCaptionOnMobile = this.$container.data('caption-disabled-on-mobile'),
isMobile = !!parseInt(this.$container.data('is-mobile'));
if(isMobile && navigator && navigator.userAgent && navigator.userAgent.indexOf("Safari") > -1) {
var $3dCubeCaptions = this.$container.find('.grid-gallery-caption[data-grid-gallery-type="3d-cube"]');
$3dCubeCaptions.attr('data-grid-gallery-type', 'revolving-door-bottom');
$3dCubeCaptions.data('grid-gallery-type', 'revolving-door-bottom');
}
$.each(this.$elements, function(index, el) {
var $el = $(el),
overlayColor = $el.find('figcaption').css('backgroundColor'),
alpha = parseInt($el.find('figcaption').data('alpha'));
if (isMobile && allwaysShowCaptionOnMobile){
$el.attr('data-grid-gallery-type', 'none');
}
if ($el.data('grid-gallery-type') == 'cube') {
$el.on('mouseenter mouseleave', function(e) {
var $figcaption = $(this).find('figcaption'),
direction = self.checkDirection($(this), e),
classHelper = null;
switch (direction) {
case 0:
classHelper = 'cube-' + (e.type == 'mouseenter' ? 'in' : 'out') + '-top';
break;
case 1:
classHelper = 'cube-' + (e.type == 'mouseenter' ? 'in' : 'out') + '-right';
break;
case 2:
classHelper = 'cube-' + (e.type == 'mouseenter' ? 'in' : 'out') + '-bottom';
break;
case 3:
classHelper = 'cube-' + (e.type == 'mouseenter' ? 'in' : 'out') + '-left';
break;
}
$figcaption.removeClass().addClass(classHelper);
});
}
if ($el.data('grid-gallery-type') == 'direction-aware') {
var color = $el.find('figcaption').css('color'),
isCaptionBuilderUsed = self.$container.data('caption-buider'),
classStr = '',
addAttr = '',
align = $el.find('figcaption').css('text-align');
if(isCaptionBuilderUsed == 1) {
$el.attr('data-caption', '
' +
($el.find('figcaption').html() || '') + '
');
} else {
var $ggImgCaption = $el.find('.gg-image-caption');
if($ggImgCaption.hasClass('ggRtlClass')) {
classStr = 'ggRtlClass';
addAttr = 'dir="rtl"';
}
$el.attr('data-caption', '
' +
($ggImgCaption.html() || '') + '
');
}
$el.sliphover({
target: $el,
backgroundColor: self.generateOverlayCaptionColor(overlayColor, alpha),
fontColor: color,
textAlign: align,
caption: 'data-caption'
});
}
if ($el.data('grid-gallery-type') == '3d-cube'){
if(!$el.find('.box-3d-cube-scene').length){
var cubeWidth = $el.width(),
cubeHeight = $el.height();
// $el.addClass('box-3d-cube-scene');
$el.children('div').addClass('front').addClass('face');
$el.children('figcaption').addClass('back').addClass('face');
$el.html('
');
// $el.html("
");
self.changeImageHeightFor3dCubeEffect($el, cubeWidth, cubeHeight);
}
}
if ($el.data('grid-gallery-type') == 'polaroid') {
self.polaroidCaptionCalculate($el);
} else {
var topRow = $el.find('.gg-caption-row.top'),
centerRow = $el.find('.gg-caption-row.center');
if(centerRow.length == 1 && topRow.length == 1) {
centerRow.css({'top': topRow.height(), 'transform': 'initial'});
}
}
});
$(document).on('click', '.sliphover-container', function(event) {
event.preventDefault();
$(this).data('relatedElement').get(0).click();
});
if(isMobile && !disableCaptionOnMobile) {
this.$container.find('.grid-gallery-caption').each(function() {
var caption = this,
$caption = $(caption),
hammer = new Hammer_gg(this),
captionIsMobile = self.$container.attr('data-caption-mobile'),
preventClick = false;
$caption.on('click', function(event) {
if (preventClick) {
event.preventDefault();
event.stopPropagation();
}
});
hammer.on("tap panstart", function(event) {
if (event.type === 'panstart') {
self.$container.find('.grid-gallery-caption').removeClass('hovered');
}
if (event.type === 'tap') {
preventClick = false;
if (!$caption.hasClass('hovered')) {
self.$container.find('.grid-gallery-caption').not(caption).removeClass('hovered');
$(caption).addClass('hovered');
if(captionIsMobile == 'false') {
preventClick = true;
}
}
}
});
});
}
if (isMobile && disableCaptionOnMobile) {
this.$container.find('.grid-gallery-caption figcaption').hide();
}
});
Gallery.prototype.polaroidCaptionCalculate = (function ($el) {
if ($el.data('grid-gallery-type') != 'polaroid' || $(this).find('.post-feed-crop').length || $el.hasClass('initialized')) return;
var $img = $el.find('img');
if($img.hasClass('ggLazyImg') || $img.hasClass('ggNotInitImg')) return;
if($el.closest('.gg-mw-row').hasClass('sggDisplNone')) return;
$el.addClass('initialized');
$img.finish();
var width = $el.width(),
gridType = this.$container.data('gridType'),
frameWidth = parseInt(this.$container.data('polaroid-frame-width'), 10) || 20,
captionHeight = this.$container.data('polaroid-caption-height'),
clearHeight = captionHeight ? parseInt(captionHeight.toString().match(/\d.?\d*.?\d*/)[0]) : 0,
overlayColor = $el.find('figcaption').css('backgroundColor'),
alpha = parseInt($el.find('figcaption').data('alpha')),
$figcaption = $el.find('figcaption'),
scaleRatio = $img.width() / $img.height();
if(gridType == 2) {
var imageHeight = $img.height() - frameWidth * 2,
imageWidth = imageHeight * scaleRatio;
} else {
var imageWidth = $img.width() - frameWidth * 2,
imageHeight = imageWidth / scaleRatio;
}
var figcaptionHeight = !isNaN(clearHeight) && clearHeight != 0 ? (captionHeight.toString().indexOf('%') > 0 ? (imageHeight * clearHeight / 100) : clearHeight) : 0,
figureFullHeight = imageHeight + frameWidth * 2 + figcaptionHeight;
$img.css({
'width': imageWidth + 'px',
'height': imageHeight + 'px',
'margin': frameWidth + 'px auto 0',
});
$el.find('.gg-caption-table').css('height', '1px');
$el.find('.crop').css({
'height': imageHeight + frameWidth + 'px'
});
if(gridType == 0) {
$el.find('.crop').css('overflow', 'visible');
} else if(gridType == 2) {
$el.css({
'height': figureFullHeight + 'px',
'width': imageWidth + frameWidth * 2 + 'px',
});
} else if(gridType == 3) {
$el.css({
'height': figureFullHeight + 'px',
});
}
$el.css({
'background': overlayColor
});
$el.css({
'width': $el.width(),
'background': this.generateOverlayCaptionColor(overlayColor, alpha)
});
$figcaption.css({
'background': 'none',
'transition': 'none',
});
if(figcaptionHeight) {
figcaptionHeight += 'px';
$figcaption.css('height', figcaptionHeight);
$el.find('.gg-caption-row').css({'max-height': figcaptionHeight ? figcaptionHeight : '100%', 'height': 'auto'});
$el.find('.gg-caption-cell').css('height', '100%');
if(gridType == 3) {
$figcaption.css('margin-top', frameWidth + 'px');
}
} else {
$figcaption.css('padding', frameWidth + 'px');
}
if ($figcaption.find('.grid-gallery-figcaption-wrap').text().length === 0) {
$figcaption
.find('.grid-gallery-figcaption-wrap')
.append('
');
}
if (this.$container.data('polaroid-animation')) {
$el.addClass('polaroid-animation');
}
if (this.$container.data('polaroid-scattering')) {
$el.css({
'transform': 'rotate(' + (-3 + Math.random() * (10 - 3)) + 'deg)'
});
$el.addClass('polaroid-scattering');
}
var slimScroll = $el.closest('div.slimScrollDiv');
if(slimScroll.length) {
var scrollHeight = figureFullHeight + 20 + 'px';
slimScroll.css('height', scrollHeight);
slimScroll.find('.grid-gallery-photos').css('height', scrollHeight);
}
});
Gallery.prototype.changeImageHeightFor3dCubeEffect = (function($figure, cubeWidth, cubeHeight) {
// check params
if(!$figure) {
return;
}
// call this function from PRO script
if(!$figure.length) {
if('figure' in $figure && 'width' in $figure && 'height' in $figure) {
cubeWidth = $figure.width;
cubeHeight = $figure.height;
$figure = $figure.figure;
} else {
return;
}
}
if(!cubeWidth) {
cubeWidth = $figure.width();
}
if(!cubeHeight) {
cubeHeight = $figure.height();
}
var perspective = Math.max(cubeHeight,cubeWidth) * 2 + 'px'
, transformOrigin = '50% 50% -' + Math.round(cubeHeight/2) + 'px';
$figure.find('.box-3d-cube-scene').css({
'perspective': perspective,
'-webkit-perspective': perspective
});
$figure.find('.box-3d-cube').css({
'transform-origin': transformOrigin,
'-ms-transform-origin': transformOrigin,
'-webkit-transform-origin': transformOrigin,
});
$figure.find('.box-3d-cube, .box-3d-cube .face').css({
width: cubeWidth + 'px',
height: cubeHeight + 'px',
});
});
Gallery.prototype.correctMargin = (function () {
if(this.$container.data('area-position') == 'right') {
return;
}
if(this.$container.data('gridType') == 4) {
return;
}
// if responsive mode = 'one by one' and mobile -> run this method
var horizontalScroll = this.$container.data('horizontal-scroll')
, isMobile = parseInt($anyGallery.attr('data-is-mobile'))
if(horizontalScroll && horizontalScroll.responsiveMode == 1 && isMobile) {} else {
return;
}
if(!this.isFluidHeight()) {
if (this.$qsEnable) {
this.$elements = this.$container.find('figure.grid-gallery-caption');
};
var prevElement = null
, totalElements = this.$elements.filter(':visible').length
, rowWidth = 0
, maxRowWidth = this.$container.width()
, initialMargin = this.initialMargin;
this.$elements.css('margin', this.initialMargin);
this.$elements.parent().css('clear', 'none');
this.$elements.filter(':visible').each(function(index){
if (rowWidth + $(this).outerWidth() > maxRowWidth) {
$(prevElement).css('margin-right', 0);
$(this).css('margin-right', this.initialMargin);
$(this).parent().css('clear', 'left');
rowWidth = $(this).outerWidth() + parseInt(initialMargin);
} else if (rowWidth + $(this).outerWidth() == maxRowWidth) {
$(this).css('margin-right', 0);
rowWidth = 0;
} else {
rowWidth += $(this).outerWidth() + parseInt(initialMargin);
}
if(index == totalElements - 1) {
$(this).css('margin-right', 0);
}
prevElement = this;
});
}
});
Gallery.prototype.hideTitleTooltip = (function () {
if(this.$container.data('hide-tooltip') == true) {
title = '';
this.$container.find('a, img, div:not(.grid-gallery-photos)').on('mouseenter', function() {
title = $(this).attr('title');
$(this).attr({'title':' '});
}).mouseout(function() {
$(this).attr({'title':title});
});
};
});
Gallery.prototype.correctFullscreen = (function () {
var windowWidth = $(window).width();
this.$elements.each(function() {
var coef = parseInt(windowWidth / $(this).width())
, resultWidth = Math.round(windowWidth / coef);
$(this).width(resultWidth);
});
});
Gallery.prototype.correctFullScreenWidthGallery = (function(){
var windowWidth = $(window).width(),
$parentContainer = this.$container.parent(),
containerOffset = $parentContainer.offset(),
containerOffsetLeft = containerOffset.left + parseFloat($parentContainer.css('padding-left'));
this.$container.find('.grid-gallery-photos').css({
width: windowWidth
});
var cssDirection = this.$container.css('direction');
if ('ltr' == cssDirection) {
this.$container.css({
width: windowWidth,
left: '-' + containerOffsetLeft + 'px',
//'max-width': '100%'
});
this.$container.find('.grid-gallery-nav').css('width', windowWidth + 'px');
} else {
this.$container.css({
width: windowWidth //, 'max-width': '100%'
}).offset(function(i, coords) {
return {'top' : coords.top, 'left' : 0};
});
}
});
Gallery.prototype.getOriginalImageSizes = function (img) {
var tempImage = new Image(),
width,
height;
if ('naturalWidth' in tempImage && 'naturalHeight' in tempImage) {
width = img.naturalWidth;
height = img.naturalHeight;
} else {
tempImage.src = img.src;
width = tempImage.width;
height = tempImage.height;
}
return {
width: width,
height: height,
};
};
Gallery.prototype.initHorizontalMode = (function () {
var horizontalScroll = this.$container.data('horizontal-scroll')
, height = this.$container.data('height')
, width = this.$container.data('width')
, offset = this.$container.data('offset')
, isMobile = parseInt($anyGallery.attr('data-is-mobile'))
, mouseWheelStep = 100
, touchStep = 100
, responsiveMode = 0
, tmpValue = 0
, self = this;
if(this.$container.data('gridType') == 4) {
return;
}
if (!horizontalScroll) {
return;
}
if(horizontalScroll) {
// if responsive mode = 'one by one' and mobile -> need to disable "responsive mode"
if(horizontalScroll.responsiveMode == 1 && isMobile) {
return;
}
if(horizontalScroll.mouseWheelStep) {
tmpValue = parseInt(horizontalScroll.mouseWheelStep);
if(!isNaN(tmpValue)) {
mouseWheelStep = tmpValue;
}
}
if(horizontalScroll.touchStep) {
tmpValue = parseInt(horizontalScroll.touchStep);
if(!isNaN(tmpValue)) {
touchStep = tmpValue;
}
}
}
//Calculate max-height and margin
if (!height) {
var elementsHeight = this.$container.find('.grid-gallery-caption>a').map(function() {
return $(this).height();
}).get(),
height = Math.max.apply(null, elementsHeight);
} else {
if(offset && offset > 0){
height = height + offset*2;
}
}
if (width === 'auto') {
this.$elements.each(function(index, el) {
var $figure = $(el),
$image = $figure.find('img');
sizes = self.getOriginalImageSizes($image.get(0));
$image.css('max-width', 'none');
if(!$image.hasClass('ggLazyImg'))
$figure.width(Math.floor((height / sizes.height) * sizes.width));
});
}
//Fixed IE9 scroll bug
var isIE9OrBelow = function() {
return /MSIE\s/.test(navigator.userAgent) && parseFloat(navigator.appVersion.split("MSIE")[1]) < 10;
}
if(isIE9OrBelow()){
this.$container.find('.grid-gallery-photos > *').css('display','table-cell');
} else {
this.$container.find('.grid-gallery-photos > *').css('display','inline-block');
}
this.$container.find('.grid-gallery-photos > *').css({
margin:0,
padding:0,
float: 'none',
animate: true,
'vertical-align': 'middle',
clear: 'right',
//'margin-right': '-5px',
'border': 'none',
'max-width': 'none',
});
this.$container.find('.grid-gallery-photos').css({
'font-size': 0,
});
this.$container.find('.grid-gallery-photos .grid-gallery-caption').css({
float: 'none',
'margin-left': 0,
});
// https://github.com/lanre-ade/jQuery-slimScroll
height = height + 7; //This is scrollbar height;
var slimScroll = this.$container.find('.grid-gallery-photos').slimScroll({
height: height,
width: 'auto',
railVisible: true,
alwaysVisible: true,
allowPageScroll: true,
axis: 'x',
animate: true,
color: horizontalScroll.color || '#000',
opacity:(100 - horizontalScroll.transparency) * 0.01,
'wheelStep': mouseWheelStep,
'touchScrollStep': touchStep,
'isMobile': isMobile,
'ggSlimscrollHandler': function() {
self.lazyLoadTriggerHandler();
},
});
// Load more height fix
if (slimScroll.height() < height) {
slimScroll.height(height);
slimScroll.parent().height(height);
}
});
Gallery.prototype.initHorizontalGalleryType = (function () {
if (this.$container.data('height') && String(this.$container.data('height')).indexOf('%') > -1) {
var height = this.$elements.first().height();
this.$elements.find('img').css({
'max-height': height,
'min-height': height,
});
}
var self = this;
setTimeout(function() {
self.resizeHorizontalElements();
}, 50);
});
Gallery.prototype.hidePreloader = function() {
var preloadEnab = this.$container.attr('data-preloader'),
preloader = this.$container.find('.gallery-loading'),
galleryPhotos = this.$container.find('.grid-gallery-photos');
preloader.hide();
if(preloadEnab !== '' && preloadEnab === 'true') {
setTimeout(function() {
galleryPhotos.show().fadeTo("slow", 1, function() {
galleryPhotos.css('opacity', '1');
});
}, 0);
} else {
galleryPhotos.show().fadeTo('fast', 1, function() {
galleryPhotos.css('opacity','1');
});
}
};
Gallery.prototype.showGalleryParts = function(){
this.$container.children('.hidden-item').removeClass('hidden-item');
};
Gallery.prototype.$getImagesFigureContainer = function(){
return this.$container.find('figure.grid-gallery-caption');
};
Gallery.prototype.initSocialSharing = function(){
if(!this.socialSharing || !this.socialSharing.enabled){
return;
}
var newUrl = encodeURIComponent(window.location.href);
var newTitle = encodeURIComponent(document.title);;
jQuery('.supSocialIcon').each(function() {
var $this = $(this);
var origUrl = $this.attr('originalurl');
var newUrl2 = origUrl.replace("{url}", newUrl);
newUrl2 = newUrl2.replace("{title}", newTitle);
newUrl2 = newUrl2.replace("{description}", newTitle);
$this.attr('href', newUrl2);
});
this.initGallerySocialSharing();
this.initImageSocialSharing();
};
Gallery.prototype.initGallerySocialSharing = function() {
var gallerySharing = this.socialSharing.gallerySharing;
if (!parseInt(gallerySharing.enabled)) {
return;
}
if (gallerySharing.position == 'top' || gallerySharing.position == 'all') {
this.$container.find('.gallery-sharing-top').fadeIn();
}
if (gallerySharing.position == 'bottom' || gallerySharing.position == 'all'){
this.$container.find('.gallery-sharing-bottom').fadeIn();
}
};
Gallery.prototype.initImageSocialSharing = function(){
var imageSharing = this.socialSharing.imageSharing;
if(!parseInt(imageSharing.enabled)){
return;
}
var btns = this.$container.find('.gallery-sharing-image').clone();
var $images = this.$getImagesFigureContainer(),
iconsEnabled = this.$container.data('icons');
$images.each(function() {
var $this = $(this),
$el;
var imgLink = jQuery($this).parent().attr('href');
btns.find('.supSocialIcon').each(function() {
var $thisBtn = $(this);
if ($thisBtn.hasClass('supSocialIconprint')) {
$thisBtn.attr('onClick','supSocialSharePrintImage("'+imgLink+'")');
}
});
if (!iconsEnabled) {
$el = $this.parent();
} else {
$el = $this.find('a.hi-icon');
}
$this.append(btns.html())
});
};
Gallery.prototype.addSocialShareToPopUp = function($element, $wrapper, addClass, fixed) {
if(!this.socialSharing.enabled || !parseInt(this.socialSharing.popupSharing.enabled)){
return;
}
var btns = this.$container.find('.gallery-sharing-popup').clone();
var newUrl = encodeURIComponent($element.get(0).baseURI);
var imgLink = $element.get(0).href;
var newTitle = jQuery($element.get(0)).attr('title');
btns.find('.supSocialIcon').each(function() {
var $this = $(this);
if ($this.hasClass('supSocialIconprint')) {
$this.attr('onClick','supSocialSharePrintImage("'+imgLink+'")');
}
$this.attr('title', newTitle);
var origUrl = $this.attr('originalurl');
var newUrl2 = origUrl.replace("{url}", newUrl);
newUrl2 = newUrl2.replace("{title}", newTitle);
newUrl2 = newUrl2.replace("{description}", newTitle);
$this.attr('href', newUrl2);
});
$wrapper.find('.supSocialIconsWrapper').remove();
$wrapper.append(btns.html());
};
// Gallery.prototype.initEvent = function($elements){
// $elements.find('.supsystic-social-sharing a.social-sharing-button').on('click',function (e) {
// if( !e ) e = window.event;
// e.preventDefault();
// e.stopPropagation();
// e.stopImmediatePropagation();
// $(document).trigger('ssSocialClick', this);
// if (e.currentTarget.href.slice(-1) !== '#') {
// window.open(e.currentTarget.href, 'mw' + e.timeStamp, 'left=20,top=20,width=500,height=500,toolbar=1,resizable=0');
// }
// var button = $(this)
// , figureWrapper = button.closest('.grid-gallery')
// , socialHtmlWrapper = figureWrapper.find('#social-share-html')
// // , socialHtmlWrapper = figureWrapper.find('.supsystic-social-sharing')
// , popupWrapper = socialHtmlWrapper.find('.supsystic-social-sharing-popup');
// if(button.hasClass('trigger-popup')){
// if(socialHtmlWrapper.css('display') === 'none'){
// socialHtmlWrapper.find('a').css('display', 'none');
// socialHtmlWrapper.css('display','block');
// popupWrapper.css('display','block');
// }else{
// socialHtmlWrapper.css('display','none');
// popupWrapper.css('display','none');
// }
// }
// if(button.closest('#pp_full_res').length){
// var buttonOverlayWrapper = button.closest('#pp_full_res')
// , buttonPopupWrapper = buttonOverlayWrapper.find('.supsystic-social-sharing-popup');
// if(buttonPopupWrapper.css('display') === 'none'){
// buttonPopupWrapper.css('display','block');
// }else{
// buttonPopupWrapper.css('display','none');
// }
// }
// $(document).on('click', function (e) {
// if( !e ) e = window.event;
// if (!$(e.target).is(".supsystic-social-sharing-popup")) {
// socialHtmlWrapper.css('display','none');
// popupWrapper.css('display','none');
// socialHtmlWrapper.find('a').css('display', 'block');
// }
// });
// });
// };
// Gallery.prototype.getSocialButtons = function(wrapper_class, url, img_id, img_src, title, noCounter) {
// title = title || '';
// var html = this.$container.find('#social-share-html').html();
// if (html !== undefined && html.length){
// html = html.replace(/{url}/g, url).replace(/{title}/g, title);
// if(noCounter) {
// // cut counter div
// html = html.replace(/