var ElementMaxHeight = function() {
this.initialize.apply(this, arguments);
}

ElementMaxHeight.prototype = {
 initialize: function(className) {
 this.elements = document.getElementsByClassName(className || 'maxheight');
 this.textElement = document.createElement('span');
 this.textElement.appendChild(document.createTextNode('A'));
 this.textElement.style.display = 'block';
 this.textElement.style.position = 'absolute';
 this.textElement.style.fontSize = '1em';
 this.textElement.style.top = '-1000px';
 this.textElement.style.left = '-1000px';
 document.body.appendChild(this.textElement);
 this.textElementHeight = document.getDimensions(this.textElement).height;
 var __object = this;
 var __checkFontSize = this.checkFontSize;
 this.checkFontSizeInterval = window.setInterval(function() {return __checkFontSize.apply(__object)}, 500);

 this.expand();

 // Refresh elements height onResize event
 var __expand = this.expand;
 if (window.addEventListener) {
 window.addEventListener('resize', function(event) {return __expand.apply(__object, [( event || window.event)])}, false);
 } else if (window.attachEvent) {
 window.attachEvent('onresize', function(event) {return __expand.apply(__object, [( event || window.event)])});
 }
 },

 expand: function() {
 this.reset();
 for (var i = 0; i < this.elements.length; i++) {
 this.elements[i].style.height = document.getDimensions(this.elements[i].parentNode).height + 'px';
 }
 },

 reset: function() {
 for (var i = 0; i < this.elements.length; i++) {
 this.elements[i].style.height = 'auto';
 }
 },

 checkFontSize: function() {
 var height = document.getDimensions(this.textElement).height;
 if(this.textElementHeight != height) {
 this.textElementHeight = height;
 this.expand();
 }
 }
}


if (!!document.evaluate) {
 document._getElementsByXPath = function(expression, parentElement) {
 var results = [];
 var query = document.evaluate(expression, parentElement || document,
 null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
 for (var i = 0, length = query.snapshotLength; i < length; i++)
 results.push(query.snapshotItem(i));
 return results;
 }
}

document.getElementsByClassName = function(className, parentElement) {
 if (!!document.evaluate) {
 var q = ".//*[contains(concat(' ', @class, ' '), ' " + className + " ')]";
 return document._getElementsByXPath(q, parentElement);
 } else {
 var children = (parentElement || document.body).getElementsByTagName('*');
 var elements = [], child;
 for (var i = 0, length = children.length; i < length; i++) {
 child = children[i];
 if (child.className.length != 0 &&
 (child.className == className ||
 child.className.match(new RegExp("(^|\\s)" + className + "(\\s|$)")))) {
 elements.push(child);
 }
 }
 return elements;
 }
}

document.getDimensions = function (element) {
 var display = element.style.display;
 if (display != 'none' && display != null) { // Safari bug
 return {width: element.offsetWidth, height: element.offsetHeight};
 }

 return {width: originalWidth, height: originalHeight};
}