Вход Регистрация
Файл: Source/assets/fancybox/source/helpers/jquery.fancybox-thumbs.js
Строк: 91
<?php
/*!
 * Thumbnail helper for fancyBox
 * version: 1.0.7 (Mon, 01 Oct 2012)
 * @requires fancyBox v2.0 or later
 *
 * Usage:
 *     $(".fancybox").fancybox({
 *         helpers : {
 *             thumbs: {
 *                 width  : 50,
 *                 height : 50
 *             }
 *         }
 *     });
 *
 */
(function ($) {
    
//Shortcut for fancyBox object
    
var = $.fancybox;

    
//Add helper object
    
F.helpers.thumbs = {
        
defaults : {
            
width    50,       // thumbnail width
            
height   50,       // thumbnail height
            
position 'bottom'// 'top' or 'bottom'
            
source   : function ( item ) {  // function to obtain the URL of the thumbnail image
                
var href;

                if (
item.element) {
                    
href = $(item.element).find('img').attr('src');
                }

                if (!
href && item.type === 'image' && item.href) {
                    
href item.href;
                }

                return 
href;
            }
        },

        
wrap  null,
        list  : 
null,
        
width 0,

        
init: function (optsobj) {
            var 
that this,
                list,
                
thumbWidth  opts.width,
                
thumbHeight opts.height,
                
thumbSource opts.source;

            
//Build list structure
            
list = '';

            for (var 
0obj.group.lengthn++) {
                list += 
'<li><a style="width:' thumbWidth 'px;height:' thumbHeight 'px;" href="javascript:jQuery.fancybox.jumpto(' ');"></a></li>';
            }

            
this.wrap = $('<div id="fancybox-thumbs"></div>').addClass(opts.position).appendTo('body');
            
this.list = $('<ul>' + list + '</ul>').appendTo(this.wrap);

            
//Load each thumbnail
            
$.each(obj.group, function (i) {
                var 
href thumbSourceobj.group] );

                if (!
href) {
                    return;
                }

                $(
"<img />").load(function () {
                    var 
width  this.width,
                        
height this.height,
                        
widthRatioheightRatioparent;

                    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 >= && 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 height 2),
                        
left   Math.floor(thumbWidth width 2)
                    });

                    
parent.width(thumbWidth).height(thumbHeight);

                    $(
this).hide().appendTo(parent).fadeIn(300);

                }).
attr('src'href);
            });

            
//Set initial width
            
this.width this.list.children().eq(0).outerWidth(true);

            
this.list.width(this.width * (obj.group.length 1)).css('left'Math.floor($(window).width() * 0.5 - (obj.index this.width this.width 0.5)));
        },

        
beforeLoad: function (optsobj) {
            
//Remove self if gallery do not have at least two items
            
if (obj.group.length 2) {
                
obj.helpers.thumbs false;

                return;
            }

            
//Increase bottom margin to give space for thumbs
            
obj.marginopts.position === 'top' ] += ((opts.height) + 15);
        },

        
afterShow: function (optsobj) {
            
//Check if exists and create or update list
            
if (this.list) {
                
this.onUpdate(optsobj);

            } else {
                
this.init(optsobj);
            }

            
//Set active element
            
this.list.children().removeClass('active').eq(obj.index).addClass('active');
        },

        
//Center list
        
onUpdate: function (optsobj) {
            if (
this.list) {
                
this.list.stop(true).animate({
                    
'left'Math.floor($(window).width() * 0.5 - (obj.index this.width this.width 0.5))
                }, 
150);
            }
        },

        
beforeClose: function () {
            if (
this.wrap) {
                
this.wrap.remove();
            }

            
this.wrap  null;
            
this.list  = null;
            
this.width 0;
        }
    }

}(
jQuery));
?>
Онлайн: 1
Реклама