autosize
Advanced tools
Comparing version 3.0.16 to 3.0.17
## Changelog | ||
##### v.3.0.17 - 2016-7-25 | ||
* Fixed Chromium issue where getComputedStyle pixel value did not exactly match the style pixel value. Fixes #306. | ||
* Removed undocumented argument, minor refactoring, more comments. | ||
##### v.3.0.16 - 2016-7-13 | ||
@@ -4,0 +8,0 @@ * Fixed issue with overflowing parent elements. Fixes #298. |
/*! | ||
Autosize 3.0.16 | ||
Autosize 3.0.17 | ||
license: MIT | ||
@@ -51,14 +51,7 @@ http://www.jacklmoore.com/autosize | ||
function assign(ta) { | ||
var _ref = arguments[1] === undefined ? {} : arguments[1]; | ||
var _ref$setOverflowX = _ref.setOverflowX; | ||
var setOverflowX = _ref$setOverflowX === undefined ? true : _ref$setOverflowX; | ||
var _ref$setOverflowY = _ref.setOverflowY; | ||
var setOverflowY = _ref$setOverflowY === undefined ? true : _ref$setOverflowY; | ||
if (!ta || !ta.nodeName || ta.nodeName !== 'TEXTAREA' || set.has(ta)) return; | ||
var heightOffset = null; | ||
var overflowY = null; | ||
var clientWidth = ta.clientWidth; | ||
var cachedHeight = null; | ||
@@ -68,4 +61,2 @@ function init() { | ||
overflowY = style.overflowY; | ||
if (style.resize === 'vertical') { | ||
@@ -104,8 +95,4 @@ ta.style.resize = 'none'; | ||
overflowY = value; | ||
ta.style.overflowY = value; | ||
if (setOverflowY) { | ||
ta.style.overflowY = value; | ||
} | ||
resize(); | ||
@@ -160,14 +147,17 @@ } | ||
function update() { | ||
var startHeight = ta.style.height; | ||
resize(); | ||
var style = window.getComputedStyle(ta, null); | ||
var computed = window.getComputedStyle(ta, null); | ||
var computedHeight = Math.round(parseFloat(computed.height)); | ||
var styleHeight = Math.round(parseFloat(ta.style.height)); | ||
if (style.height !== ta.style.height) { | ||
if (overflowY !== 'visible') { | ||
// The computed height not matching the height set via resize indicates that | ||
// the max-height has been exceeded, in which case the overflow should be set to visible. | ||
if (computedHeight !== styleHeight) { | ||
if (computed.overflowY !== 'visible') { | ||
changeOverflow('visible'); | ||
} | ||
} else { | ||
if (overflowY !== 'hidden') { | ||
// Normally keep overflow set to hidden, to avoid flash of scrollbar as the textarea expands. | ||
if (computed.overflowY !== 'hidden') { | ||
changeOverflow('hidden'); | ||
@@ -177,3 +167,4 @@ } | ||
if (startHeight !== ta.style.height) { | ||
if (cachedHeight !== computedHeight) { | ||
cachedHeight = computedHeight; | ||
var evt = createEvent('autosize:resized'); | ||
@@ -221,8 +212,5 @@ ta.dispatchEvent(evt); | ||
set.add(ta); | ||
ta.style.overflowX = 'hidden'; | ||
ta.style.wordWrap = 'break-word'; | ||
if (setOverflowX) { | ||
ta.style.overflowX = 'hidden'; | ||
ta.style.wordWrap = 'break-word'; | ||
} | ||
init(); | ||
@@ -229,0 +217,0 @@ } |
/*! | ||
Autosize 3.0.16 | ||
Autosize 3.0.17 | ||
license: MIT | ||
http://www.jacklmoore.com/autosize | ||
*/ | ||
!function(e,t){if("function"==typeof define&&define.amd)define(["exports","module"],t);else if("undefined"!=typeof exports&&"undefined"!=typeof module)t(exports,module);else{var n={exports:{}};t(n.exports,n),e.autosize=n.exports}}(this,function(e,t){"use strict";function n(e){function t(){var t=window.getComputedStyle(e,null);v=t.overflowY,"vertical"===t.resize?e.style.resize="none":"both"===t.resize&&(e.style.resize="horizontal"),p="content-box"===t.boxSizing?-(parseFloat(t.paddingTop)+parseFloat(t.paddingBottom)):parseFloat(t.borderTopWidth)+parseFloat(t.borderBottomWidth),isNaN(p)&&(p=0),s()}function n(t){var n=e.style.width;e.style.width="0px",e.offsetWidth,e.style.width=n,v=t,f&&(e.style.overflowY=t),r()}function o(e){for(var t=[];e&&e.parentNode&&e.parentNode instanceof Element;)e.parentNode.scrollTop&&t.push({node:e.parentNode,scrollTop:e.parentNode.scrollTop}),e=e.parentNode;return t}function r(){var t=e.style.height,n=o(e),r=document.documentElement&&document.documentElement.scrollTop;e.style.height="auto";var i=e.scrollHeight+p;return 0===e.scrollHeight?void(e.style.height=t):(e.style.height=i+"px",h=e.clientWidth,n.forEach(function(e){e.node.scrollTop=e.scrollTop}),void(r&&(document.documentElement.scrollTop=r)))}function s(){var t=e.style.height;r();var o=window.getComputedStyle(e,null);if(o.height!==e.style.height?"visible"!==v&&n("visible"):"hidden"!==v&&n("hidden"),t!==e.style.height){var i=d("autosize:resized");e.dispatchEvent(i)}}var l=void 0===arguments[1]?{}:arguments[1],a=l.setOverflowX,u=void 0===a?!0:a,c=l.setOverflowY,f=void 0===c?!0:c;if(e&&e.nodeName&&"TEXTAREA"===e.nodeName&&!i.has(e)){var p=null,v=null,h=e.clientWidth,y=function(){e.clientWidth!==h&&s()},m=function(t){window.removeEventListener("resize",y,!1),e.removeEventListener("input",s,!1),e.removeEventListener("keyup",s,!1),e.removeEventListener("autosize:destroy",m,!1),e.removeEventListener("autosize:update",s,!1),i["delete"](e),Object.keys(t).forEach(function(n){e.style[n]=t[n]})}.bind(e,{height:e.style.height,resize:e.style.resize,overflowY:e.style.overflowY,overflowX:e.style.overflowX,wordWrap:e.style.wordWrap});e.addEventListener("autosize:destroy",m,!1),"onpropertychange"in e&&"oninput"in e&&e.addEventListener("keyup",s,!1),window.addEventListener("resize",y,!1),e.addEventListener("input",s,!1),e.addEventListener("autosize:update",s,!1),i.add(e),u&&(e.style.overflowX="hidden",e.style.wordWrap="break-word"),t()}}function o(e){if(e&&e.nodeName&&"TEXTAREA"===e.nodeName){var t=d("autosize:destroy");e.dispatchEvent(t)}}function r(e){if(e&&e.nodeName&&"TEXTAREA"===e.nodeName){var t=d("autosize:update");e.dispatchEvent(t)}}var i="function"==typeof Set?new Set:function(){var e=[];return{has:function(t){return Boolean(e.indexOf(t)>-1)},add:function(t){e.push(t)},"delete":function(t){e.splice(e.indexOf(t),1)}}}(),d=function(e){return new Event(e)};try{new Event("test")}catch(s){d=function(e){var t=document.createEvent("Event");return t.initEvent(e,!0,!1),t}}var l=null;"undefined"==typeof window||"function"!=typeof window.getComputedStyle?(l=function(e){return e},l.destroy=function(e){return e},l.update=function(e){return e}):(l=function(e,t){return e&&Array.prototype.forEach.call(e.length?e:[e],function(e){return n(e,t)}),e},l.destroy=function(e){return e&&Array.prototype.forEach.call(e.length?e:[e],o),e},l.update=function(e){return e&&Array.prototype.forEach.call(e.length?e:[e],r),e}),t.exports=l}); | ||
!function(e,t){if("function"==typeof define&&define.amd)define(["exports","module"],t);else if("undefined"!=typeof exports&&"undefined"!=typeof module)t(exports,module);else{var n={exports:{}};t(n.exports,n),e.autosize=n.exports}}(this,function(e,t){"use strict";function n(e){function t(){var t=window.getComputedStyle(e,null);"vertical"===t.resize?e.style.resize="none":"both"===t.resize&&(e.style.resize="horizontal"),l="content-box"===t.boxSizing?-(parseFloat(t.paddingTop)+parseFloat(t.paddingBottom)):parseFloat(t.borderTopWidth)+parseFloat(t.borderBottomWidth),isNaN(l)&&(l=0),a()}function n(t){var n=e.style.width;e.style.width="0px",e.offsetWidth,e.style.width=n,e.style.overflowY=t,r()}function o(e){for(var t=[];e&&e.parentNode&&e.parentNode instanceof Element;)e.parentNode.scrollTop&&t.push({node:e.parentNode,scrollTop:e.parentNode.scrollTop}),e=e.parentNode;return t}function r(){var t=e.style.height,n=o(e),r=document.documentElement&&document.documentElement.scrollTop;e.style.height="auto";var i=e.scrollHeight+l;return 0===e.scrollHeight?void(e.style.height=t):(e.style.height=i+"px",s=e.clientWidth,n.forEach(function(e){e.node.scrollTop=e.scrollTop}),void(r&&(document.documentElement.scrollTop=r)))}function a(){r();var t=window.getComputedStyle(e,null),o=Math.round(parseFloat(t.height)),i=Math.round(parseFloat(e.style.height));if(o!==i?"visible"!==t.overflowY&&n("visible"):"hidden"!==t.overflowY&&n("hidden"),u!==o){u=o;var a=d("autosize:resized");e.dispatchEvent(a)}}if(e&&e.nodeName&&"TEXTAREA"===e.nodeName&&!i.has(e)){var l=null,s=e.clientWidth,u=null,c=function(){e.clientWidth!==s&&a()},p=function(t){window.removeEventListener("resize",c,!1),e.removeEventListener("input",a,!1),e.removeEventListener("keyup",a,!1),e.removeEventListener("autosize:destroy",p,!1),e.removeEventListener("autosize:update",a,!1),i["delete"](e),Object.keys(t).forEach(function(n){e.style[n]=t[n]})}.bind(e,{height:e.style.height,resize:e.style.resize,overflowY:e.style.overflowY,overflowX:e.style.overflowX,wordWrap:e.style.wordWrap});e.addEventListener("autosize:destroy",p,!1),"onpropertychange"in e&&"oninput"in e&&e.addEventListener("keyup",a,!1),window.addEventListener("resize",c,!1),e.addEventListener("input",a,!1),e.addEventListener("autosize:update",a,!1),i.add(e),e.style.overflowX="hidden",e.style.wordWrap="break-word",t()}}function o(e){if(e&&e.nodeName&&"TEXTAREA"===e.nodeName){var t=d("autosize:destroy");e.dispatchEvent(t)}}function r(e){if(e&&e.nodeName&&"TEXTAREA"===e.nodeName){var t=d("autosize:update");e.dispatchEvent(t)}}var i="function"==typeof Set?new Set:function(){var e=[];return{has:function(t){return Boolean(e.indexOf(t)>-1)},add:function(t){e.push(t)},"delete":function(t){e.splice(e.indexOf(t),1)}}}(),d=function(e){return new Event(e)};try{new Event("test")}catch(a){d=function(e){var t=document.createEvent("Event");return t.initEvent(e,!0,!1),t}}var l=null;"undefined"==typeof window||"function"!=typeof window.getComputedStyle?(l=function(e){return e},l.destroy=function(e){return e},l.update=function(e){return e}):(l=function(e,t){return e&&Array.prototype.forEach.call(e.length?e:[e],function(e){return n(e,t)}),e},l.destroy=function(e){return e&&Array.prototype.forEach.call(e.length?e:[e],o),e},l.update=function(e){return e&&Array.prototype.forEach.call(e.length?e:[e],r),e}),t.exports=l}); |
{ | ||
"name": "autosize", | ||
"description": "Autosize is a small, stand-alone script to automatically adjust textarea height to fit text.", | ||
"version": "3.0.16", | ||
"version": "3.0.17", | ||
"keywords": [ | ||
@@ -6,0 +6,0 @@ "textarea", |
@@ -29,8 +29,8 @@ const set = (typeof Set === "function") ? new Set() : (function () { | ||
function assign(ta, {setOverflowX = true, setOverflowY = true} = {}) { | ||
function assign(ta) { | ||
if (!ta || !ta.nodeName || ta.nodeName !== 'TEXTAREA' || set.has(ta)) return; | ||
let heightOffset = null; | ||
let overflowY = null; | ||
let clientWidth = ta.clientWidth; | ||
let cachedHeight = null; | ||
@@ -40,4 +40,2 @@ function init() { | ||
overflowY = style.overflowY; | ||
if (style.resize === 'vertical') { | ||
@@ -76,8 +74,4 @@ ta.style.resize = 'none'; | ||
overflowY = value; | ||
ta.style.overflowY = value; | ||
if (setOverflowY) { | ||
ta.style.overflowY = value; | ||
} | ||
resize(); | ||
@@ -133,14 +127,17 @@ } | ||
function update() { | ||
const startHeight = ta.style.height; | ||
resize(); | ||
const style = window.getComputedStyle(ta, null); | ||
const computed = window.getComputedStyle(ta, null); | ||
const computedHeight = Math.round(parseFloat(computed.height)); | ||
const styleHeight = Math.round(parseFloat(ta.style.height)); | ||
if (style.height !== ta.style.height) { | ||
if (overflowY !== 'visible') { | ||
// The computed height not matching the height set via resize indicates that | ||
// the max-height has been exceeded, in which case the overflow should be set to visible. | ||
if (computedHeight !== styleHeight) { | ||
if (computed.overflowY !== 'visible') { | ||
changeOverflow('visible'); | ||
} | ||
} else { | ||
if (overflowY !== 'hidden') { | ||
// Normally keep overflow set to hidden, to avoid flash of scrollbar as the textarea expands. | ||
if (computed.overflowY !== 'hidden') { | ||
changeOverflow('hidden'); | ||
@@ -150,3 +147,4 @@ } | ||
if (startHeight !== ta.style.height) { | ||
if (cachedHeight !== computedHeight) { | ||
cachedHeight = computedHeight; | ||
const evt = createEvent('autosize:resized'); | ||
@@ -195,8 +193,5 @@ ta.dispatchEvent(evt); | ||
set.add(ta); | ||
ta.style.overflowX = 'hidden'; | ||
ta.style.wordWrap = 'break-word'; | ||
if (setOverflowX) { | ||
ta.style.overflowX = 'hidden'; | ||
ta.style.wordWrap = 'break-word'; | ||
} | ||
init(); | ||
@@ -203,0 +198,0 @@ } |
22514
423