masonry-rails 0.2.0 → 0.2.1

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: d441d9484feb77daf92b8c94197d293eedb2aa00
4
+ data.tar.gz: 3331c5fd8c1f908908e74b6312451c8b7a73b1c1
5
+ SHA512:
6
+ metadata.gz: 16f44417be573df8aff7e589384232ae997693d1037158bbe2a971a19c4907e74d57d4f4328b5301bc09c54542be243242ff9876cf51e999414eb671f70b6c67
7
+ data.tar.gz: b2b016b66bccc398915fb973b92547dae8bbbbac552630279673f404bba595140c0c610682062fb7cc66d333bc3fef05924c098159fd0640a790dba2329f2d07
data/Gemfile CHANGED
@@ -3,9 +3,9 @@ source "http://rubygems.org"
3
3
  gem 'rails'
4
4
 
5
5
  group :development do
6
- gem "rspec", "> 2.8.0"
7
- gem "rdoc", ">= 3.12"
8
- gem "bundler", "> 1.0.0"
9
- gem "jeweler", ">= 1.8.4"
6
+ gem "rspec", "> 2.10.0"
7
+ gem "rdoc", "> 3.12"
8
+ gem "bundler", "> 1.2.0"
9
+ gem "jeweler", "> 1.8.4"
10
10
  gem "simplecov",">= 0.5"
11
11
  end
data/Gemfile.lock CHANGED
@@ -28,18 +28,37 @@ GEM
28
28
  activemodel (= 3.0.8)
29
29
  activesupport (= 3.0.8)
30
30
  activesupport (3.0.8)
31
+ addressable (2.3.5)
31
32
  arel (2.0.10)
32
33
  builder (2.1.2)
33
34
  diff-lcs (1.2.1)
34
35
  erubis (2.6.6)
35
36
  abstract (>= 1.0.0)
37
+ faraday (0.8.7)
38
+ multipart-post (~> 1.1)
36
39
  git (1.2.5)
40
+ github_api (0.10.1)
41
+ addressable
42
+ faraday (~> 0.8.1)
43
+ hashie (>= 1.2)
44
+ multi_json (~> 1.4)
45
+ nokogiri (~> 1.5.2)
46
+ oauth2
47
+ hashie (2.0.5)
48
+ highline (1.6.19)
49
+ httpauth (0.2.0)
37
50
  i18n (0.5.0)
38
- jeweler (1.8.4)
51
+ jeweler (1.8.6)
52
+ builder
39
53
  bundler (~> 1.0)
40
54
  git (>= 1.2.5)
55
+ github_api (= 0.10.1)
56
+ highline (>= 1.6.15)
57
+ nokogiri (= 1.5.10)
41
58
  rake
42
59
  rdoc
60
+ jwt (0.1.8)
61
+ multi_json (>= 1.5)
43
62
  mail (2.2.19)
44
63
  activesupport (>= 2.3.6)
45
64
  i18n (>= 0.4.0)
@@ -47,6 +66,16 @@ GEM
47
66
  treetop (~> 1.4.8)
48
67
  mime-types (1.21)
49
68
  multi_json (1.7.1)
69
+ multi_xml (0.5.4)
70
+ multipart-post (1.2.0)
71
+ nokogiri (1.5.10)
72
+ oauth2 (0.9.2)
73
+ faraday (~> 0.8)
74
+ httpauth (~> 0.2)
75
+ jwt (~> 0.1.4)
76
+ multi_json (~> 1.0)
77
+ multi_xml (~> 0.5)
78
+ rack (~> 1.2)
50
79
  polyglot (0.3.3)
51
80
  rack (1.2.8)
52
81
  rack-mount (0.6.14)
@@ -90,9 +119,9 @@ PLATFORMS
90
119
  ruby
91
120
 
92
121
  DEPENDENCIES
93
- bundler (> 1.0.0)
94
- jeweler (>= 1.8.4)
122
+ bundler (> 1.2.0)
123
+ jeweler (> 1.8.4)
95
124
  rails
96
- rdoc (>= 3.12)
97
- rspec (> 2.8.0)
125
+ rdoc (> 3.12)
126
+ rspec (> 2.10.0)
98
127
  simplecov (>= 0.5)
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.2.0
1
+ 0.2.1
@@ -5,11 +5,11 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = "masonry-rails"
8
- s.version = "0.2.0"
8
+ s.version = "0.2.1"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = ["Kristian Mandrup"]
12
- s.date = "2013-03-21"
12
+ s.date = "2013-12-02"
13
13
  s.description = "Masonry will rock your world!"
14
14
  s.email = "kmandrup@gmail.com"
15
15
  s.extra_rdoc_files = [
@@ -73,6 +73,7 @@ Gem::Specification.new do |s|
73
73
  "vendor/assets/javascripts/masonry/jquery.event-drag.js",
74
74
  "vendor/assets/javascripts/masonry/jquery.imagesloaded.js",
75
75
  "vendor/assets/javascripts/masonry/jquery.imagesloaded.min.js",
76
+ "vendor/assets/javascripts/masonry/jquery.infinitescroll.js",
76
77
  "vendor/assets/javascripts/masonry/jquery.infinitescroll.min.js",
77
78
  "vendor/assets/javascripts/masonry/jquery.loremimages.min.js",
78
79
  "vendor/assets/javascripts/masonry/jquery.masonry.js",
@@ -100,33 +101,33 @@ Gem::Specification.new do |s|
100
101
  s.homepage = "http://github.com/kristianmandrup/masonry-rails"
101
102
  s.licenses = ["MIT"]
102
103
  s.require_paths = ["lib"]
103
- s.rubygems_version = "1.8.25"
104
+ s.rubygems_version = "2.0.0"
104
105
  s.summary = "Use JQuery Masonry with Rails asset pipeline"
105
106
 
106
107
  if s.respond_to? :specification_version then
107
- s.specification_version = 3
108
+ s.specification_version = 4
108
109
 
109
110
  if Gem::Version.new(Gem::VERSION) >= Gem::Version.new('1.2.0') then
110
111
  s.add_runtime_dependency(%q<rails>, [">= 0"])
111
- s.add_development_dependency(%q<rspec>, ["> 2.8.0"])
112
- s.add_development_dependency(%q<rdoc>, [">= 3.12"])
113
- s.add_development_dependency(%q<bundler>, ["> 1.0.0"])
114
- s.add_development_dependency(%q<jeweler>, [">= 1.8.4"])
112
+ s.add_development_dependency(%q<rspec>, ["> 2.10.0"])
113
+ s.add_development_dependency(%q<rdoc>, ["> 3.12"])
114
+ s.add_development_dependency(%q<bundler>, ["> 1.2.0"])
115
+ s.add_development_dependency(%q<jeweler>, ["> 1.8.4"])
115
116
  s.add_development_dependency(%q<simplecov>, [">= 0.5"])
116
117
  else
117
118
  s.add_dependency(%q<rails>, [">= 0"])
118
- s.add_dependency(%q<rspec>, ["> 2.8.0"])
119
- s.add_dependency(%q<rdoc>, [">= 3.12"])
120
- s.add_dependency(%q<bundler>, ["> 1.0.0"])
121
- s.add_dependency(%q<jeweler>, [">= 1.8.4"])
119
+ s.add_dependency(%q<rspec>, ["> 2.10.0"])
120
+ s.add_dependency(%q<rdoc>, ["> 3.12"])
121
+ s.add_dependency(%q<bundler>, ["> 1.2.0"])
122
+ s.add_dependency(%q<jeweler>, ["> 1.8.4"])
122
123
  s.add_dependency(%q<simplecov>, [">= 0.5"])
123
124
  end
124
125
  else
125
126
  s.add_dependency(%q<rails>, [">= 0"])
126
- s.add_dependency(%q<rspec>, ["> 2.8.0"])
127
- s.add_dependency(%q<rdoc>, [">= 3.12"])
128
- s.add_dependency(%q<bundler>, ["> 1.0.0"])
129
- s.add_dependency(%q<jeweler>, [">= 1.8.4"])
127
+ s.add_dependency(%q<rspec>, ["> 2.10.0"])
128
+ s.add_dependency(%q<rdoc>, ["> 3.12"])
129
+ s.add_dependency(%q<bundler>, ["> 1.2.0"])
130
+ s.add_dependency(%q<jeweler>, ["> 1.8.4"])
130
131
  s.add_dependency(%q<simplecov>, [">= 0.5"])
131
132
  end
132
133
  end
@@ -0,0 +1,814 @@
1
+ /*jshint undef: true */
2
+ /*global jQuery: true */
3
+
4
+ /*
5
+ --------------------------------
6
+ Infinite Scroll
7
+ --------------------------------
8
+ + https://github.com/paulirish/infinite-scroll
9
+ + version 2.0b2.120519
10
+ + Copyright 2011/12 Paul Irish & Luke Shumard
11
+ + Licensed under the MIT license
12
+
13
+ + Documentation: http://infinite-scroll.com/
14
+ */
15
+
16
+ (function (window, $, undefined) {
17
+ "use strict";
18
+
19
+ $.infinitescroll = function infscr(options, callback, element) {
20
+ this.element = $(element);
21
+
22
+ // Flag the object in the event of a failed creation
23
+ if (!this._create(options, callback)) {
24
+ this.failed = true;
25
+ }
26
+ };
27
+
28
+ $.infinitescroll.defaults = {
29
+ loading: {
30
+ finished: undefined,
31
+ finishedMsg: "<em>Congratulations, you've reached the end of the internet.</em>",
32
+ img: "",
33
+ msg: null,
34
+ msgText: "<em>Loading the next set of posts...</em>",
35
+ selector: null,
36
+ speed: 'fast',
37
+ start: undefined
38
+ },
39
+ state: {
40
+ isDuringAjax: false,
41
+ isInvalidPage: false,
42
+ isDestroyed: false,
43
+ isDone: false, // For when it goes all the way through the archive.
44
+ isPaused: false,
45
+ isBeyondMaxPage: false,
46
+ currPage: 1
47
+ },
48
+ debug: false,
49
+ behavior: undefined,
50
+ binder: $(window), // used to cache the selector
51
+ nextSelector: "div.navigation a:first",
52
+ navSelector: "div.navigation",
53
+ contentSelector: null, // rename to pageFragment
54
+ extraScrollPx: 150,
55
+ itemSelector: "div.post",
56
+ animate: false,
57
+ pathParse: undefined,
58
+ dataType: 'html',
59
+ appendCallback: true,
60
+ bufferPx: 40,
61
+ errorCallback: function () { },
62
+ infid: 0, //Instance ID
63
+ pixelsFromNavToBottom: undefined,
64
+ path: undefined, // Either parts of a URL as an array (e.g. ["/page/", "/"] or a function that takes in the page number and returns a URL
65
+ prefill: false, // When the document is smaller than the window, load data until the document is larger or links are exhausted
66
+ maxPage: undefined // to manually control maximum page (when maxPage is undefined, maximum page limitation is not work)
67
+ };
68
+
69
+ $.infinitescroll.prototype = {
70
+
71
+ /*
72
+ ----------------------------
73
+ Private methods
74
+ ----------------------------
75
+ */
76
+
77
+ // Bind or unbind from scroll
78
+ _binding: function infscr_binding(binding) {
79
+
80
+ var instance = this,
81
+ opts = instance.options;
82
+
83
+ opts.v = '2.0b2.120520';
84
+
85
+ // if behavior is defined and this function is extended, call that instead of default
86
+ if (!!opts.behavior && this['_binding_'+opts.behavior] !== undefined) {
87
+ this['_binding_'+opts.behavior].call(this);
88
+ return;
89
+ }
90
+
91
+ if (binding !== 'bind' && binding !== 'unbind') {
92
+ this._debug('Binding value ' + binding + ' not valid');
93
+ return false;
94
+ }
95
+
96
+ if (binding === 'unbind') {
97
+ (this.options.binder).unbind('smartscroll.infscr.' + instance.options.infid);
98
+ } else {
99
+ (this.options.binder)[binding]('smartscroll.infscr.' + instance.options.infid, function () {
100
+ instance.scroll();
101
+ });
102
+ }
103
+
104
+ this._debug('Binding', binding);
105
+ },
106
+
107
+ // Fundamental aspects of the plugin are initialized
108
+ _create: function infscr_create(options, callback) {
109
+
110
+ // Add custom options to defaults
111
+ var opts = $.extend(true, {}, $.infinitescroll.defaults, options);
112
+ this.options = opts;
113
+ var $window = $(window);
114
+ var instance = this;
115
+
116
+ // Validate selectors
117
+ if (!instance._validate(options)) {
118
+ return false;
119
+ }
120
+
121
+ // Validate page fragment path
122
+ var path = $(opts.nextSelector).attr('href');
123
+ if (!path) {
124
+ this._debug('Navigation selector not found');
125
+ return false;
126
+ }
127
+
128
+ // Set the path to be a relative URL from root.
129
+ opts.path = opts.path || this._determinepath(path);
130
+
131
+ // contentSelector is 'page fragment' option for .load() / .ajax() calls
132
+ opts.contentSelector = opts.contentSelector || this.element;
133
+
134
+ // loading.selector - if we want to place the load message in a specific selector, defaulted to the contentSelector
135
+ opts.loading.selector = opts.loading.selector || opts.contentSelector;
136
+
137
+ // Define loading.msg
138
+ opts.loading.msg = opts.loading.msg || $('<div id="infscr-loading"><img alt="Loading..." src="' + opts.loading.img + '" /><div>' + opts.loading.msgText + '</div></div>');
139
+
140
+ // Preload loading.img
141
+ (new Image()).src = opts.loading.img;
142
+
143
+ // distance from nav links to bottom
144
+ // computed as: height of the document + top offset of container - top offset of nav link
145
+ if(opts.pixelsFromNavToBottom === undefined) {
146
+ opts.pixelsFromNavToBottom = $(document).height() - $(opts.navSelector).offset().top;
147
+ this._debug("pixelsFromNavToBottom: " + opts.pixelsFromNavToBottom);
148
+ }
149
+
150
+ var self = this;
151
+
152
+ // determine loading.start actions
153
+ opts.loading.start = opts.loading.start || function() {
154
+ $(opts.navSelector).hide();
155
+ opts.loading.msg
156
+ .appendTo(opts.loading.selector)
157
+ .show(opts.loading.speed, $.proxy(function() {
158
+ this.beginAjax(opts);
159
+ }, self));
160
+ };
161
+
162
+ // determine loading.finished actions
163
+ opts.loading.finished = opts.loading.finished || function() {
164
+ if (!opts.state.isBeyondMaxPage)
165
+ opts.loading.msg.fadeOut(opts.loading.speed);
166
+ };
167
+
168
+ // callback loading
169
+ opts.callback = function(instance, data, url) {
170
+ if (!!opts.behavior && instance['_callback_'+opts.behavior] !== undefined) {
171
+ instance['_callback_'+opts.behavior].call($(opts.contentSelector)[0], data, url);
172
+ }
173
+
174
+ if (callback) {
175
+ callback.call($(opts.contentSelector)[0], data, opts, url);
176
+ }
177
+
178
+ if (opts.prefill) {
179
+ $window.bind("resize.infinite-scroll", instance._prefill);
180
+ }
181
+ };
182
+
183
+ if (options.debug) {
184
+ // Tell IE9 to use its built-in console
185
+ if (Function.prototype.bind && (typeof console === 'object' || typeof console === 'function') && typeof console.log === "object") {
186
+ ["log","info","warn","error","assert","dir","clear","profile","profileEnd"]
187
+ .forEach(function (method) {
188
+ console[method] = this.call(console[method], console);
189
+ }, Function.prototype.bind);
190
+ }
191
+ }
192
+
193
+ this._setup();
194
+
195
+ // Setups the prefill method for use
196
+ if (opts.prefill) {
197
+ this._prefill();
198
+ }
199
+
200
+ // Return true to indicate successful creation
201
+ return true;
202
+ },
203
+
204
+ _prefill: function infscr_prefill() {
205
+ var instance = this;
206
+ var $window = $(window);
207
+
208
+ function needsPrefill() {
209
+ return (instance.options.contentSelector.height() <= $window.height());
210
+ }
211
+
212
+ this._prefill = function() {
213
+ if (needsPrefill()) {
214
+ instance.scroll();
215
+ }
216
+
217
+ $window.bind("resize.infinite-scroll", function() {
218
+ if (needsPrefill()) {
219
+ $window.unbind("resize.infinite-scroll");
220
+ instance.scroll();
221
+ }
222
+ });
223
+ };
224
+
225
+ // Call self after setting up the new function
226
+ this._prefill();
227
+ },
228
+
229
+ // Console log wrapper
230
+ _debug: function infscr_debug() {
231
+ if (true !== this.options.debug) {
232
+ return;
233
+ }
234
+
235
+ if (typeof console !== 'undefined' && typeof console.log === 'function') {
236
+ // Modern browsers
237
+ // Single argument, which is a string
238
+ if ((Array.prototype.slice.call(arguments)).length === 1 && typeof Array.prototype.slice.call(arguments)[0] === 'string') {
239
+ console.log( (Array.prototype.slice.call(arguments)).toString() );
240
+ } else {
241
+ console.log( Array.prototype.slice.call(arguments) );
242
+ }
243
+ } else if (!Function.prototype.bind && typeof console !== 'undefined' && typeof console.log === 'object') {
244
+ // IE8
245
+ Function.prototype.call.call(console.log, console, Array.prototype.slice.call(arguments));
246
+ }
247
+ },
248
+
249
+ // find the number to increment in the path.
250
+ _determinepath: function infscr_determinepath(path) {
251
+
252
+ var opts = this.options;
253
+
254
+ // if behavior is defined and this function is extended, call that instead of default
255
+ if (!!opts.behavior && this['_determinepath_'+opts.behavior] !== undefined) {
256
+ return this['_determinepath_'+opts.behavior].call(this,path);
257
+ }
258
+
259
+ if (!!opts.pathParse) {
260
+
261
+ this._debug('pathParse manual');
262
+ return opts.pathParse(path, this.options.state.currPage+1);
263
+
264
+ } else if (path.match(/^(.*?)\b2\b(.*?$)/)) {
265
+ path = path.match(/^(.*?)\b2\b(.*?$)/).slice(1);
266
+
267
+ // if there is any 2 in the url at all.
268
+ } else if (path.match(/^(.*?)2(.*?$)/)) {
269
+
270
+ // page= is used in django:
271
+ // http://www.infinite-scroll.com/changelog/comment-page-1/#comment-127
272
+ if (path.match(/^(.*?page=)2(\/.*|$)/)) {
273
+ path = path.match(/^(.*?page=)2(\/.*|$)/).slice(1);
274
+ return path;
275
+ }
276
+
277
+ path = path.match(/^(.*?)2(.*?$)/).slice(1);
278
+
279
+ } else {
280
+
281
+ // page= is used in drupal too but second page is page=1 not page=2:
282
+ // thx Jerod Fritz, vladikoff
283
+ if (path.match(/^(.*?page=)1(\/.*|$)/)) {
284
+ path = path.match(/^(.*?page=)1(\/.*|$)/).slice(1);
285
+ return path;
286
+ } else {
287
+ this._debug('Sorry, we couldn\'t parse your Next (Previous Posts) URL. Verify your the css selector points to the correct A tag. If you still get this error: yell, scream, and kindly ask for help at infinite-scroll.com.');
288
+ // Get rid of isInvalidPage to allow permalink to state
289
+ opts.state.isInvalidPage = true; //prevent it from running on this page.
290
+ }
291
+ }
292
+ this._debug('determinePath', path);
293
+ return path;
294
+
295
+ },
296
+
297
+ // Custom error
298
+ _error: function infscr_error(xhr) {
299
+
300
+ var opts = this.options;
301
+
302
+ // if behavior is defined and this function is extended, call that instead of default
303
+ if (!!opts.behavior && this['_error_'+opts.behavior] !== undefined) {
304
+ this['_error_'+opts.behavior].call(this,xhr);
305
+ return;
306
+ }
307
+
308
+ if (xhr !== 'destroy' && xhr !== 'end') {
309
+ xhr = 'unknown';
310
+ }
311
+
312
+ this._debug('Error', xhr);
313
+
314
+ if (xhr === 'end' || opts.state.isBeyondMaxPage) {
315
+ this._showdonemsg();
316
+ }
317
+
318
+ opts.state.isDone = true;
319
+ opts.state.currPage = 1; // if you need to go back to this instance
320
+ opts.state.isPaused = false;
321
+ opts.state.isBeyondMaxPage = false;
322
+ this._binding('unbind');
323
+
324
+ },
325
+
326
+ // Load Callback
327
+ _loadcallback: function infscr_loadcallback(box, data, url) {
328
+ var opts = this.options,
329
+ callback = this.options.callback, // GLOBAL OBJECT FOR CALLBACK
330
+ result = (opts.state.isDone) ? 'done' : (!opts.appendCallback) ? 'no-append' : 'append',
331
+ frag;
332
+
333
+ // if behavior is defined and this function is extended, call that instead of default
334
+ if (!!opts.behavior && this['_loadcallback_'+opts.behavior] !== undefined) {
335
+ this['_loadcallback_'+opts.behavior].call(this,box,data);
336
+ return;
337
+ }
338
+
339
+ switch (result) {
340
+ case 'done':
341
+ this._showdonemsg();
342
+ return false;
343
+
344
+ case 'no-append':
345
+ if (opts.dataType === 'html') {
346
+ data = '<div>' + data + '</div>';
347
+ data = $(data).find(opts.itemSelector);
348
+ }
349
+ break;
350
+
351
+ case 'append':
352
+ var children = box.children();
353
+ // if it didn't return anything
354
+ if (children.length === 0) {
355
+ return this._error('end');
356
+ }
357
+
358
+ // use a documentFragment because it works when content is going into a table or UL
359
+ frag = document.createDocumentFragment();
360
+ while (box[0].firstChild) {
361
+ frag.appendChild(box[0].firstChild);
362
+ }
363
+
364
+ this._debug('contentSelector', $(opts.contentSelector)[0]);
365
+ $(opts.contentSelector)[0].appendChild(frag);
366
+ // previously, we would pass in the new DOM element as context for the callback
367
+ // however we're now using a documentfragment, which doesn't have parents or children,
368
+ // so the context is the contentContainer guy, and we pass in an array
369
+ // of the elements collected as the first argument.
370
+
371
+ data = children.get();
372
+ break;
373
+ }
374
+
375
+ // loadingEnd function
376
+ opts.loading.finished.call($(opts.contentSelector)[0],opts);
377
+
378
+ // smooth scroll to ease in the new content
379
+ if (opts.animate) {
380
+ var scrollTo = $(window).scrollTop() + $(opts.loading.msg).height() + opts.extraScrollPx + 'px';
381
+ $('html,body').animate({ scrollTop: scrollTo }, 800, function () { opts.state.isDuringAjax = false; });
382
+ }
383
+
384
+ if (!opts.animate) {
385
+ // once the call is done, we can allow it again.
386
+ opts.state.isDuringAjax = false;
387
+ }
388
+
389
+ callback(this, data, url);
390
+
391
+ if (opts.prefill) {
392
+ this._prefill();
393
+ }
394
+ },
395
+
396
+ _nearbottom: function infscr_nearbottom() {
397
+
398
+ var opts = this.options,
399
+ pixelsFromWindowBottomToBottom = 0 + $(document).height() - (opts.binder.scrollTop()) - $(window).height();
400
+
401
+ // if behavior is defined and this function is extended, call that instead of default
402
+ if (!!opts.behavior && this['_nearbottom_'+opts.behavior] !== undefined) {
403
+ return this['_nearbottom_'+opts.behavior].call(this);
404
+ }
405
+
406
+ this._debug('math:', pixelsFromWindowBottomToBottom, opts.pixelsFromNavToBottom);
407
+
408
+ // if distance remaining in the scroll (including buffer) is less than the orignal nav to bottom....
409
+ return (pixelsFromWindowBottomToBottom - opts.bufferPx < opts.pixelsFromNavToBottom);
410
+
411
+ },
412
+
413
+ // Pause / temporarily disable plugin from firing
414
+ _pausing: function infscr_pausing(pause) {
415
+
416
+ var opts = this.options;
417
+
418
+ // if behavior is defined and this function is extended, call that instead of default
419
+ if (!!opts.behavior && this['_pausing_'+opts.behavior] !== undefined) {
420
+ this['_pausing_'+opts.behavior].call(this,pause);
421
+ return;
422
+ }
423
+
424
+ // If pause is not 'pause' or 'resume', toggle it's value
425
+ if (pause !== 'pause' && pause !== 'resume' && pause !== null) {
426
+ this._debug('Invalid argument. Toggling pause value instead');
427
+ }
428
+
429
+ pause = (pause && (pause === 'pause' || pause === 'resume')) ? pause : 'toggle';
430
+
431
+ switch (pause) {
432
+ case 'pause':
433
+ opts.state.isPaused = true;
434
+ break;
435
+
436
+ case 'resume':
437
+ opts.state.isPaused = false;
438
+ break;
439
+
440
+ case 'toggle':
441
+ opts.state.isPaused = !opts.state.isPaused;
442
+ break;
443
+ }
444
+
445
+ this._debug('Paused', opts.state.isPaused);
446
+ return false;
447
+
448
+ },
449
+
450
+ // Behavior is determined
451
+ // If the behavior option is undefined, it will set to default and bind to scroll
452
+ _setup: function infscr_setup() {
453
+
454
+ var opts = this.options;
455
+
456
+ // if behavior is defined and this function is extended, call that instead of default
457
+ if (!!opts.behavior && this['_setup_'+opts.behavior] !== undefined) {
458
+ this['_setup_'+opts.behavior].call(this);
459
+ return;
460
+ }
461
+
462
+ this._binding('bind');
463
+
464
+ return false;
465
+
466
+ },
467
+
468
+ // Show done message
469
+ _showdonemsg: function infscr_showdonemsg() {
470
+
471
+ var opts = this.options;
472
+
473
+ // if behavior is defined and this function is extended, call that instead of default
474
+ if (!!opts.behavior && this['_showdonemsg_'+opts.behavior] !== undefined) {
475
+ this['_showdonemsg_'+opts.behavior].call(this);
476
+ return;
477
+ }
478
+
479
+ opts.loading.msg
480
+ .find('img')
481
+ .hide()
482
+ .parent()
483
+ .find('div').html(opts.loading.finishedMsg).animate({ opacity: 1 }, 2000, function () {
484
+ $(this).parent().fadeOut(opts.loading.speed);
485
+ });
486
+
487
+ // user provided callback when done
488
+ opts.errorCallback.call($(opts.contentSelector)[0],'done');
489
+ },
490
+
491
+ // grab each selector option and see if any fail
492
+ _validate: function infscr_validate(opts) {
493
+ for (var key in opts) {
494
+ if (key.indexOf && key.indexOf('Selector') > -1 && $(opts[key]).length === 0) {
495
+ this._debug('Your ' + key + ' found no elements.');
496
+ return false;
497
+ }
498
+ }
499
+
500
+ return true;
501
+ },
502
+
503
+ /*
504
+ ----------------------------
505
+ Public methods
506
+ ----------------------------
507
+ */
508
+
509
+ // Bind to scroll
510
+ bind: function infscr_bind() {
511
+ this._binding('bind');
512
+ },
513
+
514
+ // Destroy current instance of plugin
515
+ destroy: function infscr_destroy() {
516
+ this.options.state.isDestroyed = true;
517
+ this.options.loading.finished();
518
+ return this._error('destroy');
519
+ },
520
+
521
+ // Set pause value to false
522
+ pause: function infscr_pause() {
523
+ this._pausing('pause');
524
+ },
525
+
526
+ // Set pause value to false
527
+ resume: function infscr_resume() {
528
+ this._pausing('resume');
529
+ },
530
+
531
+ beginAjax: function infscr_ajax(opts) {
532
+ var instance = this,
533
+ path = opts.path,
534
+ box, desturl, method, condition;
535
+
536
+ // increment the URL bit. e.g. /page/3/
537
+ opts.state.currPage++;
538
+
539
+ // Manually control maximum page
540
+ if ( opts.maxPage != undefined && opts.state.currPage > opts.maxPage ){
541
+ opts.state.isBeyondMaxPage = true;
542
+ this.destroy();
543
+ return;
544
+ }
545
+
546
+ // if we're dealing with a table we can't use DIVs
547
+ box = $(opts.contentSelector).is('table, tbody') ? $('<tbody/>') : $('<div/>');
548
+
549
+ desturl = (typeof path === 'function') ? path(opts.state.currPage) : path.join(opts.state.currPage);
550
+ instance._debug('heading into ajax', desturl);
551
+
552
+ method = (opts.dataType === 'html' || opts.dataType === 'json' ) ? opts.dataType : 'html+callback';
553
+ if (opts.appendCallback && opts.dataType === 'html') {
554
+ method += '+callback';
555
+ }
556
+
557
+ switch (method) {
558
+ case 'html+callback':
559
+ instance._debug('Using HTML via .load() method');
560
+ box.load(desturl + ' ' + opts.itemSelector, undefined, function infscr_ajax_callback(responseText) {
561
+ instance._loadcallback(box, responseText, desturl);
562
+ });
563
+
564
+ break;
565
+
566
+ case 'html':
567
+ instance._debug('Using ' + (method.toUpperCase()) + ' via $.ajax() method');
568
+ $.ajax({
569
+ // params
570
+ url: desturl,
571
+ dataType: opts.dataType,
572
+ complete: function infscr_ajax_callback(jqXHR, textStatus) {
573
+ condition = (typeof (jqXHR.isResolved) !== 'undefined') ? (jqXHR.isResolved()) : (textStatus === "success" || textStatus === "notmodified");
574
+ if (condition) {
575
+ instance._loadcallback(box, jqXHR.responseText, desturl);
576
+ } else {
577
+ instance._error('end');
578
+ }
579
+ }
580
+ });
581
+
582
+ break;
583
+ case 'json':
584
+ instance._debug('Using ' + (method.toUpperCase()) + ' via $.ajax() method');
585
+ $.ajax({
586
+ dataType: 'json',
587
+ type: 'GET',
588
+ url: desturl,
589
+ success: function (data, textStatus, jqXHR) {
590
+ condition = (typeof (jqXHR.isResolved) !== 'undefined') ? (jqXHR.isResolved()) : (textStatus === "success" || textStatus === "notmodified");
591
+ if (opts.appendCallback) {
592
+ // if appendCallback is true, you must defined template in options.
593
+ // note that data passed into _loadcallback is already an html (after processed in opts.template(data)).
594
+ if (opts.template !== undefined) {
595
+ var theData = opts.template(data);
596
+ box.append(theData);
597
+ if (condition) {
598
+ instance._loadcallback(box, theData);
599
+ } else {
600
+ instance._error('end');
601
+ }
602
+ } else {
603
+ instance._debug("template must be defined.");
604
+ instance._error('end');
605
+ }
606
+ } else {
607
+ // if appendCallback is false, we will pass in the JSON object. you should handle it yourself in your callback.
608
+ if (condition) {
609
+ instance._loadcallback(box, data, desturl);
610
+ } else {
611
+ instance._error('end');
612
+ }
613
+ }
614
+ },
615
+ error: function() {
616
+ instance._debug("JSON ajax request failed.");
617
+ instance._error('end');
618
+ }
619
+ });
620
+
621
+ break;
622
+ }
623
+ },
624
+
625
+ // Retrieve next set of content items
626
+ retrieve: function infscr_retrieve(pageNum) {
627
+ pageNum = pageNum || null;
628
+
629
+ var instance = this,
630
+ opts = instance.options;
631
+
632
+ // if behavior is defined and this function is extended, call that instead of default
633
+ if (!!opts.behavior && this['retrieve_'+opts.behavior] !== undefined) {
634
+ this['retrieve_'+opts.behavior].call(this,pageNum);
635
+ return;
636
+ }
637
+
638
+ // for manual triggers, if destroyed, get out of here
639
+ if (opts.state.isDestroyed) {
640
+ this._debug('Instance is destroyed');
641
+ return false;
642
+ }
643
+
644
+ // we dont want to fire the ajax multiple times
645
+ opts.state.isDuringAjax = true;
646
+
647
+ opts.loading.start.call($(opts.contentSelector)[0],opts);
648
+ },
649
+
650
+ // Check to see next page is needed
651
+ scroll: function infscr_scroll() {
652
+
653
+ var opts = this.options,
654
+ state = opts.state;
655
+
656
+ // if behavior is defined and this function is extended, call that instead of default
657
+ if (!!opts.behavior && this['scroll_'+opts.behavior] !== undefined) {
658
+ this['scroll_'+opts.behavior].call(this);
659
+ return;
660
+ }
661
+
662
+ if (state.isDuringAjax || state.isInvalidPage || state.isDone || state.isDestroyed || state.isPaused) {
663
+ return;
664
+ }
665
+
666
+ if (!this._nearbottom()) {
667
+ return;
668
+ }
669
+
670
+ this.retrieve();
671
+
672
+ },
673
+
674
+ // Toggle pause value
675
+ toggle: function infscr_toggle() {
676
+ this._pausing();
677
+ },
678
+
679
+ // Unbind from scroll
680
+ unbind: function infscr_unbind() {
681
+ this._binding('unbind');
682
+ },
683
+
684
+ // update options
685
+ update: function infscr_options(key) {
686
+ if ($.isPlainObject(key)) {
687
+ this.options = $.extend(true,this.options,key);
688
+ }
689
+ }
690
+ };
691
+
692
+
693
+ /*
694
+ ----------------------------
695
+ Infinite Scroll function
696
+ ----------------------------
697
+
698
+ Borrowed logic from the following...
699
+
700
+ jQuery UI
701
+ - https://github.com/jquery/jquery-ui/blob/master/ui/jquery.ui.widget.js
702
+
703
+ jCarousel
704
+ - https://github.com/jsor/jcarousel/blob/master/lib/jquery.jcarousel.js
705
+
706
+ Masonry
707
+ - https://github.com/desandro/masonry/blob/master/jquery.masonry.js
708
+
709
+ */
710
+
711
+ $.fn.infinitescroll = function infscr_init(options, callback) {
712
+
713
+
714
+ var thisCall = typeof options;
715
+
716
+ switch (thisCall) {
717
+
718
+ // method
719
+ case 'string':
720
+ var args = Array.prototype.slice.call(arguments, 1);
721
+
722
+ this.each(function () {
723
+ var instance = $.data(this, 'infinitescroll');
724
+
725
+ if (!instance) {
726
+ // not setup yet
727
+ // return $.error('Method ' + options + ' cannot be called until Infinite Scroll is setup');
728
+ return false;
729
+ }
730
+
731
+ if (!$.isFunction(instance[options]) || options.charAt(0) === "_") {
732
+ // return $.error('No such method ' + options + ' for Infinite Scroll');
733
+ return false;
734
+ }
735
+
736
+ // no errors!
737
+ instance[options].apply(instance, args);
738
+ });
739
+
740
+ break;
741
+
742
+ // creation
743
+ case 'object':
744
+
745
+ this.each(function () {
746
+
747
+ var instance = $.data(this, 'infinitescroll');
748
+
749
+ if (instance) {
750
+
751
+ // update options of current instance
752
+ instance.update(options);
753
+
754
+ } else {
755
+
756
+ // initialize new instance
757
+ instance = new $.infinitescroll(options, callback, this);
758
+
759
+ // don't attach if instantiation failed
760
+ if (!instance.failed) {
761
+ $.data(this, 'infinitescroll', instance);
762
+ }
763
+
764
+ }
765
+
766
+ });
767
+
768
+ break;
769
+
770
+ }
771
+
772
+ return this;
773
+ };
774
+
775
+
776
+
777
+ /*
778
+ * smartscroll: debounced scroll event for jQuery *
779
+ * https://github.com/lukeshumard/smartscroll
780
+ * Based on smartresize by @louis_remi: https://github.com/lrbabe/jquery.smartresize.js *
781
+ * Copyright 2011 Louis-Remi & Luke Shumard * Licensed under the MIT license. *
782
+ */
783
+
784
+ var event = $.event,
785
+ scrollTimeout;
786
+
787
+ event.special.smartscroll = {
788
+ setup: function () {
789
+ $(this).bind("scroll", event.special.smartscroll.handler);
790
+ },
791
+ teardown: function () {
792
+ $(this).unbind("scroll", event.special.smartscroll.handler);
793
+ },
794
+ handler: function (event, execAsap) {
795
+ // Save the context
796
+ var context = this,
797
+ args = arguments;
798
+
799
+ // set correct event type
800
+ event.type = "smartscroll";
801
+
802
+ if (scrollTimeout) { clearTimeout(scrollTimeout); }
803
+ scrollTimeout = setTimeout(function () {
804
+ $(context).trigger('smartscroll', args);
805
+ }, execAsap === "execAsap" ? 0 : 100);
806
+ }
807
+ };
808
+
809
+ $.fn.smartscroll = function (fn) {
810
+ return fn ? this.bind("smartscroll", fn) : this.trigger("smartscroll", ["execAsap"]);
811
+ };
812
+
813
+
814
+ })(window, jQuery);
@@ -1,14 +1 @@
1
- /*
2
- --------------------------------
3
- Infinite Scroll
4
- --------------------------------
5
- + https://github.com/paulirish/infinitescroll
6
- + version 2.0b2.120519
7
- + Copyright 2011 Paul Irish & Luke Shumard
8
- + Licensed under the MIT license
9
-
10
- + Documentation: http://infinite-scroll.com/
11
-
12
- */
13
-
14
- (function(o,i,k){i.infinitescroll=function z(D,F,E){this.element=i(E);if(!this._create(D,F)){this.failed=true}};i.infinitescroll.defaults={loading:{finished:k,finishedMsg:"<em>Congratulations, you've reached the end of the internet.</em>",img:"",msg:null,msgText:"<em>Loading the next set of posts...</em>",selector:null,speed:"fast",start:k},state:{isDuringAjax:false,isInvalidPage:false,isDestroyed:false,isDone:false,isPaused:false,currPage:1},debug:false,behavior:k,binder:i(o),nextSelector:"div.navigation a:first",navSelector:"div.navigation",contentSelector:null,extraScrollPx:150,itemSelector:"div.post",animate:false,pathParse:k,dataType:"html",appendCallback:true,bufferPx:40,errorCallback:function(){},infid:0,pixelsFromNavToBottom:k,path:k,prefill:false};i.infinitescroll.prototype={_binding:function g(F){var D=this,E=D.options;E.v="2.0b2.120520";if(!!E.behavior&&this["_binding_"+E.behavior]!==k){this["_binding_"+E.behavior].call(this);return}if(F!=="bind"&&F!=="unbind"){this._debug("Binding value "+F+" not valid");return false}if(F==="unbind"){(this.options.binder).unbind("smartscroll.infscr."+D.options.infid)}else{(this.options.binder)[F]("smartscroll.infscr."+D.options.infid,function(){D.scroll()})}this._debug("Binding",F)},_create:function t(F,J){var G=i.extend(true,{},i.infinitescroll.defaults,F);this.options=G;var I=i(o);var D=this;if(!D._validate(F)){return false}var H=i(G.nextSelector).attr("href");if(!H){this._debug("Navigation selector not found");return false}G.path=G.path||this._determinepath(H);G.contentSelector=G.contentSelector||this.element;G.loading.selector=G.loading.selector||G.contentSelector;G.loading.msg=G.loading.msg||i('<div id="infscr-loading"><img alt="Loading..." src="'+G.loading.img+'" /><div>'+G.loading.msgText+"</div></div>");(new Image()).src=G.loading.img;if(G.pixelsFromNavToBottom===k){G.pixelsFromNavToBottom=i(document).height()-i(G.navSelector).offset().top}var E=this;G.loading.start=G.loading.start||function(){i(G.navSelector).hide();G.loading.msg.appendTo(G.loading.selector).show(G.loading.speed,i.proxy(function(){this.beginAjax(G)},E))};G.loading.finished=G.loading.finished||function(){G.loading.msg.fadeOut(G.loading.speed)};G.callback=function(K,M,L){if(!!G.behavior&&K["_callback_"+G.behavior]!==k){K["_callback_"+G.behavior].call(i(G.contentSelector)[0],M,L)}if(J){J.call(i(G.contentSelector)[0],M,G,L)}if(G.prefill){I.bind("resize.infinite-scroll",K._prefill)}};if(F.debug){if(Function.prototype.bind&&(typeof console==="object"||typeof console==="function")&&typeof console.log==="object"){["log","info","warn","error","assert","dir","clear","profile","profileEnd"].forEach(function(K){console[K]=this.call(console[K],console)},Function.prototype.bind)}}this._setup();if(G.prefill){this._prefill()}return true},_prefill:function n(){var D=this;var G=i(document);var F=i(o);function E(){return(G.height()<=F.height())}this._prefill=function(){if(E()){D.scroll()}F.bind("resize.infinite-scroll",function(){if(E()){F.unbind("resize.infinite-scroll");D.scroll()}})};this._prefill()},_debug:function q(){if(true!==this.options.debug){return}if(typeof console!=="undefined"&&typeof console.log==="function"){if((Array.prototype.slice.call(arguments)).length===1&&typeof Array.prototype.slice.call(arguments)[0]==="string"){console.log((Array.prototype.slice.call(arguments)).toString())}else{console.log(Array.prototype.slice.call(arguments))}}else{if(!Function.prototype.bind&&typeof console!=="undefined"&&typeof console.log==="object"){Function.prototype.call.call(console.log,console,Array.prototype.slice.call(arguments))}}},_determinepath:function A(E){var D=this.options;if(!!D.behavior&&this["_determinepath_"+D.behavior]!==k){return this["_determinepath_"+D.behavior].call(this,E)}if(!!D.pathParse){this._debug("pathParse manual");return D.pathParse(E,this.options.state.currPage+1)}else{if(E.match(/^(.*?)\b2\b(.*?$)/)){E=E.match(/^(.*?)\b2\b(.*?$)/).slice(1)}else{if(E.match(/^(.*?)2(.*?$)/)){if(E.match(/^(.*?page=)2(\/.*|$)/)){E=E.match(/^(.*?page=)2(\/.*|$)/).slice(1);return E}E=E.match(/^(.*?)2(.*?$)/).slice(1)}else{if(E.match(/^(.*?page=)1(\/.*|$)/)){E=E.match(/^(.*?page=)1(\/.*|$)/).slice(1);return E}else{this._debug("Sorry, we couldn't parse your Next (Previous Posts) URL. Verify your the css selector points to the correct A tag. If you still get this error: yell, scream, and kindly ask for help at infinite-scroll.com.");D.state.isInvalidPage=true}}}}this._debug("determinePath",E);return E},_error:function v(E){var D=this.options;if(!!D.behavior&&this["_error_"+D.behavior]!==k){this["_error_"+D.behavior].call(this,E);return}if(E!=="destroy"&&E!=="end"){E="unknown"}this._debug("Error",E);if(E==="end"){this._showdonemsg()}D.state.isDone=true;D.state.currPage=1;D.state.isPaused=false;this._binding("unbind")},_loadcallback:function c(H,G,E){var D=this.options,J=this.options.callback,L=(D.state.isDone)?"done":(!D.appendCallback)?"no-append":"append",K;if(!!D.behavior&&this["_loadcallback_"+D.behavior]!==k){this["_loadcallback_"+D.behavior].call(this,H,G);return}switch(L){case"done":this._showdonemsg();return false;case"no-append":if(D.dataType==="html"){G="<div>"+G+"</div>";G=i(G).find(D.itemSelector)}break;case"append":var F=H.children();if(F.length===0){return this._error("end")}K=document.createDocumentFragment();while(H[0].firstChild){K.appendChild(H[0].firstChild)}this._debug("contentSelector",i(D.contentSelector)[0]);i(D.contentSelector)[0].appendChild(K);G=F.get();break}D.loading.finished.call(i(D.contentSelector)[0],D);if(D.animate){var I=i(o).scrollTop()+i("#infscr-loading").height()+D.extraScrollPx+"px";i("html,body").animate({scrollTop:I},800,function(){D.state.isDuringAjax=false})}if(!D.animate){D.state.isDuringAjax=false}J(this,G,E);if(D.prefill){this._prefill()}},_nearbottom:function u(){var E=this.options,D=0+i(document).height()-(E.binder.scrollTop())-i(o).height();if(!!E.behavior&&this["_nearbottom_"+E.behavior]!==k){return this["_nearbottom_"+E.behavior].call(this)}this._debug("math:",D,E.pixelsFromNavToBottom);return(D-E.bufferPx<E.pixelsFromNavToBottom)},_pausing:function l(E){var D=this.options;if(!!D.behavior&&this["_pausing_"+D.behavior]!==k){this["_pausing_"+D.behavior].call(this,E);return}if(E!=="pause"&&E!=="resume"&&E!==null){this._debug("Invalid argument. Toggling pause value instead")}E=(E&&(E==="pause"||E==="resume"))?E:"toggle";switch(E){case"pause":D.state.isPaused=true;break;case"resume":D.state.isPaused=false;break;case"toggle":D.state.isPaused=!D.state.isPaused;break}this._debug("Paused",D.state.isPaused);return false},_setup:function r(){var D=this.options;if(!!D.behavior&&this["_setup_"+D.behavior]!==k){this["_setup_"+D.behavior].call(this);return}this._binding("bind");return false},_showdonemsg:function a(){var D=this.options;if(!!D.behavior&&this["_showdonemsg_"+D.behavior]!==k){this["_showdonemsg_"+D.behavior].call(this);return}D.loading.msg.find("img").hide().parent().find("div").html(D.loading.finishedMsg).animate({opacity:1},2000,function(){i(this).parent().fadeOut(D.loading.speed)});D.errorCallback.call(i(D.contentSelector)[0],"done")},_validate:function w(E){for(var D in E){if(D.indexOf&&D.indexOf("Selector")>-1&&i(E[D]).length===0){this._debug("Your "+D+" found no elements.");return false}}return true},bind:function p(){this._binding("bind")},destroy:function C(){this.options.state.isDestroyed=true;return this._error("destroy")},pause:function e(){this._pausing("pause")},resume:function h(){this._pausing("resume")},beginAjax:function B(G){var E=this,I=G.path,F,D,K,J;G.state.currPage++;F=i(G.contentSelector).is("table")?i("<tbody/>"):i("<div/>");D=(typeof I==="function")?I(G.state.currPage):I.join(G.state.currPage);E._debug("heading into ajax",D);K=(G.dataType==="html"||G.dataType==="json")?G.dataType:"html+callback";if(G.appendCallback&&G.dataType==="html"){K+="+callback"}switch(K){case"html+callback":E._debug("Using HTML via .load() method");F.load(D+" "+G.itemSelector,k,function H(L){E._loadcallback(F,L,D)});break;case"html":E._debug("Using "+(K.toUpperCase())+" via $.ajax() method");i.ajax({url:D,dataType:G.dataType,complete:function H(L,M){J=(typeof(L.isResolved)!=="undefined")?(L.isResolved()):(M==="success"||M==="notmodified");if(J){E._loadcallback(F,L.responseText,D)}else{E._error("end")}}});break;case"json":E._debug("Using "+(K.toUpperCase())+" via $.ajax() method");i.ajax({dataType:"json",type:"GET",url:D,success:function(N,O,M){J=(typeof(M.isResolved)!=="undefined")?(M.isResolved()):(O==="success"||O==="notmodified");if(G.appendCallback){if(G.template!==k){var L=G.template(N);F.append(L);if(J){E._loadcallback(F,L)}else{E._error("end")}}else{E._debug("template must be defined.");E._error("end")}}else{if(J){E._loadcallback(F,N,D)}else{E._error("end")}}},error:function(){E._debug("JSON ajax request failed.");E._error("end")}});break}},retrieve:function b(F){F=F||null;var D=this,E=D.options;if(!!E.behavior&&this["retrieve_"+E.behavior]!==k){this["retrieve_"+E.behavior].call(this,F);return}if(E.state.isDestroyed){this._debug("Instance is destroyed");return false}E.state.isDuringAjax=true;E.loading.start.call(i(E.contentSelector)[0],E)},scroll:function f(){var D=this.options,E=D.state;if(!!D.behavior&&this["scroll_"+D.behavior]!==k){this["scroll_"+D.behavior].call(this);return}if(E.isDuringAjax||E.isInvalidPage||E.isDone||E.isDestroyed||E.isPaused){return}if(!this._nearbottom()){return}this.retrieve()},toggle:function y(){this._pausing()},unbind:function m(){this._binding("unbind")},update:function j(D){if(i.isPlainObject(D)){this.options=i.extend(true,this.options,D)}}};i.fn.infinitescroll=function d(F,G){var E=typeof F;switch(E){case"string":var D=Array.prototype.slice.call(arguments,1);this.each(function(){var H=i.data(this,"infinitescroll");if(!H){return false}if(!i.isFunction(H[F])||F.charAt(0)==="_"){return false}H[F].apply(H,D)});break;case"object":this.each(function(){var H=i.data(this,"infinitescroll");if(H){H.update(F)}else{H=new i.infinitescroll(F,G,this);if(!H.failed){i.data(this,"infinitescroll",H)}}});break}return this};var x=i.event,s;x.special.smartscroll={setup:function(){i(this).bind("scroll",x.special.smartscroll.handler)},teardown:function(){i(this).unbind("scroll",x.special.smartscroll.handler)},handler:function(G,D){var F=this,E=arguments;G.type="smartscroll";if(s){clearTimeout(s)}s=setTimeout(function(){i.event.handle.apply(F,E)},D==="execAsap"?0:100)}};i.fn.smartscroll=function(D){return D?this.bind("smartscroll",D):this.trigger("smartscroll",["execAsap"])}})(window,jQuery);
1
+ (function(e,t,n){"use strict";t.infinitescroll=function(n,r,i){this.element=t(i);if(!this._create(n,r)){this.failed=true}};t.infinitescroll.defaults={loading:{finished:n,finishedMsg:"<em>Congratulations, you've reached the end of the internet.</em>",img:"",msg:null,msgText:"<em>Loading the next set of posts...</em>",selector:null,speed:"fast",start:n},state:{isDuringAjax:false,isInvalidPage:false,isDestroyed:false,isDone:false,isPaused:false,isBeyondMaxPage:false,currPage:1},debug:false,behavior:n,binder:t(e),nextSelector:"div.navigation a:first",navSelector:"div.navigation",contentSelector:null,extraScrollPx:150,itemSelector:"div.post",animate:false,pathParse:n,dataType:"html",appendCallback:true,bufferPx:40,errorCallback:function(){},infid:0,pixelsFromNavToBottom:n,path:n,prefill:false,maxPage:n};t.infinitescroll.prototype={_binding:function(t){var r=this,i=r.options;i.v="2.0b2.120520";if(!!i.behavior&&this["_binding_"+i.behavior]!==n){this["_binding_"+i.behavior].call(this);return}if(t!=="bind"&&t!=="unbind"){this._debug("Binding value "+t+" not valid");return false}if(t==="unbind"){this.options.binder.unbind("smartscroll.infscr."+r.options.infid)}else{this.options.binder[t]("smartscroll.infscr."+r.options.infid,function(){r.scroll()})}this._debug("Binding",t)},_create:function(i,s){var o=t.extend(true,{},t.infinitescroll.defaults,i);this.options=o;var u=t(e);var a=this;if(!a._validate(i)){return false}var f=t(o.nextSelector).attr("href");if(!f){this._debug("Navigation selector not found");return false}o.path=o.path||this._determinepath(f);o.contentSelector=o.contentSelector||this.element;o.loading.selector=o.loading.selector||o.contentSelector;o.loading.msg=o.loading.msg||t('<div id="infscr-loading"><img alt="Loading..." src="'+o.loading.img+'" /><div>'+o.loading.msgText+"</div></div>");(new Image).src=o.loading.img;if(o.pixelsFromNavToBottom===n){o.pixelsFromNavToBottom=t(document).height()-t(o.navSelector).offset().top;this._debug("pixelsFromNavToBottom: "+o.pixelsFromNavToBottom)}var l=this;o.loading.start=o.loading.start||function(){t(o.navSelector).hide();o.loading.msg.appendTo(o.loading.selector).show(o.loading.speed,t.proxy(function(){this.beginAjax(o)},l))};o.loading.finished=o.loading.finished||function(){if(!o.state.isBeyondMaxPage)o.loading.msg.fadeOut(o.loading.speed)};o.callback=function(e,r,i){if(!!o.behavior&&e["_callback_"+o.behavior]!==n){e["_callback_"+o.behavior].call(t(o.contentSelector)[0],r,i)}if(s){s.call(t(o.contentSelector)[0],r,o,i)}if(o.prefill){u.bind("resize.infinite-scroll",e._prefill)}};if(i.debug){if(Function.prototype.bind&&(typeof console==="object"||typeof console==="function")&&typeof console.log==="object"){["log","info","warn","error","assert","dir","clear","profile","profileEnd"].forEach(function(e){console[e]=this.call(console[e],console)},Function.prototype.bind)}}this._setup();if(o.prefill){this._prefill()}return true},_prefill:function(){function s(){return r.options.contentSelector.height()<=i.height()}var r=this;var i=t(e);this._prefill=function(){if(s()){r.scroll()}i.bind("resize.infinite-scroll",function(){if(s()){i.unbind("resize.infinite-scroll");r.scroll()}})};this._prefill()},_debug:function(){if(true!==this.options.debug){return}if(typeof console!=="undefined"&&typeof console.log==="function"){if(Array.prototype.slice.call(arguments).length===1&&typeof Array.prototype.slice.call(arguments)[0]==="string"){console.log(Array.prototype.slice.call(arguments).toString())}else{console.log(Array.prototype.slice.call(arguments))}}else if(!Function.prototype.bind&&typeof console!=="undefined"&&typeof console.log==="object"){Function.prototype.call.call(console.log,console,Array.prototype.slice.call(arguments))}},_determinepath:function(t){var r=this.options;if(!!r.behavior&&this["_determinepath_"+r.behavior]!==n){return this["_determinepath_"+r.behavior].call(this,t)}if(!!r.pathParse){this._debug("pathParse manual");return r.pathParse(t,this.options.state.currPage+1)}else if(t.match(/^(.*?)\b2\b(.*?$)/)){t=t.match(/^(.*?)\b2\b(.*?$)/).slice(1)}else if(t.match(/^(.*?)2(.*?$)/)){if(t.match(/^(.*?page=)2(\/.*|$)/)){t=t.match(/^(.*?page=)2(\/.*|$)/).slice(1);return t}t=t.match(/^(.*?)2(.*?$)/).slice(1)}else{if(t.match(/^(.*?page=)1(\/.*|$)/)){t=t.match(/^(.*?page=)1(\/.*|$)/).slice(1);return t}else{this._debug("Sorry, we couldn't parse your Next (Previous Posts) URL. Verify your the css selector points to the correct A tag. If you still get this error: yell, scream, and kindly ask for help at infinite-scroll.com.");r.state.isInvalidPage=true}}this._debug("determinePath",t);return t},_error:function(t){var r=this.options;if(!!r.behavior&&this["_error_"+r.behavior]!==n){this["_error_"+r.behavior].call(this,t);return}if(t!=="destroy"&&t!=="end"){t="unknown"}this._debug("Error",t);if(t==="end"||r.state.isBeyondMaxPage){this._showdonemsg()}r.state.isDone=true;r.state.currPage=1;r.state.isPaused=false;r.state.isBeyondMaxPage=false;this._binding("unbind")},_loadcallback:function(i,s,o){var u=this.options,a=this.options.callback,f=u.state.isDone?"done":!u.appendCallback?"no-append":"append",l;if(!!u.behavior&&this["_loadcallback_"+u.behavior]!==n){this["_loadcallback_"+u.behavior].call(this,i,s);return}switch(f){case"done":this._showdonemsg();return false;case"no-append":if(u.dataType==="html"){s="<div>"+s+"</div>";s=t(s).find(u.itemSelector)}break;case"append":var c=i.children();if(c.length===0){return this._error("end")}l=document.createDocumentFragment();while(i[0].firstChild){l.appendChild(i[0].firstChild)}this._debug("contentSelector",t(u.contentSelector)[0]);t(u.contentSelector)[0].appendChild(l);s=c.get();break}u.loading.finished.call(t(u.contentSelector)[0],u);if(u.animate){var h=t(e).scrollTop()+t(u.loading.msg).height()+u.extraScrollPx+"px";t("html,body").animate({scrollTop:h},800,function(){u.state.isDuringAjax=false})}if(!u.animate){u.state.isDuringAjax=false}a(this,s,o);if(u.prefill){this._prefill()}},_nearbottom:function(){var i=this.options,s=0+t(document).height()-i.binder.scrollTop()-t(e).height();if(!!i.behavior&&this["_nearbottom_"+i.behavior]!==n){return this["_nearbottom_"+i.behavior].call(this)}this._debug("math:",s,i.pixelsFromNavToBottom);return s-i.bufferPx<i.pixelsFromNavToBottom},_pausing:function(t){var r=this.options;if(!!r.behavior&&this["_pausing_"+r.behavior]!==n){this["_pausing_"+r.behavior].call(this,t);return}if(t!=="pause"&&t!=="resume"&&t!==null){this._debug("Invalid argument. Toggling pause value instead")}t=t&&(t==="pause"||t==="resume")?t:"toggle";switch(t){case"pause":r.state.isPaused=true;break;case"resume":r.state.isPaused=false;break;case"toggle":r.state.isPaused=!r.state.isPaused;break}this._debug("Paused",r.state.isPaused);return false},_setup:function(){var t=this.options;if(!!t.behavior&&this["_setup_"+t.behavior]!==n){this["_setup_"+t.behavior].call(this);return}this._binding("bind");return false},_showdonemsg:function(){var r=this.options;if(!!r.behavior&&this["_showdonemsg_"+r.behavior]!==n){this["_showdonemsg_"+r.behavior].call(this);return}r.loading.msg.find("img").hide().parent().find("div").html(r.loading.finishedMsg).animate({opacity:1},2e3,function(){t(this).parent().fadeOut(r.loading.speed)});r.errorCallback.call(t(r.contentSelector)[0],"done")},_validate:function(n){for(var r in n){if(r.indexOf&&r.indexOf("Selector")>-1&&t(n[r]).length===0){this._debug("Your "+r+" found no elements.");return false}}return true},bind:function(){this._binding("bind")},destroy:function(){this.options.state.isDestroyed=true;this.options.loading.finished();return this._error("destroy")},pause:function(){this._pausing("pause")},resume:function(){this._pausing("resume")},beginAjax:function(r){var i=this,s=r.path,o,u,a,f;r.state.currPage++;if(r.maxPage!=n&&r.state.currPage>r.maxPage){r.state.isBeyondMaxPage=true;this.destroy();return}o=t(r.contentSelector).is("table, tbody")?t("<tbody/>"):t("<div/>");u=typeof s==="function"?s(r.state.currPage):s.join(r.state.currPage);i._debug("heading into ajax",u);a=r.dataType==="html"||r.dataType==="json"?r.dataType:"html+callback";if(r.appendCallback&&r.dataType==="html"){a+="+callback"}switch(a){case"html+callback":i._debug("Using HTML via .load() method");o.load(u+" "+r.itemSelector,n,function(t){i._loadcallback(o,t,u)});break;case"html":i._debug("Using "+a.toUpperCase()+" via $.ajax() method");t.ajax({url:u,dataType:r.dataType,complete:function(t,n){f=typeof t.isResolved!=="undefined"?t.isResolved():n==="success"||n==="notmodified";if(f){i._loadcallback(o,t.responseText,u)}else{i._error("end")}}});break;case"json":i._debug("Using "+a.toUpperCase()+" via $.ajax() method");t.ajax({dataType:"json",type:"GET",url:u,success:function(e,t,s){f=typeof s.isResolved!=="undefined"?s.isResolved():t==="success"||t==="notmodified";if(r.appendCallback){if(r.template!==n){var a=r.template(e);o.append(a);if(f){i._loadcallback(o,a)}else{i._error("end")}}else{i._debug("template must be defined.");i._error("end")}}else{if(f){i._loadcallback(o,e,u)}else{i._error("end")}}},error:function(){i._debug("JSON ajax request failed.");i._error("end")}});break}},retrieve:function(r){r=r||null;var i=this,s=i.options;if(!!s.behavior&&this["retrieve_"+s.behavior]!==n){this["retrieve_"+s.behavior].call(this,r);return}if(s.state.isDestroyed){this._debug("Instance is destroyed");return false}s.state.isDuringAjax=true;s.loading.start.call(t(s.contentSelector)[0],s)},scroll:function(){var t=this.options,r=t.state;if(!!t.behavior&&this["scroll_"+t.behavior]!==n){this["scroll_"+t.behavior].call(this);return}if(r.isDuringAjax||r.isInvalidPage||r.isDone||r.isDestroyed||r.isPaused){return}if(!this._nearbottom()){return}this.retrieve()},toggle:function(){this._pausing()},unbind:function(){this._binding("unbind")},update:function(n){if(t.isPlainObject(n)){this.options=t.extend(true,this.options,n)}}};t.fn.infinitescroll=function(n,r){var i=typeof n;switch(i){case"string":var s=Array.prototype.slice.call(arguments,1);this.each(function(){var e=t.data(this,"infinitescroll");if(!e){return false}if(!t.isFunction(e[n])||n.charAt(0)==="_"){return false}e[n].apply(e,s)});break;case"object":this.each(function(){var e=t.data(this,"infinitescroll");if(e){e.update(n)}else{e=new t.infinitescroll(n,r,this);if(!e.failed){t.data(this,"infinitescroll",e)}}});break}return this};var r=t.event,i;r.special.smartscroll={setup:function(){t(this).bind("scroll",r.special.smartscroll.handler)},teardown:function(){t(this).unbind("scroll",r.special.smartscroll.handler)},handler:function(e,n){var r=this,s=arguments;e.type="smartscroll";if(i){clearTimeout(i)}i=setTimeout(function(){t(r).trigger("smartscroll",s)},n==="execAsap"?0:100)}};t.fn.smartscroll=function(e){return e?this.bind("smartscroll",e):this.trigger("smartscroll",["execAsap"])}})(window,jQuery)
@@ -14,7 +14,7 @@ http://developer.yahoo.com/yui/license.html
14
14
  version: 3.3.0
15
15
  build: 3167
16
16
  */
17
- .sausage-set {font:13px/1.231 'Hevetica Neueu', Helvetica, Arial, sans-serif;*font-size:small;*font:x-small;} .sausage-set select, .sausage-set input, .sausage-set button, .sausage-set textarea{font:99% "lucida grande", .sausage-set tahoma, .sausage-set verdana, .sausage-set arial, .sausage-set sans-serif;} .sausage-set table{font-size:inherit;font:100%;} .sausage-set pre, .sausage-set code, .sausage-set kbd, .sausage-set samp, .sausage-set tt{font-family:monospace;*font-size:108%;line-height:100%;}
17
+ .sausage-set {font:13px/1.231 'Hevetica Neueu', Helvetica, Arial, sans-serif;*font-size:small;*font:x-small;} .sausage-set select, .sausage-set input, .sausage-set button, .sausage-set textarea{font:99% "lucida grande", tahoma, verdana, arial, sans-serif;} .sausage-set table{font-size:inherit;font:100%;} .sausage-set pre, .sausage-set code, .sausage-set kbd, .sausage-set samp, .sausage-set tt{font-family:monospace;*font-size:108%;line-height:100%;}
18
18
 
19
19
  /*
20
20
  Copyright (c) 2010, .reset Yahoo! Inc. All rights reserved.
@@ -32,4 +32,4 @@ http://developer.yahoo.com/yui/license.html
32
32
  version: 3.3.0
33
33
  build: 3167
34
34
  */
35
- .reset {font:13px/1.231 Georgia, sans-serif;*font-size:small;*font:x-small;} .reset select, .reset input, .reset button, .reset textarea{font:99% "lucida grande", .reset tahoma, .reset verdana, .reset arial, .reset sans-serif;} .reset table{font-size:inherit;font:100%;} .reset pre, .reset code, .reset kbd, .reset samp, .reset tt{font-family:monospace;*font-size:108%;line-height:100%;}
35
+ .reset {font:13px/1.231 Georgia, sans-serif;*font-size:small;*font:x-small;} .reset select, .reset input, .reset button, .reset textarea{font:99% "lucida grande", tahoma, verdana, arial, sans-serif;} .reset table{font-size:inherit;font:100%;} .reset pre, .reset code, .reset kbd, .reset samp, .reset tt{font-family:monospace;*font-size:108%;line-height:100%;}
metadata CHANGED
@@ -1,110 +1,97 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: masonry-rails
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.0
5
- prerelease:
4
+ version: 0.2.1
6
5
  platform: ruby
7
6
  authors:
8
7
  - Kristian Mandrup
9
8
  autorequire:
10
9
  bindir: bin
11
10
  cert_chain: []
12
- date: 2013-03-21 00:00:00.000000000 Z
11
+ date: 2013-12-02 00:00:00.000000000 Z
13
12
  dependencies:
14
13
  - !ruby/object:Gem::Dependency
15
14
  name: rails
16
15
  requirement: !ruby/object:Gem::Requirement
17
- none: false
18
16
  requirements:
19
- - - ! '>='
17
+ - - '>='
20
18
  - !ruby/object:Gem::Version
21
19
  version: '0'
22
20
  type: :runtime
23
21
  prerelease: false
24
22
  version_requirements: !ruby/object:Gem::Requirement
25
- none: false
26
23
  requirements:
27
- - - ! '>='
24
+ - - '>='
28
25
  - !ruby/object:Gem::Version
29
26
  version: '0'
30
27
  - !ruby/object:Gem::Dependency
31
28
  name: rspec
32
29
  requirement: !ruby/object:Gem::Requirement
33
- none: false
34
30
  requirements:
35
- - - ! '>'
31
+ - - '>'
36
32
  - !ruby/object:Gem::Version
37
- version: 2.8.0
33
+ version: 2.10.0
38
34
  type: :development
39
35
  prerelease: false
40
36
  version_requirements: !ruby/object:Gem::Requirement
41
- none: false
42
37
  requirements:
43
- - - ! '>'
38
+ - - '>'
44
39
  - !ruby/object:Gem::Version
45
- version: 2.8.0
40
+ version: 2.10.0
46
41
  - !ruby/object:Gem::Dependency
47
42
  name: rdoc
48
43
  requirement: !ruby/object:Gem::Requirement
49
- none: false
50
44
  requirements:
51
- - - ! '>='
45
+ - - '>'
52
46
  - !ruby/object:Gem::Version
53
47
  version: '3.12'
54
48
  type: :development
55
49
  prerelease: false
56
50
  version_requirements: !ruby/object:Gem::Requirement
57
- none: false
58
51
  requirements:
59
- - - ! '>='
52
+ - - '>'
60
53
  - !ruby/object:Gem::Version
61
54
  version: '3.12'
62
55
  - !ruby/object:Gem::Dependency
63
56
  name: bundler
64
57
  requirement: !ruby/object:Gem::Requirement
65
- none: false
66
58
  requirements:
67
- - - ! '>'
59
+ - - '>'
68
60
  - !ruby/object:Gem::Version
69
- version: 1.0.0
61
+ version: 1.2.0
70
62
  type: :development
71
63
  prerelease: false
72
64
  version_requirements: !ruby/object:Gem::Requirement
73
- none: false
74
65
  requirements:
75
- - - ! '>'
66
+ - - '>'
76
67
  - !ruby/object:Gem::Version
77
- version: 1.0.0
68
+ version: 1.2.0
78
69
  - !ruby/object:Gem::Dependency
79
70
  name: jeweler
80
71
  requirement: !ruby/object:Gem::Requirement
81
- none: false
82
72
  requirements:
83
- - - ! '>='
73
+ - - '>'
84
74
  - !ruby/object:Gem::Version
85
75
  version: 1.8.4
86
76
  type: :development
87
77
  prerelease: false
88
78
  version_requirements: !ruby/object:Gem::Requirement
89
- none: false
90
79
  requirements:
91
- - - ! '>='
80
+ - - '>'
92
81
  - !ruby/object:Gem::Version
93
82
  version: 1.8.4
94
83
  - !ruby/object:Gem::Dependency
95
84
  name: simplecov
96
85
  requirement: !ruby/object:Gem::Requirement
97
- none: false
98
86
  requirements:
99
- - - ! '>='
87
+ - - '>='
100
88
  - !ruby/object:Gem::Version
101
89
  version: '0.5'
102
90
  type: :development
103
91
  prerelease: false
104
92
  version_requirements: !ruby/object:Gem::Requirement
105
- none: false
106
93
  requirements:
107
- - - ! '>='
94
+ - - '>='
108
95
  - !ruby/object:Gem::Version
109
96
  version: '0.5'
110
97
  description: Masonry will rock your world!
@@ -171,6 +158,7 @@ files:
171
158
  - vendor/assets/javascripts/masonry/jquery.event-drag.js
172
159
  - vendor/assets/javascripts/masonry/jquery.imagesloaded.js
173
160
  - vendor/assets/javascripts/masonry/jquery.imagesloaded.min.js
161
+ - vendor/assets/javascripts/masonry/jquery.infinitescroll.js
174
162
  - vendor/assets/javascripts/masonry/jquery.infinitescroll.min.js
175
163
  - vendor/assets/javascripts/masonry/jquery.loremimages.min.js
176
164
  - vendor/assets/javascripts/masonry/jquery.masonry.js
@@ -197,29 +185,25 @@ files:
197
185
  homepage: http://github.com/kristianmandrup/masonry-rails
198
186
  licenses:
199
187
  - MIT
188
+ metadata: {}
200
189
  post_install_message:
201
190
  rdoc_options: []
202
191
  require_paths:
203
192
  - lib
204
193
  required_ruby_version: !ruby/object:Gem::Requirement
205
- none: false
206
194
  requirements:
207
- - - ! '>='
195
+ - - '>='
208
196
  - !ruby/object:Gem::Version
209
197
  version: '0'
210
- segments:
211
- - 0
212
- hash: 1844422040452268934
213
198
  required_rubygems_version: !ruby/object:Gem::Requirement
214
- none: false
215
199
  requirements:
216
- - - ! '>='
200
+ - - '>='
217
201
  - !ruby/object:Gem::Version
218
202
  version: '0'
219
203
  requirements: []
220
204
  rubyforge_project:
221
- rubygems_version: 1.8.25
205
+ rubygems_version: 2.0.0
222
206
  signing_key:
223
- specification_version: 3
207
+ specification_version: 4
224
208
  summary: Use JQuery Masonry with Rails asset pipeline
225
209
  test_files: []