123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- /*!
- * Thumbnail helper for fancyBox
- * version: 1.0.4
- * @requires fancyBox v2.0 or later
- *
- * Usage:
- * $(".fancybox").fancybox({
- * thumbs: {
- * width : 50,
- * height : 50
- * }
- * });
- *
- * Options:
- * width - thumbnail width
- * height - thumbnail height
- * source - function to obtain the URL of the thumbnail image
- * position - 'top' or 'bottom'
- *
- */
- (function ($) {
- //Shortcut for fancyBox object
- var F = $.fancybox;
- //Add helper object
- F.helpers.thumbs = {
- wrap: null,
- list: null,
- width: 0,
- //Default function to obtain the URL of the thumbnail image
- source: function (el) {
- var img;
- if ($.type(el) === 'string') {
- return el;
- }
- img = $(el).find('img');
- return img.length ? img.attr('src') : el.href;
- },
- init: function (opts) {
- var that = this,
- list,
- thumbWidth = opts.width || 50,
- thumbHeight = opts.height || 50,
- thumbSource = opts.source || this.source;
- //Build list structure
- list = '';
- for (var n = 0; n < F.group.length; n++) {
- list += '<li><a style="width:' + thumbWidth + 'px;height:' + thumbHeight + 'px;" href="javascript:jQuery.fancybox.jumpto(' + n + ');"></a></li>';
- }
- this.wrap = $('<div id="fancybox-thumbs"></div>').addClass(opts.position || 'bottom').appendTo('body');
- this.list = $('<ul>' + list + '</ul>').appendTo(this.wrap);
- //Load each thumbnail
- $.each(F.group, function (i) {
- $("<img />").load(function () {
- var width = this.width,
- height = this.height,
- widthRatio, heightRatio, parent;
- if (!that.list || !width || !height) {
- return;
- }
- //Calculate thumbnail width/height and center it
- widthRatio = width / thumbWidth;
- heightRatio = height / thumbHeight;
- parent = that.list.children().eq(i).find('a');
- if (widthRatio >= 1 && heightRatio >= 1) {
- if (widthRatio > heightRatio) {
- width = Math.floor(width / heightRatio);
- height = thumbHeight;
- } else {
- width = thumbWidth;
- height = Math.floor(height / widthRatio);
- }
- }
- $(this).css({
- width: width,
- height: height,
- top: Math.floor(thumbHeight / 2 - height / 2),
- left: Math.floor(thumbWidth / 2 - width / 2)
- });
- parent.width(thumbWidth).height(thumbHeight);
- $(this).hide().appendTo(parent).fadeIn(300);
- }).attr('src', thumbSource( F.group[ i ] ));
- });
- //Set initial width
- this.width = this.list.children().eq(0).outerWidth(true);
- this.list.width(this.width * (F.group.length + 1)).css('left', Math.floor($(window).width() * 0.5 - (F.current.index * this.width + this.width * 0.5)));
- },
- //Center list
- update: function (opts) {
- if (this.list) {
- this.list.stop(true).animate({
- 'left': Math.floor($(window).width() * 0.5 - (F.current.index * this.width + this.width * 0.5))
- }, 150);
- }
- },
- beforeLoad: function (opts) {
- //Remove self if gallery do not have at least two items
- if (F.group.length < 2) {
- F.coming.helpers.thumbs = false;
- return;
- }
- //Increase bottom margin to give space for thumbs
- F.coming.margin[ opts.position === 'top' ? 0 : 2 ] = opts.height + 30;
- },
- afterShow: function (opts) {
- //Check if exists and create or update list
- if (this.list) {
- this.update(opts);
- } else {
- this.init(opts);
- }
- //Set active element
- this.list.children().removeClass('active').eq(F.current.index).addClass('active');
- },
- onUpdate: function () {
- this.update();
- },
- beforeClose: function () {
- if (this.wrap) {
- this.wrap.remove();
- }
- this.wrap = null;
- this.list = null;
- this.width = 0;
- }
- }
- }(jQuery));
|