mirror of
				https://github.com/ZetaKebab/kesper.git
				synced 2025-11-04 08:09:49 +00:00 
			
		
		
		
	Merge pull request #130 from jillesme/master
Optimize index.js and add style consistency
This commit is contained in:
		@@ -2,23 +2,51 @@
 | 
				
			|||||||
 * Main JS file for Casper behaviours
 | 
					 * Main JS file for Casper behaviours
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*globals jQuery, document */
 | 
					/* globals jQuery, document */
 | 
				
			||||||
(function ($) {
 | 
					(function ($, sr, undefined) {
 | 
				
			||||||
    "use strict";
 | 
					    "use strict";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    $(document).ready(function(){
 | 
					    var $document = $(document),
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $(".post-content").fitVids();
 | 
					        // debouncing function from John Hann
 | 
				
			||||||
 | 
					        // http://unscriptable.com/index.php/2009/03/20/debouncing-javascript-methods/
 | 
				
			||||||
 | 
					        debounce = function (func, threshold, execAsap) {
 | 
				
			||||||
 | 
					            var timeout;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        function casperFullImg() {
 | 
					            return function debounced () {
 | 
				
			||||||
            $("img").each( function() {
 | 
					                var obj = this, args = arguments;
 | 
				
			||||||
                var contentWidth = $(".post-content").outerWidth(); // Width of the content
 | 
					                function delayed () {
 | 
				
			||||||
                var imageWidth = $(this)[0].naturalWidth; // Original image resolution
 | 
					                    if (!execAsap) {
 | 
				
			||||||
 | 
					                        func.apply(obj, args);
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
 | 
					                    timeout = null;
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                if (timeout) {
 | 
				
			||||||
 | 
					                    clearTimeout(timeout);
 | 
				
			||||||
 | 
					                } else if (execAsap) {
 | 
				
			||||||
 | 
					                    func.apply(obj, args);
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                timeout = setTimeout(delayed, threshold || 100);
 | 
				
			||||||
 | 
					            };
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    $document.ready(function () {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        var $postContent = $(".post-content");
 | 
				
			||||||
 | 
					        $postContent.fitVids();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        var casperFullImg = function () {
 | 
				
			||||||
 | 
					            $("img").each(function () {
 | 
				
			||||||
 | 
					                var $this = $(this),
 | 
				
			||||||
 | 
					                    contentWidth = $postContent.outerWidth(), // Width of the content
 | 
				
			||||||
 | 
					                    imageWidth = $this[0].naturalWidth; // Original image resolution
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                if (imageWidth >= contentWidth) {
 | 
					                if (imageWidth >= contentWidth) {
 | 
				
			||||||
                    $(this).addClass('full-img');
 | 
					                    $this.addClass('full-img');
 | 
				
			||||||
                } else {
 | 
					                } else {
 | 
				
			||||||
                    $(this).removeClass('full-img');
 | 
					                    $this.removeClass('full-img');
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
            });
 | 
					            });
 | 
				
			||||||
        };
 | 
					        };
 | 
				
			||||||
@@ -30,61 +58,38 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    });
 | 
					    });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}(jQuery));
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
(function($,sr){
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  // debouncing function from John Hann
 | 
					 | 
				
			||||||
  // http://unscriptable.com/index.php/2009/03/20/debouncing-javascript-methods/
 | 
					 | 
				
			||||||
  var debounce = function (func, threshold, execAsap) {
 | 
					 | 
				
			||||||
      var timeout;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      return function debounced () {
 | 
					 | 
				
			||||||
          var obj = this, args = arguments;
 | 
					 | 
				
			||||||
          function delayed () {
 | 
					 | 
				
			||||||
              if (!execAsap)
 | 
					 | 
				
			||||||
                  func.apply(obj, args);
 | 
					 | 
				
			||||||
              timeout = null;
 | 
					 | 
				
			||||||
          };
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
          if (timeout)
 | 
					 | 
				
			||||||
              clearTimeout(timeout);
 | 
					 | 
				
			||||||
          else if (execAsap)
 | 
					 | 
				
			||||||
              func.apply(obj, args);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
          timeout = setTimeout(delayed, threshold || 100);
 | 
					 | 
				
			||||||
      };
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
    // smartresize
 | 
					    // smartresize
 | 
				
			||||||
  jQuery.fn[sr] = function(fn){  return fn ? this.bind('resize', debounce(fn)) : this.trigger(sr); };
 | 
					    jQuery.fn[sr] = function(fn) { return fn ? this.bind('resize', debounce(fn)) : this.trigger(sr); };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
})(jQuery,'smartresize');
 | 
					    // Arctic Scroll by Paul Adam Davis
 | 
				
			||||||
 | 
					    // https://github.com/PaulAdamDavis/Arctic-Scroll
 | 
				
			||||||
// Arctic Scroll by Paul Adam Davis
 | 
					 | 
				
			||||||
// https://github.com/PaulAdamDavis/Arctic-Scroll
 | 
					 | 
				
			||||||
(function ($) {
 | 
					 | 
				
			||||||
    $.fn.arctic_scroll = function (options) {
 | 
					    $.fn.arctic_scroll = function (options) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        var defaults = {
 | 
					        var defaults = {
 | 
				
			||||||
            elem: $(this),
 | 
					            elem: $(this),
 | 
				
			||||||
            speed: 500
 | 
					            speed: 500
 | 
				
			||||||
        };
 | 
					        },
 | 
				
			||||||
        var options = $.extend(defaults, options);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        options.elem.click(function(event){     
 | 
					        allOptions = $.extend(defaults, options);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        allOptions.elem.click(function (event) {
 | 
				
			||||||
            event.preventDefault();
 | 
					            event.preventDefault();
 | 
				
			||||||
            var offset = ($(this).attr('data-offset')) ? $(this).attr('data-offset') : false,
 | 
					            var $this = $(this),
 | 
				
			||||||
                position = ($(this).attr('data-position')) ? $(this).attr('data-position') : false;         
 | 
					                $htmlBody = $('html, body'),
 | 
				
			||||||
 | 
					                offset = ($this.attr('data-offset')) ? $this.attr('data-offset') : false,
 | 
				
			||||||
 | 
					                position = ($this.attr('data-position')) ? $this.attr('data-position') : false,
 | 
				
			||||||
 | 
					                toMove;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            if (offset) {
 | 
					            if (offset) {
 | 
				
			||||||
                var toMove = parseInt(offset);
 | 
					                toMove = parseInt(offset);
 | 
				
			||||||
                $('html,body').stop(true, false).animate({scrollTop: ($(this.hash).offset().top + toMove) }, options.speed);
 | 
					                $htmlBody.stop(true, false).animate({scrollTop: ($(this.hash).offset().top + toMove) }, allOptions.speed);
 | 
				
			||||||
            } else if (position) {
 | 
					            } else if (position) {
 | 
				
			||||||
                var toMove = parseInt(position);
 | 
					                toMove = parseInt(position);
 | 
				
			||||||
                $('html,body').stop(true, false).animate({scrollTop: toMove }, options.speed);
 | 
					                $htmlBody.stop(true, false).animate({scrollTop: toMove }, allOptions.speed);
 | 
				
			||||||
            } else {
 | 
					            } else {
 | 
				
			||||||
                $('html,body').stop(true, false).animate({scrollTop: ($(this.hash).offset().top) }, options.speed);
 | 
					                $htmlBody.stop(true, false).animate({scrollTop: ($(this.hash).offset().top) }, allOptions.speed);
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
})(jQuery);
 | 
					})(jQuery, 'smartresize');
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user