forked from extern/egroupware
170 lines
5.6 KiB
JavaScript
170 lines
5.6 KiB
JavaScript
/*
|
|
* blueimp Gallery Indicator JS 1.1.0
|
|
* https://github.com/blueimp/Gallery
|
|
*
|
|
* Copyright 2013, Sebastian Tschan
|
|
* https://blueimp.net
|
|
*
|
|
* Licensed under the MIT license:
|
|
* http://www.opensource.org/licenses/MIT
|
|
*/
|
|
|
|
/* global define, window, document */
|
|
|
|
(function (factory) {
|
|
'use strict';
|
|
if (typeof define === 'function' && define.amd) {
|
|
// Register as an anonymous AMD module:
|
|
define([
|
|
'./blueimp-helper',
|
|
'./blueimp-gallery'
|
|
], factory);
|
|
} else {
|
|
// Browser globals:
|
|
factory(
|
|
window.blueimp.helper || window.jQuery,
|
|
window.blueimp.Gallery
|
|
);
|
|
}
|
|
}(function ($, Gallery) {
|
|
'use strict';
|
|
|
|
$.extend(Gallery.prototype.options, {
|
|
// The tag name, Id, element or querySelector of the indicator container:
|
|
indicatorContainer: 'ol',
|
|
// The class for the active indicator:
|
|
activeIndicatorClass: 'active',
|
|
// The list object property (or data attribute) with the thumbnail URL,
|
|
// used as alternative to a thumbnail child element:
|
|
thumbnailProperty: 'thumbnail',
|
|
// Defines if the gallery indicators should display a thumbnail:
|
|
thumbnailIndicators: true,
|
|
// The tag name of thumbnails indicators
|
|
thumbnailsTagIndicators: 'li',
|
|
//thumbnail with image tag
|
|
thumbnailWithImgTag: false
|
|
});
|
|
|
|
var initSlides = Gallery.prototype.initSlides,
|
|
addSlide = Gallery.prototype.addSlide,
|
|
resetSlides = Gallery.prototype.resetSlides,
|
|
handleClick = Gallery.prototype.handleClick,
|
|
handleSlide = Gallery.prototype.handleSlide,
|
|
handleClose = Gallery.prototype.handleClose;
|
|
|
|
$.extend(Gallery.prototype, {
|
|
|
|
createIndicator: function (obj) {
|
|
var indicator = this.indicatorPrototype.cloneNode(this.options.thumbnailWithImgTag),
|
|
title = this.getItemProperty(obj, this.options.titleProperty),
|
|
thumbnailProperty = this.options.thumbnailProperty,
|
|
thumbnailUrl,
|
|
thumbnail;
|
|
if (this.options.thumbnailIndicators) {
|
|
thumbnail = obj.getElementsByTagName && $(obj).find('img')[0];
|
|
if (thumbnail) {
|
|
thumbnailUrl = thumbnail.src;
|
|
} else if (thumbnailProperty) {
|
|
thumbnailUrl = this.getItemProperty(obj, thumbnailProperty);
|
|
}
|
|
if (thumbnailUrl) {
|
|
if (this.options.thumbnailsTagIndicators == 'img')
|
|
{
|
|
indicator.src = thumbnailUrl;
|
|
}
|
|
else if (this.options.thumbnailWithImgTag)
|
|
{
|
|
indicator.children[0].src = thumbnailUrl;
|
|
}
|
|
else
|
|
{
|
|
indicator.style.backgroundImage = 'url("' + thumbnailUrl + '")';
|
|
}
|
|
}
|
|
}
|
|
if (title) {
|
|
indicator.title = title;
|
|
}
|
|
return indicator;
|
|
},
|
|
|
|
addIndicator: function (index) {
|
|
if (this.indicatorContainer.length) {
|
|
var indicator = this.createIndicator(this.list[index]);
|
|
indicator.setAttribute('data-index', index);
|
|
this.indicatorContainer[0].appendChild(indicator);
|
|
this.indicators.push(indicator);
|
|
}
|
|
},
|
|
|
|
setActiveIndicator: function (index) {
|
|
if (this.indicators) {
|
|
if (this.activeIndicator) {
|
|
this.activeIndicator
|
|
.removeClass(this.options.activeIndicatorClass);
|
|
}
|
|
this.activeIndicator = $(this.indicators[index]);
|
|
this.activeIndicator
|
|
.addClass(this.options.activeIndicatorClass);
|
|
}
|
|
},
|
|
|
|
initSlides: function (reload) {
|
|
if (!reload) {
|
|
this.indicatorContainer = this.container.find(
|
|
this.options.indicatorContainer
|
|
);
|
|
if (this.indicatorContainer.length) {
|
|
this.indicatorPrototype = document.createElement(this.options.thumbnailsTagIndicators);
|
|
if (this.options.thumbnailWithImgTag) this.indicatorPrototype.appendChild(document.createElement('img'));
|
|
this.indicators = this.indicatorContainer[0].children;
|
|
}
|
|
}
|
|
initSlides.call(this, reload);
|
|
},
|
|
|
|
addSlide: function (index) {
|
|
addSlide.call(this, index);
|
|
this.addIndicator(index);
|
|
},
|
|
|
|
resetSlides: function () {
|
|
resetSlides.call(this);
|
|
this.indicatorContainer.empty();
|
|
this.indicators = [];
|
|
},
|
|
|
|
handleClick: function (event) {
|
|
var target = event.target || event.srcElement,
|
|
parent = target.parentNode;
|
|
if (parent === this.indicatorContainer[0]) {
|
|
// Click on indicator element
|
|
this.preventDefault(event);
|
|
this.slide(this.getNodeIndex(target));
|
|
} else if (parent.parentNode === this.indicatorContainer[0]) {
|
|
// Click on indicator child element
|
|
this.preventDefault(event);
|
|
this.slide(this.getNodeIndex(parent));
|
|
} else {
|
|
return handleClick.call(this, event);
|
|
}
|
|
},
|
|
|
|
handleSlide: function (index) {
|
|
handleSlide.call(this, index);
|
|
this.setActiveIndicator(index);
|
|
},
|
|
|
|
handleClose: function () {
|
|
if (this.activeIndicator) {
|
|
this.activeIndicator
|
|
.removeClass(this.options.activeIndicatorClass);
|
|
}
|
|
handleClose.call(this);
|
|
}
|
|
|
|
});
|
|
|
|
return Gallery;
|
|
}));
|