vanilla-match-height
Advanced tools
Comparing version 0.0.6 to 0.0.7
@@ -0,1 +1,9 @@ | ||
<a name="0.0.7"></a> | ||
# 0.0.7 (2023-11-23) | ||
### release summary | ||
- 'orientationchange' window event added | ||
- Common lines of code rewritten into functions | ||
<a name="0.0.6"></a> | ||
@@ -2,0 +10,0 @@ # 0.0.6 (2023-11-22) |
/** | ||
* vanilla-match-height v0.0.6 by @mitera | ||
* vanilla-match-height v0.0.7 by @mitera | ||
* Simone Miterangelis <simone@mite.it> | ||
@@ -75,20 +75,29 @@ * License: MIT | ||
document.addEventListener("DOMContentLoaded", function() { | ||
$this._apply(); | ||
if ($this._validateProperty($this.settings.attributeName)) { | ||
$this._applyDataApi($this.settings.attributeName); | ||
} | ||
$this._applyDataApi('data-match-height'); | ||
$this._applyDataApi('data-mh'); | ||
$this._events(); | ||
}); | ||
window.addEventListener("resize", function() { | ||
$this._apply(); | ||
if ($this._validateProperty($this.settings.attributeName)) { | ||
$this._applyDataApi($this.settings.attributeName); | ||
} | ||
$this._applyDataApi('data-match-height'); | ||
$this._applyDataApi('data-mh'); | ||
$this._events(); | ||
}); | ||
window.addEventListener("orientationchange", function() { | ||
$this._events(); | ||
}); | ||
} | ||
/** | ||
* Initialize the common events | ||
*/ | ||
MatchHeight.prototype._events = function() { | ||
var $this = this; | ||
$this._apply(); | ||
if ($this._validateProperty($this.settings.attributeName)) { | ||
$this._applyDataApi($this.settings.attributeName); | ||
} | ||
$this._applyDataApi('data-match-height'); | ||
$this._applyDataApi('data-mh'); | ||
} | ||
/* | ||
@@ -251,4 +260,3 @@ * _validateProperty | ||
$row.forEach(($that) => { | ||
eval('$that.style.' + opts.property + ' = \'\';'); | ||
if ($that.getAttribute('style') == '') $that.removeAttribute('style'); | ||
$this._resetStyle($that, opts.property); | ||
}) | ||
@@ -331,4 +339,3 @@ return; | ||
if ($that === $el) { | ||
eval('$el.style.' + opts.property + ' = \'\';'); | ||
if ($el.getAttribute('style') == '') $el.removeAttribute('style'); | ||
$this._resetStyle($el, opts.property); | ||
} | ||
@@ -338,4 +345,3 @@ }); | ||
if ($that === opts.remove) { | ||
eval('$that.style.' + opts.property + ' = \'\';'); | ||
if ($that.getAttribute('style') == '') $that.removeAttribute('style'); | ||
$this._resetStyle($that, opts.property); | ||
} | ||
@@ -350,2 +356,14 @@ } | ||
/** | ||
* _resetStyle | ||
* @param {Element} $that | ||
* @param {String} property | ||
*/ | ||
MatchHeight.prototype._resetStyle = function($that, property) { | ||
if (this._validateProperty(property)) { | ||
eval('$that.style.' + property + ' = \'\';'); | ||
if ($that.getAttribute('style') == '') $that.removeAttribute('style'); | ||
} | ||
} | ||
})(); |
@@ -1,1 +0,1 @@ | ||
(function(){"use strict";Element.prototype.matchHeight=function(settings){return new MatchHeight(this,settings)};if(typeof Object.merge!="function"){Object.merge=function(o1,o2){for(var i in o1){o2[i]=o1[i]}return o2}}function MatchHeight(wrapEl,settings){this.wrapEl=wrapEl;let default_settings={elements:"",byRow:true,target:null,attributeName:null,attributeValue:null,property:"height",remove:null};if(settings!=null){this.settings=Object.merge(settings,default_settings)}else{this.settings=default_settings}if(!this._validateProperty(this.settings.property)){this.settings.property="height"}this.settings.property=this._dashToCamel(this.settings.property);this._init()}MatchHeight.prototype._init=function(){var $this=this;document.addEventListener("DOMContentLoaded",function(){$this._apply();if($this._validateProperty($this.settings.attributeName)){$this._applyDataApi($this.settings.attributeName)}$this._applyDataApi("data-match-height");$this._applyDataApi("data-mh")});window.addEventListener("resize",function(){$this._apply();if($this._validateProperty($this.settings.attributeName)){$this._applyDataApi($this.settings.attributeName)}$this._applyDataApi("data-match-height");$this._applyDataApi("data-mh")})};MatchHeight.prototype._validateProperty=function(value){return String(value).toLowerCase().match(/^([a-z-]{2,})$/)};MatchHeight.prototype._parse=function(value){return parseFloat(value)||0};MatchHeight.prototype._rows=function(elements){var $this=this;var tolerance=1,lastTop=null,listRows=[],rows=[];elements.forEach($that=>{var top=$that.getBoundingClientRect().top-$this._parse($that.style.marginTop);if(lastTop!=null&&Math.floor(Math.abs(lastTop-top))>=tolerance){listRows.push(rows);rows=[];lastTop=null;rows.push($that)}else{rows.push($that)}lastTop=top});listRows.push(rows);return listRows};MatchHeight.prototype._dashToCamel=function(input){return input.toLowerCase().replace(/-(.)/g,function(match,group1){return group1.toUpperCase()})};MatchHeight.prototype._applyDataApi=function(property){var $this=this;var $row=this.wrapEl.querySelectorAll("["+property+"]");$row.forEach($el=>{var groupId=$el.getAttribute(property);$this.settings=Object.merge({attributeName:property,attributeValue:groupId},$this.settings);$this._apply()})};MatchHeight.prototype._remove=function(){var $elements=[];var opts=this.settings;if(opts.elements){$elements=this.wrapEl.querySelectorAll(opts.elements)}else{if(opts.attributeName&&opts.attributeValue){$elements=this.wrapEl.querySelectorAll("["+opts.attributeName+'="'+opts.attributeValue+'"]')}}$elements.forEach(item=>{eval("item.style."+opts.property+" = '';");if(item.getAttribute("style")=="")item.removeAttribute("style")})};MatchHeight.prototype._apply=function(){var $this=this;var opts=$this.settings;var $elements=[];if(opts.elements){$elements=this.wrapEl.querySelectorAll(opts.elements)}else{if(opts.attributeName&&opts.attributeValue){$elements=this.wrapEl.querySelectorAll("["+opts.attributeName+'="'+opts.attributeValue+'"]')}}var rows=[$elements];if(opts.byRow&&!opts.target){$elements.forEach($that=>{var display=$that.style.display;if(display&&(display!=="inline-block"&&display!=="flex"&&display!=="inline-flex")){display="display: block; "}$that.setAttribute("style-cache",$that.getAttribute("style")||"");$that.setAttribute("style",display+"padding-top: 0; padding-bottom: 0; margin-top: 0; margin-bottom: 0; border-top-width: 0; border-bottom-width: 0; height: 100px; overflow: hidden;")});rows=this._rows($elements);$elements.forEach($that=>{$that.setAttribute("style",$that.getAttribute("style-cache")||"");$that.removeAttribute("style-cache");if($that.getAttribute("style")=="")$that.removeAttribute("style")})}rows.forEach($row=>{var targetHeight=0;if(!opts.target){if(opts.byRow&&$row.length<=1){$row.forEach($that=>{eval("$that.style."+opts.property+" = '';");if($that.getAttribute("style")=="")$that.removeAttribute("style")});return}$row.forEach($that=>{var style=$that.getAttribute("style")||"",display=$that.style.display;if(display&&(display!=="inline-block"&&display!=="flex"&&display!=="inline-flex")){display="block"}$that.setAttribute("style","display: "+display+";");var isTarget=true;if(opts.remove){if(opts.remove instanceof NodeList){opts.remove.forEach($el=>{if($that===$el){isTarget=false}})}else{if($that===opts.remove){isTarget=false}}}if(isTarget){if($that.getBoundingClientRect().height>targetHeight){targetHeight=$that.getBoundingClientRect().height}}if(style){$that.setAttribute("style",style)}else{$that.style.display=""}if($that.getAttribute("style")=="")$that.removeAttribute("style")})}else{targetHeight=opts.target.getBoundingClientRect().height}$row.forEach($that=>{var verticalPadding=0;if(opts.target&&$that===opts.target){return}verticalPadding+=$this._parse($that.style.borderTopWidth)+$this._parse($that.style.borderBottomWidth);verticalPadding+=$this._parse($that.style.paddingTop)+$this._parse($that.style.paddingBottom);eval("$that.style."+opts.property+" = '"+(targetHeight-verticalPadding)+"px'");if($that.getBoundingClientRect().height<targetHeight){eval("$that.style."+opts.property+" = '"+targetHeight+"px'")}if(opts.remove){if(opts.remove instanceof NodeList){opts.remove.forEach($el=>{if($that===$el){eval("$el.style."+opts.property+" = '';");if($el.getAttribute("style")=="")$el.removeAttribute("style")}})}else{if($that===opts.remove){eval("$that.style."+opts.property+" = '';");if($that.getAttribute("style")=="")$that.removeAttribute("style")}}}})})}})(); | ||
(function(){"use strict";Element.prototype.matchHeight=function(settings){return new MatchHeight(this,settings)};if(typeof Object.merge!="function"){Object.merge=function(o1,o2){for(var i in o1){o2[i]=o1[i]}return o2}}function MatchHeight(wrapEl,settings){this.wrapEl=wrapEl;let default_settings={elements:"",byRow:true,target:null,attributeName:null,attributeValue:null,property:"height",remove:null};if(settings!=null){this.settings=Object.merge(settings,default_settings)}else{this.settings=default_settings}if(!this._validateProperty(this.settings.property)){this.settings.property="height"}this.settings.property=this._dashToCamel(this.settings.property);this._init()}MatchHeight.prototype._init=function(){var $this=this;document.addEventListener("DOMContentLoaded",function(){$this._events()});window.addEventListener("resize",function(){$this._events()});window.addEventListener("orientationchange",function(){$this._events()})};MatchHeight.prototype._events=function(){var $this=this;$this._apply();if($this._validateProperty($this.settings.attributeName)){$this._applyDataApi($this.settings.attributeName)}$this._applyDataApi("data-match-height");$this._applyDataApi("data-mh")};MatchHeight.prototype._validateProperty=function(value){return String(value).toLowerCase().match(/^([a-z-]{2,})$/)};MatchHeight.prototype._parse=function(value){return parseFloat(value)||0};MatchHeight.prototype._rows=function(elements){var $this=this;var tolerance=1,lastTop=null,listRows=[],rows=[];elements.forEach($that=>{var top=$that.getBoundingClientRect().top-$this._parse($that.style.marginTop);if(lastTop!=null&&Math.floor(Math.abs(lastTop-top))>=tolerance){listRows.push(rows);rows=[];lastTop=null;rows.push($that)}else{rows.push($that)}lastTop=top});listRows.push(rows);return listRows};MatchHeight.prototype._dashToCamel=function(input){return input.toLowerCase().replace(/-(.)/g,function(match,group1){return group1.toUpperCase()})};MatchHeight.prototype._applyDataApi=function(property){var $this=this;var $row=this.wrapEl.querySelectorAll("["+property+"]");$row.forEach($el=>{var groupId=$el.getAttribute(property);$this.settings=Object.merge({attributeName:property,attributeValue:groupId},$this.settings);$this._apply()})};MatchHeight.prototype._remove=function(){var $elements=[];var opts=this.settings;if(opts.elements){$elements=this.wrapEl.querySelectorAll(opts.elements)}else{if(opts.attributeName&&opts.attributeValue){$elements=this.wrapEl.querySelectorAll("["+opts.attributeName+'="'+opts.attributeValue+'"]')}}$elements.forEach(item=>{eval("item.style."+opts.property+" = '';");if(item.getAttribute("style")=="")item.removeAttribute("style")})};MatchHeight.prototype._apply=function(){var $this=this;var opts=$this.settings;var $elements=[];if(opts.elements){$elements=this.wrapEl.querySelectorAll(opts.elements)}else{if(opts.attributeName&&opts.attributeValue){$elements=this.wrapEl.querySelectorAll("["+opts.attributeName+'="'+opts.attributeValue+'"]')}}var rows=[$elements];if(opts.byRow&&!opts.target){$elements.forEach($that=>{var display=$that.style.display;if(display&&(display!=="inline-block"&&display!=="flex"&&display!=="inline-flex")){display="display: block; "}$that.setAttribute("style-cache",$that.getAttribute("style")||"");$that.setAttribute("style",display+"padding-top: 0; padding-bottom: 0; margin-top: 0; margin-bottom: 0; border-top-width: 0; border-bottom-width: 0; height: 100px; overflow: hidden;")});rows=this._rows($elements);$elements.forEach($that=>{$that.setAttribute("style",$that.getAttribute("style-cache")||"");$that.removeAttribute("style-cache");if($that.getAttribute("style")=="")$that.removeAttribute("style")})}rows.forEach($row=>{var targetHeight=0;if(!opts.target){if(opts.byRow&&$row.length<=1){$row.forEach($that=>{$this._resetStyle($that,opts.property)});return}$row.forEach($that=>{var style=$that.getAttribute("style")||"",display=$that.style.display;if(display&&(display!=="inline-block"&&display!=="flex"&&display!=="inline-flex")){display="block"}$that.setAttribute("style","display: "+display+";");var isTarget=true;if(opts.remove){if(opts.remove instanceof NodeList){opts.remove.forEach($el=>{if($that===$el){isTarget=false}})}else{if($that===opts.remove){isTarget=false}}}if(isTarget){if($that.getBoundingClientRect().height>targetHeight){targetHeight=$that.getBoundingClientRect().height}}if(style){$that.setAttribute("style",style)}else{$that.style.display=""}if($that.getAttribute("style")=="")$that.removeAttribute("style")})}else{targetHeight=opts.target.getBoundingClientRect().height}$row.forEach($that=>{var verticalPadding=0;if(opts.target&&$that===opts.target){return}verticalPadding+=$this._parse($that.style.borderTopWidth)+$this._parse($that.style.borderBottomWidth);verticalPadding+=$this._parse($that.style.paddingTop)+$this._parse($that.style.paddingBottom);eval("$that.style."+opts.property+" = '"+(targetHeight-verticalPadding)+"px'");if($that.getBoundingClientRect().height<targetHeight){eval("$that.style."+opts.property+" = '"+targetHeight+"px'")}if(opts.remove){if(opts.remove instanceof NodeList){opts.remove.forEach($el=>{if($that===$el){$this._resetStyle($el,opts.property)}})}else{if($that===opts.remove){$this._resetStyle($that,opts.property)}}}})})};MatchHeight.prototype._resetStyle=function($that,property){if(this._validateProperty(property)){eval("$that.style."+property+" = '';");if($that.getAttribute("style")=="")$that.removeAttribute("style")}}})(); |
{ | ||
"name": "vanilla-match-height", | ||
"version": "0.0.6", | ||
"version": "0.0.7", | ||
"license": "MIT", | ||
@@ -5,0 +5,0 @@ "author": "Simone Miterangelis <simone@mite.it>", |
/** | ||
* vanilla-match-height v0.0.6 by @mitera | ||
* vanilla-match-height v0.0.7 by @mitera | ||
* Simone Miterangelis <simone@mite.it> | ||
@@ -75,20 +75,29 @@ * License: MIT | ||
document.addEventListener("DOMContentLoaded", function() { | ||
$this._apply(); | ||
if ($this._validateProperty($this.settings.attributeName)) { | ||
$this._applyDataApi($this.settings.attributeName); | ||
} | ||
$this._applyDataApi('data-match-height'); | ||
$this._applyDataApi('data-mh'); | ||
$this._events(); | ||
}); | ||
window.addEventListener("resize", function() { | ||
$this._apply(); | ||
if ($this._validateProperty($this.settings.attributeName)) { | ||
$this._applyDataApi($this.settings.attributeName); | ||
} | ||
$this._applyDataApi('data-match-height'); | ||
$this._applyDataApi('data-mh'); | ||
$this._events(); | ||
}); | ||
window.addEventListener("orientationchange", function() { | ||
$this._events(); | ||
}); | ||
} | ||
/** | ||
* Initialize the common events | ||
*/ | ||
MatchHeight.prototype._events = function() { | ||
var $this = this; | ||
$this._apply(); | ||
if ($this._validateProperty($this.settings.attributeName)) { | ||
$this._applyDataApi($this.settings.attributeName); | ||
} | ||
$this._applyDataApi('data-match-height'); | ||
$this._applyDataApi('data-mh'); | ||
} | ||
/* | ||
@@ -251,4 +260,3 @@ * _validateProperty | ||
$row.forEach(($that) => { | ||
eval('$that.style.' + opts.property + ' = \'\';'); | ||
if ($that.getAttribute('style') == '') $that.removeAttribute('style'); | ||
$this._resetStyle($that, opts.property); | ||
}) | ||
@@ -331,4 +339,3 @@ return; | ||
if ($that === $el) { | ||
eval('$el.style.' + opts.property + ' = \'\';'); | ||
if ($el.getAttribute('style') == '') $el.removeAttribute('style'); | ||
$this._resetStyle($el, opts.property); | ||
} | ||
@@ -338,4 +345,3 @@ }); | ||
if ($that === opts.remove) { | ||
eval('$that.style.' + opts.property + ' = \'\';'); | ||
if ($that.getAttribute('style') == '') $that.removeAttribute('style'); | ||
$this._resetStyle($that, opts.property); | ||
} | ||
@@ -350,2 +356,14 @@ } | ||
/** | ||
* _resetStyle | ||
* @param {Element} $that | ||
* @param {String} property | ||
*/ | ||
MatchHeight.prototype._resetStyle = function($that, property) { | ||
if (this._validateProperty(property)) { | ||
eval('$that.style.' + property + ' = \'\';'); | ||
if ($that.getAttribute('style') == '') $that.removeAttribute('style'); | ||
} | ||
} | ||
})(); |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
169979
870
18