Вход Регистрация
Файл: oc-includes/osclass/gui/js/fancybox/helpers/jquery.fancybox-thumbs.js
Строк: 99
<?php
/*!
 * Thumbnail helper for fancyBox
 * version: 1.0.2
 * @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 = $.fancybox;

    
//Add helper object
    
F.helpers.thumbs = {
        
wrapnull,
        list: 
null,
        
width0,

        
//Default function to obtain the URL of the thumbnail image
        
source: function (el) {
            var 
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 
0F.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 || '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,
                        
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({
                        
widthwidth,
                        
heightheight,
                        
topMath.floor(thumbHeight height 2),
                        
leftMath.floor(thumbWidth width 2)
                    });

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

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

                }).
attr('src'thumbSource(this));
            });

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

            
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.marginopts.position === 'top' ] = 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));
?>
Онлайн: 1
Реклама