bgneal@106
|
1 /*!
|
bgneal@106
|
2 * Thumbnail helper for fancyBox
|
bgneal@106
|
3 * version: 1.0.7 (Mon, 01 Oct 2012)
|
bgneal@106
|
4 * @requires fancyBox v2.0 or later
|
bgneal@106
|
5 *
|
bgneal@106
|
6 * Usage:
|
bgneal@106
|
7 * $(".fancybox").fancybox({
|
bgneal@106
|
8 * helpers : {
|
bgneal@106
|
9 * thumbs: {
|
bgneal@106
|
10 * width : 50,
|
bgneal@106
|
11 * height : 50
|
bgneal@106
|
12 * }
|
bgneal@106
|
13 * }
|
bgneal@106
|
14 * });
|
bgneal@106
|
15 *
|
bgneal@106
|
16 */
|
bgneal@106
|
17 (function ($) {
|
bgneal@106
|
18 //Shortcut for fancyBox object
|
bgneal@106
|
19 var F = $.fancybox;
|
bgneal@106
|
20
|
bgneal@106
|
21 //Add helper object
|
bgneal@106
|
22 F.helpers.thumbs = {
|
bgneal@106
|
23 defaults : {
|
bgneal@106
|
24 width : 50, // thumbnail width
|
bgneal@106
|
25 height : 50, // thumbnail height
|
bgneal@106
|
26 position : 'bottom', // 'top' or 'bottom'
|
bgneal@106
|
27 source : function ( item ) { // function to obtain the URL of the thumbnail image
|
bgneal@106
|
28 var href;
|
bgneal@106
|
29
|
bgneal@106
|
30 if (item.element) {
|
bgneal@106
|
31 href = $(item.element).find('img').attr('src');
|
bgneal@106
|
32 }
|
bgneal@106
|
33
|
bgneal@106
|
34 if (!href && item.type === 'image' && item.href) {
|
bgneal@106
|
35 href = item.href;
|
bgneal@106
|
36 }
|
bgneal@106
|
37
|
bgneal@106
|
38 return href;
|
bgneal@106
|
39 }
|
bgneal@106
|
40 },
|
bgneal@106
|
41
|
bgneal@106
|
42 wrap : null,
|
bgneal@106
|
43 list : null,
|
bgneal@106
|
44 width : 0,
|
bgneal@106
|
45
|
bgneal@106
|
46 init: function (opts, obj) {
|
bgneal@106
|
47 var that = this,
|
bgneal@106
|
48 list,
|
bgneal@106
|
49 thumbWidth = opts.width,
|
bgneal@106
|
50 thumbHeight = opts.height,
|
bgneal@106
|
51 thumbSource = opts.source;
|
bgneal@106
|
52
|
bgneal@106
|
53 //Build list structure
|
bgneal@106
|
54 list = '';
|
bgneal@106
|
55
|
bgneal@106
|
56 for (var n = 0; n < obj.group.length; n++) {
|
bgneal@106
|
57 list += '<li><a style="width:' + thumbWidth + 'px;height:' + thumbHeight + 'px;" href="javascript:jQuery.fancybox.jumpto(' + n + ');"></a></li>';
|
bgneal@106
|
58 }
|
bgneal@106
|
59
|
bgneal@106
|
60 this.wrap = $('<div id="fancybox-thumbs"></div>').addClass(opts.position).appendTo('body');
|
bgneal@106
|
61 this.list = $('<ul>' + list + '</ul>').appendTo(this.wrap);
|
bgneal@106
|
62
|
bgneal@106
|
63 //Load each thumbnail
|
bgneal@106
|
64 $.each(obj.group, function (i) {
|
bgneal@106
|
65 var href = thumbSource( obj.group[ i ] );
|
bgneal@106
|
66
|
bgneal@106
|
67 if (!href) {
|
bgneal@106
|
68 return;
|
bgneal@106
|
69 }
|
bgneal@106
|
70
|
bgneal@106
|
71 $("<img />").load(function () {
|
bgneal@106
|
72 var width = this.width,
|
bgneal@106
|
73 height = this.height,
|
bgneal@106
|
74 widthRatio, heightRatio, parent;
|
bgneal@106
|
75
|
bgneal@106
|
76 if (!that.list || !width || !height) {
|
bgneal@106
|
77 return;
|
bgneal@106
|
78 }
|
bgneal@106
|
79
|
bgneal@106
|
80 //Calculate thumbnail width/height and center it
|
bgneal@106
|
81 widthRatio = width / thumbWidth;
|
bgneal@106
|
82 heightRatio = height / thumbHeight;
|
bgneal@106
|
83
|
bgneal@106
|
84 parent = that.list.children().eq(i).find('a');
|
bgneal@106
|
85
|
bgneal@106
|
86 if (widthRatio >= 1 && heightRatio >= 1) {
|
bgneal@106
|
87 if (widthRatio > heightRatio) {
|
bgneal@106
|
88 width = Math.floor(width / heightRatio);
|
bgneal@106
|
89 height = thumbHeight;
|
bgneal@106
|
90
|
bgneal@106
|
91 } else {
|
bgneal@106
|
92 width = thumbWidth;
|
bgneal@106
|
93 height = Math.floor(height / widthRatio);
|
bgneal@106
|
94 }
|
bgneal@106
|
95 }
|
bgneal@106
|
96
|
bgneal@106
|
97 $(this).css({
|
bgneal@106
|
98 width : width,
|
bgneal@106
|
99 height : height,
|
bgneal@106
|
100 top : Math.floor(thumbHeight / 2 - height / 2),
|
bgneal@106
|
101 left : Math.floor(thumbWidth / 2 - width / 2)
|
bgneal@106
|
102 });
|
bgneal@106
|
103
|
bgneal@106
|
104 parent.width(thumbWidth).height(thumbHeight);
|
bgneal@106
|
105
|
bgneal@106
|
106 $(this).hide().appendTo(parent).fadeIn(300);
|
bgneal@106
|
107
|
bgneal@106
|
108 }).attr('src', href);
|
bgneal@106
|
109 });
|
bgneal@106
|
110
|
bgneal@106
|
111 //Set initial width
|
bgneal@106
|
112 this.width = this.list.children().eq(0).outerWidth(true);
|
bgneal@106
|
113
|
bgneal@106
|
114 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)));
|
bgneal@106
|
115 },
|
bgneal@106
|
116
|
bgneal@106
|
117 beforeLoad: function (opts, obj) {
|
bgneal@106
|
118 //Remove self if gallery do not have at least two items
|
bgneal@106
|
119 if (obj.group.length < 2) {
|
bgneal@106
|
120 obj.helpers.thumbs = false;
|
bgneal@106
|
121
|
bgneal@106
|
122 return;
|
bgneal@106
|
123 }
|
bgneal@106
|
124
|
bgneal@106
|
125 //Increase bottom margin to give space for thumbs
|
bgneal@106
|
126 obj.margin[ opts.position === 'top' ? 0 : 2 ] += ((opts.height) + 15);
|
bgneal@106
|
127 },
|
bgneal@106
|
128
|
bgneal@106
|
129 afterShow: function (opts, obj) {
|
bgneal@106
|
130 //Check if exists and create or update list
|
bgneal@106
|
131 if (this.list) {
|
bgneal@106
|
132 this.onUpdate(opts, obj);
|
bgneal@106
|
133
|
bgneal@106
|
134 } else {
|
bgneal@106
|
135 this.init(opts, obj);
|
bgneal@106
|
136 }
|
bgneal@106
|
137
|
bgneal@106
|
138 //Set active element
|
bgneal@106
|
139 this.list.children().removeClass('active').eq(obj.index).addClass('active');
|
bgneal@106
|
140 },
|
bgneal@106
|
141
|
bgneal@106
|
142 //Center list
|
bgneal@106
|
143 onUpdate: function (opts, obj) {
|
bgneal@106
|
144 if (this.list) {
|
bgneal@106
|
145 this.list.stop(true).animate({
|
bgneal@106
|
146 'left': Math.floor($(window).width() * 0.5 - (obj.index * this.width + this.width * 0.5))
|
bgneal@106
|
147 }, 150);
|
bgneal@106
|
148 }
|
bgneal@106
|
149 },
|
bgneal@106
|
150
|
bgneal@106
|
151 beforeClose: function () {
|
bgneal@106
|
152 if (this.wrap) {
|
bgneal@106
|
153 this.wrap.remove();
|
bgneal@106
|
154 }
|
bgneal@106
|
155
|
bgneal@106
|
156 this.wrap = null;
|
bgneal@106
|
157 this.list = null;
|
bgneal@106
|
158 this.width = 0;
|
bgneal@106
|
159 }
|
bgneal@106
|
160 }
|
bgneal@106
|
161
|
bgneal@106
|
162 }(jQuery)); |