Skip to content

Instantly share code, notes, and snippets.

@mach3
Last active August 29, 2015 13:56
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
Star You must be signed in to star a gist
Save mach3/8841906 to your computer and use it in GitHub Desktop.
test jquery-lineup update
(function($){
/**
* LineUp
* ------
* Fix heights of the cols in the same row
*
* @class
* @param String selector
* @param Object option
*/
var LineUp = function(selector, option){
var my = this;
my.option = {
onFontResize : true,
checkFontInterval : 10,
fontSamplerName : "lineup-font-size-sampler",
onResize : true,
after: $.noop
};
my.nodes = null;
my.checkFontTimer = null;
my.sampler = null;
/**
* Initialize with selector
*
* @constructor
* @param String selector
* @param Object option
* @return LineUp
*/
my.init = function(selector, option){
this.nodes = $(selector);
this.config(option);
this.refresh();
if(this.option.onResize){
$(window).on("resize", $.proxy(this.refresh, this));
}
if(this.option.onFontResize){
this.onFontResize($.proxy(this.refresh, this));
}
return this;
};
/**
* Configure option
*
* @param Object option
*/
my.config = function(option){
this.option = $.extend({}, this.option, option);
};
/**
* Refresh the heights of elements for the selector
*
* @return LineUp
*/
my.refresh = function(){
var items, currentTop, fixHeight;
nodes = this.nodes.toArray();
nodes.sort(function(a, b){
return $(a).offset().top - $(b).offset().top;
});
items = [];
currentTop = null;
fixHeight = function(){
var max = 0;
$(items).each(function(){
max = Math.max(max, $(this).height());
})
.each(function(){
$(this).height(max);
});
items = [];
};
this.reset();
$.each(nodes, function(){
var node = $(this);
if(currentTop !== null && node.offset().top !== currentTop){
fixHeight();
}
currentTop = node.offset().top;
items.push(this);
});
fixHeight();
if($.isFunction(this.option.after)){
this.option.after(this);
}
return this;
};
/**
* Reset all the heights of elements for the selector
*
* @return LineUp
*/
my.reset = function(){
this.nodes.css("height", "");
return this;
};
/**
* Run callback on font size changed
*
* @param Function callback
* @return LineUp
*/
my.onFontResize = function(callback){
var check;
this.sampler = $("#" + this.option.fontSamplerName);
check = function(){
var height = my.sampler.height();
if(my.sampler.data("size") !== height){
callback();
my.sampler.data("size", height);
}
};
if(! this.sampler.length){
this.sampler = $("<span>")
.text("M")
.css({
position : "absolute",
visibility : "hidden"
})
.attr("id", this.option.fontSamplerName)
.appendTo($("body"));
}
this.sampler.data("size", this.sampler.height());
this.checkFontTimer = setInterval(check, this.option.checkFontInterval);
};
my.init.apply(this, arguments);
};
/**
* jquery.fn.lineUp
*/
$.fn.extend({
lineUp : function(option){
var node, lineup;
node = $(this);
lineup = node.data("lineUp");
if(lineup instanceof LineUp){
lineup.config(option);
lineup.refresh();
} else {
node.data("lineUp", new LineUp(this.selector, option));
}
}
});
/**
* Run with parameter
*
* @example
* <script src="lineup.js" data-selector=".item-a, .item-b"></script>
*/
(function(){
var selector = $("script:last").data("lineupSelector");
if(selector){
$.each(selector.split(","), function(index, value){
$(value).lineUp();
});
}
}());
}(jQuery));
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment