lightbox2-rails 2.7.1 → 2.8.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 7a67988d020cae69618153abad54fc507dbf0067
4
- data.tar.gz: e098b0d7683a66a03754d4f848bcf5ea3b243942
3
+ metadata.gz: 41d269c9d0d7a48a4d35abb45166ac601f4867f8
4
+ data.tar.gz: b3bb6321cf086d445078abccd10614cb9ecfdce8
5
5
  SHA512:
6
- metadata.gz: 3efc54e397d4c4e6631e1dbe998b5a6c1c782e1e197fa074f8710cd016ff0c9becec80f9a4a990b79a2ab20bf607e4c561633c20f70bd517c5949109acc92363
7
- data.tar.gz: f4ae1e35fe397f392ac036357af86c3699ff8696ba5ba51daea41340ace4fa3ba4da2a90cad7bd04e375746ff387ba723079cba3764deddc562f61ec386b670f
6
+ metadata.gz: 848d16ce55eeded42d818bbfb2f69b866668ab00b203046c26d296e8fa33d01a8d382fede1fa03e36160cf38600d3c615fc6231eb893e1af924262b6e7a3a514
7
+ data.tar.gz: 34b643a0b3f44bf084120483e3b265aeae9895d0c9a6040ba336b5c11d77b373ba173a86577394706c2a9ef29a19fd16e5472f8fe6b2741e88e2a732fadee57e
data/README.md CHANGED
@@ -1,36 +1,61 @@
1
- # lightbox2-rails
1
+ # :stars: lightbox2-rails
2
2
 
3
- [Lightbox2](http://lokeshdhakar.com/projects/lightbox2) for Rails asset pipeline
4
-
5
- Lightbox2 version: 2.7.1
6
-
7
- ## Installation
3
+ [![Gem Version](http://img.shields.io/gem/v/lightbox2-rails.svg)](https://rubygems.org/gems/lightbox2-rails)
4
+ [![Gem Downloads](https://img.shields.io/gem/dt/lightbox2-rails.svg)](https://rubygems.org/gems/lightbox2-rails)
8
5
 
9
- Add to your `Gemfile` and install with bundler:
10
-
11
- ```ruby
12
- gem 'lightbox2-rails'
13
- ```
14
-
15
- Add to your `config/initializers/assets.rb` in order to have the images for lightbox precompiled:
16
- ```ruby
17
- Rails.application.config.assets.precompile += %w( lightbox/* )
18
- ```
6
+ [Lightbox2](http://lokeshdhakar.com/projects/lightbox2) for Rails asset pipeline
19
7
 
20
- Require the Lightbox2 javascript file in `app/assets/javascripts/application.js`:
8
+ - Modified for [Turbolinks](https://github.com/rails/turbolinks) and [Sprockets](https://github.com/sstephenson/sprockets)' asset digests compatibility
21
9
 
22
- ```js
23
- //= require lightbox
24
- ```
10
+ - Lightbox2 version: [2.8.2](https://github.com/lokesh/lightbox2/releases/tag/v2.8.2)
25
11
 
26
- Require the modified Lightbox2 css file in `app/assets/stylesheets/application.css`:
12
+ ## Installation
27
13
 
28
- ```css
29
- *= require lightbox
30
- ```
14
+ 1. Add to your `Gemfile` and install with bundler:
15
+
16
+ ```ruby
17
+ gem 'lightbox2-rails'
18
+ ```
19
+
20
+ ```bash
21
+ bundle install
22
+ ```
23
+
24
+ 2. Add to your `config/initializers/assets.rb` in order to have the images for lightbox precompiled:
25
+
26
+ ```ruby
27
+ Rails.application.config.assets.precompile += %w( lightbox/* )
28
+ ```
29
+
30
+ 3. Require the modified Lightbox2 javascript file in `app/assets/javascripts/application.js`:
31
+
32
+ ```js
33
+ //= require lightbox
34
+ ```
35
+
36
+ Or in `app/assets/javascripts/application.js.coffee`:
37
+
38
+ ```coffeescript
39
+ #= require lightbox
40
+ ```
41
+
42
+ 4. Require the modified Lightbox2 css file in `app/assets/stylesheets/application.css`:
43
+
44
+ ```css
45
+ *= require lightbox
46
+ ```
47
+ Or in `app/assets/javascripts/application.css.scss` / `app/assets/javascripts/application.css.sass`:
48
+
49
+ ```scss
50
+ @import lightbox;
51
+ ```
52
+
53
+ ```sass
54
+ @import lightbox
55
+ ```
31
56
 
32
57
  ## Acknowledgements
33
58
 
34
59
  [Lightbox2](http://lokeshdhakar.com/projects/lightbox2) created by Lokesh Dhakar, licensed under the [Creative Commons Attribution 2.5 License](http://creativecommons.org/licenses/by/2.5/)
35
60
 
36
- Copyright [Gavin Lam](http://gavin.hk), released under the MIT License.
61
+ Copyright [Gavin Lam](https://www.gavin.hk), released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  module Lightbox2
2
2
  module Rails
3
- VERSION = '2.7.1'
3
+ VERSION = '2.8.2'
4
4
  end
5
5
  end
@@ -1,411 +1,453 @@
1
- /**
2
- * Lightbox v2.7.1
3
- * by Lokesh Dhakar - http://lokeshdhakar.com/projects/lightbox2/
1
+ /*!
2
+ * Lightbox v2.8.2
3
+ * by Lokesh Dhakar
4
4
  *
5
- * @license http://creativecommons.org/licenses/by/2.5/
6
- * - Free for use in both personal and commercial projects
7
- * - Attribution requires leaving author name, author link, and the license info intact
5
+ * More info:
6
+ * http://lokeshdhakar.com/projects/lightbox2/
7
+ *
8
+ * Copyright 2007, 2015 Lokesh Dhakar
9
+ * Released under the MIT license
10
+ * https://github.com/lokesh/lightbox2/blob/master/LICENSE
8
11
  */
9
12
 
10
- (function() {
11
- // Use local alias
12
- var $ = jQuery;
13
-
14
- var LightboxOptions = (function() {
15
- function LightboxOptions() {
16
- this.fadeDuration = 500;
17
- this.fitImagesInViewport = true;
18
- this.resizeDuration = 700;
19
- this.positionFromTop = 50;
20
- this.showImageNumberLabel = true;
21
- this.alwaysShowNavOnTouchDevices = false;
22
- this.wrapAround = false;
23
- }
24
-
25
- // Change to localize to non-english language
26
- LightboxOptions.prototype.albumLabel = function(curImageNum, albumSize) {
27
- return "Image " + curImageNum + " of " + albumSize;
28
- };
13
+ // Uses Node, AMD or browser globals to create a module.
14
+ (function (root, factory) {
15
+ if (typeof define === 'function' && define.amd) {
16
+ // AMD. Register as an anonymous module.
17
+ define(['jquery'], factory);
18
+ } else if (typeof exports === 'object') {
19
+ // Node. Does not work with strict CommonJS, but
20
+ // only CommonJS-like environments that support module.exports,
21
+ // like Node.
22
+ module.exports = factory(require('jquery'));
23
+ } else {
24
+ // Browser globals (root is window)
25
+ root.lightbox = factory(root.jQuery);
26
+ }
27
+ }(this, function ($) {
28
+
29
+ function Lightbox(options) {
30
+ this.album = [];
31
+ this.currentImageIndex = void 0;
32
+ this.init();
33
+
34
+ // options
35
+ this.options = $.extend({}, this.constructor.defaults);
36
+ this.option(options);
37
+ }
38
+
39
+ // Descriptions of all options available on the demo site:
40
+ // http://lokeshdhakar.com/projects/lightbox2/index.html#options
41
+ Lightbox.defaults = {
42
+ albumLabel: 'Image %1 of %2',
43
+ alwaysShowNavOnTouchDevices: false,
44
+ fadeDuration: 500,
45
+ fitImagesInViewport: true,
46
+ // maxWidth: 800,
47
+ // maxHeight: 600,
48
+ positionFromTop: 50,
49
+ resizeDuration: 700,
50
+ showImageNumberLabel: true,
51
+ wrapAround: false,
52
+ disableScrolling: false
53
+ };
54
+
55
+ Lightbox.prototype.option = function(options) {
56
+ $.extend(this.options, options);
57
+ };
58
+
59
+ Lightbox.prototype.imageCountLabel = function(currentImageNum, totalImages) {
60
+ return this.options.albumLabel.replace(/%1/g, currentImageNum).replace(/%2/g, totalImages);
61
+ };
62
+
63
+ Lightbox.prototype.init = function() {
64
+ this.enable();
65
+ this.build();
66
+ };
67
+
68
+ // Loop through anchors and areamaps looking for either data-lightbox attributes or rel attributes
69
+ // that contain 'lightbox'. When these are clicked, start lightbox.
70
+ Lightbox.prototype.enable = function() {
71
+ var self = this;
72
+ $('body').on('click', 'a[rel^=lightbox], area[rel^=lightbox], a[data-lightbox], area[data-lightbox]', function(event) {
73
+ self.start($(event.currentTarget));
74
+ return false;
75
+ });
76
+ };
77
+
78
+ // Build html for the lightbox and the overlay.
79
+ // Attach event handlers to the new DOM elements. click click click
80
+ Lightbox.prototype.build = function() {
81
+ var self = this;
82
+ $('<div id="lightboxOverlay" class="lightboxOverlay"></div><div id="lightbox" class="lightbox"><div class="lb-outerContainer"><div class="lb-container"><img class="lb-image" src="" /><div class="lb-nav"><a class="lb-prev" href="" ></a><a class="lb-next" href="" ></a></div><div class="lb-loader"><a class="lb-cancel"></a></div></div></div><div class="lb-dataContainer"><div class="lb-data"><div class="lb-details"><span class="lb-caption"></span><span class="lb-number"></span></div><div class="lb-closeContainer"><a class="lb-close"></a></div></div></div></div>').appendTo($('body'));
83
+
84
+ // Cache jQuery objects
85
+ this.$lightbox = $('#lightbox');
86
+ this.$overlay = $('#lightboxOverlay');
87
+ this.$outerContainer = this.$lightbox.find('.lb-outerContainer');
88
+ this.$container = this.$lightbox.find('.lb-container');
89
+
90
+ // Store css values for future lookup
91
+ this.containerTopPadding = parseInt(this.$container.css('padding-top'), 10);
92
+ this.containerRightPadding = parseInt(this.$container.css('padding-right'), 10);
93
+ this.containerBottomPadding = parseInt(this.$container.css('padding-bottom'), 10);
94
+ this.containerLeftPadding = parseInt(this.$container.css('padding-left'), 10);
95
+
96
+ // Attach event handlers to the newly minted DOM elements
97
+ this.$overlay.hide().on('click', function() {
98
+ self.end();
99
+ return false;
100
+ });
101
+
102
+ this.$lightbox.hide().on('click', function(event) {
103
+ if ($(event.target).attr('id') === 'lightbox') {
104
+ self.end();
105
+ }
106
+ return false;
107
+ });
29
108
 
30
- return LightboxOptions;
31
- })();
109
+ this.$outerContainer.on('click', function(event) {
110
+ if ($(event.target).attr('id') === 'lightbox') {
111
+ self.end();
112
+ }
113
+ return false;
114
+ });
32
115
 
116
+ this.$lightbox.find('.lb-prev').on('click', function() {
117
+ if (self.currentImageIndex === 0) {
118
+ self.changeImage(self.album.length - 1);
119
+ } else {
120
+ self.changeImage(self.currentImageIndex - 1);
121
+ }
122
+ return false;
123
+ });
33
124
 
34
- var Lightbox = (function() {
35
- function Lightbox(options) {
36
- this.options = options;
37
- this.album = [];
38
- this.currentImageIndex = void 0;
39
- this.init();
40
- }
125
+ this.$lightbox.find('.lb-next').on('click', function() {
126
+ if (self.currentImageIndex === self.album.length - 1) {
127
+ self.changeImage(0);
128
+ } else {
129
+ self.changeImage(self.currentImageIndex + 1);
130
+ }
131
+ return false;
132
+ });
41
133
 
42
- Lightbox.prototype.init = function() {
43
- this.enable();
44
- this.build();
45
- };
134
+ this.$lightbox.find('.lb-loader, .lb-close').on('click', function() {
135
+ self.end();
136
+ return false;
137
+ });
138
+ };
46
139
 
47
- // Loop through anchors and areamaps looking for either data-lightbox attributes or rel attributes
48
- // that contain 'lightbox'. When these are clicked, start lightbox.
49
- Lightbox.prototype.enable = function() {
50
- var self = this;
51
- $('body').on('click', 'a[rel^=lightbox], area[rel^=lightbox], a[data-lightbox], area[data-lightbox]', function(event) {
52
- self.start($(event.currentTarget));
53
- return false;
54
- });
55
- };
140
+ // Show overlay and lightbox. If the image is part of a set, add siblings to album array.
141
+ Lightbox.prototype.start = function($link) {
142
+ var self = this;
143
+ var $window = $(window);
56
144
 
57
- // Build html for the lightbox and the overlay.
58
- // Attach event handlers to the new DOM elements. click click click
59
- Lightbox.prototype.build = function() {
60
- var self = this;
61
- $("<div id='lightboxOverlay' class='lightboxOverlay'></div><div id='lightbox' class='lightbox'><div class='lb-outerContainer'><div class='lb-container'><img class='lb-image' src='' /><div class='lb-nav'><a class='lb-prev' href='' ></a><a class='lb-next' href='' ></a></div><div class='lb-loader'><a class='lb-cancel'></a></div></div></div><div class='lb-dataContainer'><div class='lb-data'><div class='lb-details'><span class='lb-caption'></span><span class='lb-number'></span></div><div class='lb-closeContainer'><a class='lb-close'></a></div></div></div></div>").appendTo($('body'));
62
-
63
- // Cache jQuery objects
64
- this.$lightbox = $('#lightbox');
65
- this.$overlay = $('#lightboxOverlay');
66
- this.$outerContainer = this.$lightbox.find('.lb-outerContainer');
67
- this.$container = this.$lightbox.find('.lb-container');
68
-
69
- // Store css values for future lookup
70
- this.containerTopPadding = parseInt(this.$container.css('padding-top'), 10);
71
- this.containerRightPadding = parseInt(this.$container.css('padding-right'), 10);
72
- this.containerBottomPadding = parseInt(this.$container.css('padding-bottom'), 10);
73
- this.containerLeftPadding = parseInt(this.$container.css('padding-left'), 10);
74
-
75
- // Attach event handlers to the newly minted DOM elements
76
- this.$overlay.hide().on('click', function() {
77
- self.end();
78
- return false;
79
- });
145
+ $window.on('resize', $.proxy(this.sizeOverlay, this));
80
146
 
81
- this.$lightbox.hide().on('click', function(event) {
82
- if ($(event.target).attr('id') === 'lightbox') {
83
- self.end();
84
- }
85
- return false;
86
- });
147
+ $('select, object, embed').css({
148
+ visibility: 'hidden'
149
+ });
87
150
 
88
- this.$outerContainer.on('click', function(event) {
89
- if ($(event.target).attr('id') === 'lightbox') {
90
- self.end();
91
- }
92
- return false;
93
- });
151
+ this.sizeOverlay();
94
152
 
95
- this.$lightbox.find('.lb-prev').on('click', function() {
96
- if (self.currentImageIndex === 0) {
97
- self.changeImage(self.album.length - 1);
98
- } else {
99
- self.changeImage(self.currentImageIndex - 1);
100
- }
101
- return false;
153
+ this.album = [];
154
+ var imageNumber = 0;
155
+
156
+ function addToAlbum($link) {
157
+ self.album.push({
158
+ link: $link.attr('href'),
159
+ title: $link.attr('data-title') || $link.attr('title')
102
160
  });
161
+ }
103
162
 
104
- this.$lightbox.find('.lb-next').on('click', function() {
105
- if (self.currentImageIndex === self.album.length - 1) {
106
- self.changeImage(0);
107
- } else {
108
- self.changeImage(self.currentImageIndex + 1);
163
+ // Support both data-lightbox attribute and rel attribute implementations
164
+ var dataLightboxValue = $link.attr('data-lightbox');
165
+ var $links;
166
+
167
+ if (dataLightboxValue) {
168
+ $links = $($link.prop('tagName') + '[data-lightbox="' + dataLightboxValue + '"]');
169
+ for (var i = 0; i < $links.length; i = ++i) {
170
+ addToAlbum($($links[i]));
171
+ if ($links[i] === $link[0]) {
172
+ imageNumber = i;
109
173
  }
110
- return false;
111
- });
174
+ }
175
+ } else {
176
+ if ($link.attr('rel') === 'lightbox') {
177
+ // If image is not part of a set
178
+ addToAlbum($link);
179
+ } else {
180
+ // If image is part of a set
181
+ $links = $($link.prop('tagName') + '[rel="' + $link.attr('rel') + '"]');
182
+ for (var j = 0; j < $links.length; j = ++j) {
183
+ addToAlbum($($links[j]));
184
+ if ($links[j] === $link[0]) {
185
+ imageNumber = j;
186
+ }
187
+ }
188
+ }
189
+ }
112
190
 
113
- this.$lightbox.find('.lb-loader, .lb-close').on('click', function() {
114
- self.end();
115
- return false;
116
- });
117
- };
191
+ // Position Lightbox
192
+ var top = $window.scrollTop() + this.options.positionFromTop;
193
+ var left = $window.scrollLeft();
194
+ this.$lightbox.css({
195
+ top: top + 'px',
196
+ left: left + 'px'
197
+ }).fadeIn(this.options.fadeDuration);
198
+
199
+ // Disable scrolling of the page while open
200
+ if (this.options.disableScrolling) {
201
+ $('body').addClass('lb-disable-scrolling');
202
+ }
118
203
 
119
- // Show overlay and lightbox. If the image is part of a set, add siblings to album array.
120
- Lightbox.prototype.start = function($link) {
121
- var self = this;
122
- var $window = $(window);
204
+ this.changeImage(imageNumber);
205
+ };
123
206
 
124
- $window.on('resize', $.proxy(this.sizeOverlay, this));
207
+ // Hide most UI elements in preparation for the animated resizing of the lightbox.
208
+ Lightbox.prototype.changeImage = function(imageNumber) {
209
+ var self = this;
125
210
 
126
- $('select, object, embed').css({
127
- visibility: "hidden"
128
- });
211
+ this.disableKeyboardNav();
212
+ var $image = this.$lightbox.find('.lb-image');
129
213
 
130
- this.sizeOverlay();
214
+ this.$overlay.fadeIn(this.options.fadeDuration);
131
215
 
132
- this.album = [];
133
- var imageNumber = 0;
216
+ $('.lb-loader').fadeIn('slow');
217
+ this.$lightbox.find('.lb-image, .lb-nav, .lb-prev, .lb-next, .lb-dataContainer, .lb-numbers, .lb-caption').hide();
134
218
 
135
- function addToAlbum($link) {
136
- self.album.push({
137
- link: $link.attr('href'),
138
- title: $link.attr('data-title') || $link.attr('title')
139
- });
140
- }
219
+ this.$outerContainer.addClass('animating');
141
220
 
142
- // Support both data-lightbox attribute and rel attribute implementations
143
- var dataLightboxValue = $link.attr('data-lightbox');
144
- var $links;
221
+ // When image to show is preloaded, we send the width and height to sizeContainer()
222
+ var preloader = new Image();
223
+ preloader.onload = function() {
224
+ var $preloader;
225
+ var imageHeight;
226
+ var imageWidth;
227
+ var maxImageHeight;
228
+ var maxImageWidth;
229
+ var windowHeight;
230
+ var windowWidth;
145
231
 
146
- if (dataLightboxValue) {
147
- $links = $($link.prop("tagName") + '[data-lightbox="' + dataLightboxValue + '"]');
148
- for (var i = 0; i < $links.length; i = ++i) {
149
- addToAlbum($($links[i]));
150
- if ($links[i] === $link[0]) {
151
- imageNumber = i;
152
- }
232
+ $image.attr('src', self.album[imageNumber].link);
233
+
234
+ $preloader = $(preloader);
235
+
236
+ $image.width(preloader.width);
237
+ $image.height(preloader.height);
238
+
239
+ if (self.options.fitImagesInViewport) {
240
+ // Fit image inside the viewport.
241
+ // Take into account the border around the image and an additional 10px gutter on each side.
242
+
243
+ windowWidth = $(window).width();
244
+ windowHeight = $(window).height();
245
+ maxImageWidth = windowWidth - self.containerLeftPadding - self.containerRightPadding - 20;
246
+ maxImageHeight = windowHeight - self.containerTopPadding - self.containerBottomPadding - 120;
247
+
248
+ // Check if image size is larger then maxWidth|maxHeight in settings
249
+ if (self.options.maxWidth && self.options.maxWidth < maxImageWidth) {
250
+ maxImageWidth = self.options.maxWidth;
153
251
  }
154
- } else {
155
- if ($link.attr('rel') === 'lightbox') {
156
- // If image is not part of a set
157
- addToAlbum($link);
158
- } else {
159
- // If image is part of a set
160
- $links = $($link.prop("tagName") + '[rel="' + $link.attr('rel') + '"]');
161
- for (var j = 0; j < $links.length; j = ++j) {
162
- addToAlbum($($links[j]));
163
- if ($links[j] === $link[0]) {
164
- imageNumber = j;
165
- }
166
- }
252
+ if (self.options.maxHeight && self.options.maxHeight < maxImageWidth) {
253
+ maxImageHeight = self.options.maxHeight;
167
254
  }
168
- }
169
-
170
- // Position Lightbox
171
- var top = $window.scrollTop() + this.options.positionFromTop;
172
- var left = $window.scrollLeft();
173
- this.$lightbox.css({
174
- top: top + 'px',
175
- left: left + 'px'
176
- }).fadeIn(this.options.fadeDuration);
177
-
178
- this.changeImage(imageNumber);
179
- };
180
255
 
181
- // Hide most UI elements in preparation for the animated resizing of the lightbox.
182
- Lightbox.prototype.changeImage = function(imageNumber) {
183
- var self = this;
184
-
185
- this.disableKeyboardNav();
186
- var $image = this.$lightbox.find('.lb-image');
187
-
188
- this.$overlay.fadeIn(this.options.fadeDuration);
189
-
190
- $('.lb-loader').fadeIn('slow');
191
- this.$lightbox.find('.lb-image, .lb-nav, .lb-prev, .lb-next, .lb-dataContainer, .lb-numbers, .lb-caption').hide();
192
-
193
- this.$outerContainer.addClass('animating');
194
-
195
- // When image to show is preloaded, we send the width and height to sizeContainer()
196
- var preloader = new Image();
197
- preloader.onload = function() {
198
- var $preloader, imageHeight, imageWidth, maxImageHeight, maxImageWidth, windowHeight, windowWidth;
199
- $image.attr('src', self.album[imageNumber].link);
200
-
201
- $preloader = $(preloader);
202
-
203
- $image.width(preloader.width);
204
- $image.height(preloader.height);
205
-
206
- if (self.options.fitImagesInViewport) {
207
- // Fit image inside the viewport.
208
- // Take into account the border around the image and an additional 10px gutter on each side.
209
-
210
- windowWidth = $(window).width();
211
- windowHeight = $(window).height();
212
- maxImageWidth = windowWidth - self.containerLeftPadding - self.containerRightPadding - 20;
213
- maxImageHeight = windowHeight - self.containerTopPadding - self.containerBottomPadding - 120;
214
-
215
- // Is there a fitting issue?
216
- if ((preloader.width > maxImageWidth) || (preloader.height > maxImageHeight)) {
217
- if ((preloader.width / maxImageWidth) > (preloader.height / maxImageHeight)) {
218
- imageWidth = maxImageWidth;
219
- imageHeight = parseInt(preloader.height / (preloader.width / imageWidth), 10);
220
- $image.width(imageWidth);
221
- $image.height(imageHeight);
222
- } else {
223
- imageHeight = maxImageHeight;
224
- imageWidth = parseInt(preloader.width / (preloader.height / imageHeight), 10);
225
- $image.width(imageWidth);
226
- $image.height(imageHeight);
227
- }
256
+ // Is there a fitting issue?
257
+ if ((preloader.width > maxImageWidth) || (preloader.height > maxImageHeight)) {
258
+ if ((preloader.width / maxImageWidth) > (preloader.height / maxImageHeight)) {
259
+ imageWidth = maxImageWidth;
260
+ imageHeight = parseInt(preloader.height / (preloader.width / imageWidth), 10);
261
+ $image.width(imageWidth);
262
+ $image.height(imageHeight);
263
+ } else {
264
+ imageHeight = maxImageHeight;
265
+ imageWidth = parseInt(preloader.width / (preloader.height / imageHeight), 10);
266
+ $image.width(imageWidth);
267
+ $image.height(imageHeight);
228
268
  }
229
269
  }
230
- self.sizeContainer($image.width(), $image.height());
231
- };
232
-
233
- preloader.src = this.album[imageNumber].link;
234
- this.currentImageIndex = imageNumber;
270
+ }
271
+ self.sizeContainer($image.width(), $image.height());
235
272
  };
236
273
 
237
- // Stretch overlay to fit the viewport
238
- Lightbox.prototype.sizeOverlay = function() {
239
- this.$overlay
240
- .width($(window).width())
241
- .height($(document).height());
242
- };
274
+ preloader.src = this.album[imageNumber].link;
275
+ this.currentImageIndex = imageNumber;
276
+ };
243
277
 
244
- // Animate the size of the lightbox to fit the image we are showing
245
- Lightbox.prototype.sizeContainer = function(imageWidth, imageHeight) {
246
- var self = this;
247
-
248
- var oldWidth = this.$outerContainer.outerWidth();
249
- var oldHeight = this.$outerContainer.outerHeight();
250
- var newWidth = imageWidth + this.containerLeftPadding + this.containerRightPadding;
251
- var newHeight = imageHeight + this.containerTopPadding + this.containerBottomPadding;
252
-
253
- function postResize() {
254
- self.$lightbox.find('.lb-dataContainer').width(newWidth);
255
- self.$lightbox.find('.lb-prevLink').height(newHeight);
256
- self.$lightbox.find('.lb-nextLink').height(newHeight);
257
- self.showImage();
258
- }
278
+ // Stretch overlay to fit the viewport
279
+ Lightbox.prototype.sizeOverlay = function() {
280
+ this.$overlay
281
+ .width($(document).width())
282
+ .height($(document).height());
283
+ };
284
+
285
+ // Animate the size of the lightbox to fit the image we are showing
286
+ Lightbox.prototype.sizeContainer = function(imageWidth, imageHeight) {
287
+ var self = this;
288
+
289
+ var oldWidth = this.$outerContainer.outerWidth();
290
+ var oldHeight = this.$outerContainer.outerHeight();
291
+ var newWidth = imageWidth + this.containerLeftPadding + this.containerRightPadding;
292
+ var newHeight = imageHeight + this.containerTopPadding + this.containerBottomPadding;
293
+
294
+ function postResize() {
295
+ self.$lightbox.find('.lb-dataContainer').width(newWidth);
296
+ self.$lightbox.find('.lb-prevLink').height(newHeight);
297
+ self.$lightbox.find('.lb-nextLink').height(newHeight);
298
+ self.showImage();
299
+ }
259
300
 
260
- if (oldWidth !== newWidth || oldHeight !== newHeight) {
261
- this.$outerContainer.animate({
262
- width: newWidth,
263
- height: newHeight
264
- }, this.options.resizeDuration, 'swing', function() {
265
- postResize();
266
- });
267
- } else {
301
+ if (oldWidth !== newWidth || oldHeight !== newHeight) {
302
+ this.$outerContainer.animate({
303
+ width: newWidth,
304
+ height: newHeight
305
+ }, this.options.resizeDuration, 'swing', function() {
268
306
  postResize();
269
- }
270
- };
271
-
272
- // Display the image and it's details and begin preload neighboring images.
273
- Lightbox.prototype.showImage = function() {
274
- this.$lightbox.find('.lb-loader').hide();
275
- this.$lightbox.find('.lb-image').fadeIn('slow');
276
-
277
- this.updateNav();
278
- this.updateDetails();
279
- this.preloadNeighboringImages();
280
- this.enableKeyboardNav();
281
- };
282
-
283
- // Display previous and next navigation if appropriate.
284
- Lightbox.prototype.updateNav = function() {
285
- // Check to see if the browser supports touch events. If so, we take the conservative approach
286
- // and assume that mouse hover events are not supported and always show prev/next navigation
287
- // arrows in image sets.
288
- var alwaysShowNav = false;
289
- try {
290
- document.createEvent("TouchEvent");
291
- alwaysShowNav = (this.options.alwaysShowNavOnTouchDevices)? true: false;
292
- } catch (e) {}
293
-
294
- this.$lightbox.find('.lb-nav').show();
295
-
296
- if (this.album.length > 1) {
297
- if (this.options.wrapAround) {
307
+ });
308
+ } else {
309
+ postResize();
310
+ }
311
+ };
312
+
313
+ // Display the image and its details and begin preload neighboring images.
314
+ Lightbox.prototype.showImage = function() {
315
+ this.$lightbox.find('.lb-loader').stop(true).hide();
316
+ this.$lightbox.find('.lb-image').fadeIn('slow');
317
+
318
+ this.updateNav();
319
+ this.updateDetails();
320
+ this.preloadNeighboringImages();
321
+ this.enableKeyboardNav();
322
+ };
323
+
324
+ // Display previous and next navigation if appropriate.
325
+ Lightbox.prototype.updateNav = function() {
326
+ // Check to see if the browser supports touch events. If so, we take the conservative approach
327
+ // and assume that mouse hover events are not supported and always show prev/next navigation
328
+ // arrows in image sets.
329
+ var alwaysShowNav = false;
330
+ try {
331
+ document.createEvent('TouchEvent');
332
+ alwaysShowNav = (this.options.alwaysShowNavOnTouchDevices) ? true : false;
333
+ } catch (e) {}
334
+
335
+ this.$lightbox.find('.lb-nav').show();
336
+
337
+ if (this.album.length > 1) {
338
+ if (this.options.wrapAround) {
339
+ if (alwaysShowNav) {
340
+ this.$lightbox.find('.lb-prev, .lb-next').css('opacity', '1');
341
+ }
342
+ this.$lightbox.find('.lb-prev, .lb-next').show();
343
+ } else {
344
+ if (this.currentImageIndex > 0) {
345
+ this.$lightbox.find('.lb-prev').show();
298
346
  if (alwaysShowNav) {
299
- this.$lightbox.find('.lb-prev, .lb-next').css('opacity', '1');
300
- }
301
- this.$lightbox.find('.lb-prev, .lb-next').show();
302
- } else {
303
- if (this.currentImageIndex > 0) {
304
- this.$lightbox.find('.lb-prev').show();
305
- if (alwaysShowNav) {
306
- this.$lightbox.find('.lb-prev').css('opacity', '1');
307
- }
347
+ this.$lightbox.find('.lb-prev').css('opacity', '1');
308
348
  }
309
- if (this.currentImageIndex < this.album.length - 1) {
310
- this.$lightbox.find('.lb-next').show();
311
- if (alwaysShowNav) {
312
- this.$lightbox.find('.lb-next').css('opacity', '1');
313
- }
349
+ }
350
+ if (this.currentImageIndex < this.album.length - 1) {
351
+ this.$lightbox.find('.lb-next').show();
352
+ if (alwaysShowNav) {
353
+ this.$lightbox.find('.lb-next').css('opacity', '1');
314
354
  }
315
355
  }
316
356
  }
317
- };
357
+ }
358
+ };
318
359
 
319
- // Display caption, image number, and closing button.
320
- Lightbox.prototype.updateDetails = function() {
321
- var self = this;
360
+ // Display caption, image number, and closing button.
361
+ Lightbox.prototype.updateDetails = function() {
362
+ var self = this;
322
363
 
323
- // Enable anchor clicks in the injected caption html.
324
- // Thanks Nate Wright for the fix. @https://github.com/NateWr
325
- if (typeof this.album[this.currentImageIndex].title !== 'undefined' && this.album[this.currentImageIndex].title !== "") {
326
- this.$lightbox.find('.lb-caption')
364
+ // Enable anchor clicks in the injected caption html.
365
+ // Thanks Nate Wright for the fix. @https://github.com/NateWr
366
+ if (typeof this.album[this.currentImageIndex].title !== 'undefined' &&
367
+ this.album[this.currentImageIndex].title !== '') {
368
+ this.$lightbox.find('.lb-caption')
327
369
  .html(this.album[this.currentImageIndex].title)
328
370
  .fadeIn('fast')
329
- .find('a').on('click', function(event){
330
- location.href = $(this).attr('href');
331
- });
332
- }
333
-
334
- if (this.album.length > 1 && this.options.showImageNumberLabel) {
335
- this.$lightbox.find('.lb-number').text(this.options.albumLabel(this.currentImageIndex + 1, this.album.length)).fadeIn('fast');
336
- } else {
337
- this.$lightbox.find('.lb-number').hide();
338
- }
339
-
340
- this.$outerContainer.removeClass('animating');
341
-
342
- this.$lightbox.find('.lb-dataContainer').fadeIn(this.options.resizeDuration, function() {
343
- return self.sizeOverlay();
371
+ .find('a').on('click', function(event) {
372
+ if ($(this).attr('target') !== undefined) {
373
+ window.open($(this).attr('href'), $(this).attr('target'));
374
+ } else {
375
+ location.href = $(this).attr('href');
376
+ }
344
377
  });
345
- };
378
+ }
346
379
 
347
- // Preload previous and next images in set.
348
- Lightbox.prototype.preloadNeighboringImages = function() {
349
- if (this.album.length > this.currentImageIndex + 1) {
350
- var preloadNext = new Image();
351
- preloadNext.src = this.album[this.currentImageIndex + 1].link;
352
- }
353
- if (this.currentImageIndex > 0) {
354
- var preloadPrev = new Image();
355
- preloadPrev.src = this.album[this.currentImageIndex - 1].link;
356
- }
357
- };
380
+ if (this.album.length > 1 && this.options.showImageNumberLabel) {
381
+ var labelText = this.imageCountLabel(this.currentImageIndex + 1, this.album.length);
382
+ this.$lightbox.find('.lb-number').text(labelText).fadeIn('fast');
383
+ } else {
384
+ this.$lightbox.find('.lb-number').hide();
385
+ }
358
386
 
359
- Lightbox.prototype.enableKeyboardNav = function() {
360
- $(document).on('keyup.keyboard', $.proxy(this.keyboardAction, this));
361
- };
387
+ this.$outerContainer.removeClass('animating');
362
388
 
363
- Lightbox.prototype.disableKeyboardNav = function() {
364
- $(document).off('.keyboard');
365
- };
389
+ this.$lightbox.find('.lb-dataContainer').fadeIn(this.options.resizeDuration, function() {
390
+ return self.sizeOverlay();
391
+ });
392
+ };
366
393
 
367
- Lightbox.prototype.keyboardAction = function(event) {
368
- var KEYCODE_ESC = 27;
369
- var KEYCODE_LEFTARROW = 37;
370
- var KEYCODE_RIGHTARROW = 39;
371
-
372
- var keycode = event.keyCode;
373
- var key = String.fromCharCode(keycode).toLowerCase();
374
- if (keycode === KEYCODE_ESC || key.match(/x|o|c/)) {
375
- this.end();
376
- } else if (key === 'p' || keycode === KEYCODE_LEFTARROW) {
377
- if (this.currentImageIndex !== 0) {
378
- this.changeImage(this.currentImageIndex - 1);
379
- } else if (this.options.wrapAround && this.album.length > 1) {
380
- this.changeImage(this.album.length - 1);
381
- }
382
- } else if (key === 'n' || keycode === KEYCODE_RIGHTARROW) {
383
- if (this.currentImageIndex !== this.album.length - 1) {
384
- this.changeImage(this.currentImageIndex + 1);
385
- } else if (this.options.wrapAround && this.album.length > 1) {
386
- this.changeImage(0);
387
- }
394
+ // Preload previous and next images in set.
395
+ Lightbox.prototype.preloadNeighboringImages = function() {
396
+ if (this.album.length > this.currentImageIndex + 1) {
397
+ var preloadNext = new Image();
398
+ preloadNext.src = this.album[this.currentImageIndex + 1].link;
399
+ }
400
+ if (this.currentImageIndex > 0) {
401
+ var preloadPrev = new Image();
402
+ preloadPrev.src = this.album[this.currentImageIndex - 1].link;
403
+ }
404
+ };
405
+
406
+ Lightbox.prototype.enableKeyboardNav = function() {
407
+ $(document).on('keyup.keyboard', $.proxy(this.keyboardAction, this));
408
+ };
409
+
410
+ Lightbox.prototype.disableKeyboardNav = function() {
411
+ $(document).off('.keyboard');
412
+ };
413
+
414
+ Lightbox.prototype.keyboardAction = function(event) {
415
+ var KEYCODE_ESC = 27;
416
+ var KEYCODE_LEFTARROW = 37;
417
+ var KEYCODE_RIGHTARROW = 39;
418
+
419
+ var keycode = event.keyCode;
420
+ var key = String.fromCharCode(keycode).toLowerCase();
421
+ if (keycode === KEYCODE_ESC || key.match(/x|o|c/)) {
422
+ this.end();
423
+ } else if (key === 'p' || keycode === KEYCODE_LEFTARROW) {
424
+ if (this.currentImageIndex !== 0) {
425
+ this.changeImage(this.currentImageIndex - 1);
426
+ } else if (this.options.wrapAround && this.album.length > 1) {
427
+ this.changeImage(this.album.length - 1);
388
428
  }
389
- };
390
-
391
- // Closing time. :-(
392
- Lightbox.prototype.end = function() {
393
- this.disableKeyboardNav();
394
- $(window).off("resize", this.sizeOverlay);
395
- this.$lightbox.fadeOut(this.options.fadeDuration);
396
- this.$overlay.fadeOut(this.options.fadeDuration);
397
- $('select, object, embed').css({
398
- visibility: "visible"
399
- });
400
- };
401
-
402
- return Lightbox;
403
-
404
- })();
405
-
406
- $(document).on('page:load ready', function() {
407
- var options = new LightboxOptions();
408
- var lightbox = new Lightbox(options);
409
- });
429
+ } else if (key === 'n' || keycode === KEYCODE_RIGHTARROW) {
430
+ if (this.currentImageIndex !== this.album.length - 1) {
431
+ this.changeImage(this.currentImageIndex + 1);
432
+ } else if (this.options.wrapAround && this.album.length > 1) {
433
+ this.changeImage(0);
434
+ }
435
+ }
436
+ };
437
+
438
+ // Closing time. :-(
439
+ Lightbox.prototype.end = function() {
440
+ this.disableKeyboardNav();
441
+ $(window).off('resize', this.sizeOverlay);
442
+ this.$lightbox.fadeOut(this.options.fadeDuration);
443
+ this.$overlay.fadeOut(this.options.fadeDuration);
444
+ $('select, object, embed').css({
445
+ visibility: 'visible'
446
+ });
447
+ if (this.options.disableScrolling) {
448
+ $('body').removeClass('lb-disable-scrolling');
449
+ }
450
+ };
410
451
 
411
- }).call(this);
452
+ return new Lightbox();
453
+ }));