| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274 | 
							- (function (global, factory) {
 
- 	typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
 
- 	typeof define === 'function' && define.amd ? define(factory) :
 
- 	(global = global || self, global.autosize = factory());
 
- }(this, (function () {
 
- 	var map = typeof Map === "function" ? new Map() : function () {
 
- 	  var keys = [];
 
- 	  var values = [];
 
- 	  return {
 
- 	    has: function has(key) {
 
- 	      return keys.indexOf(key) > -1;
 
- 	    },
 
- 	    get: function get(key) {
 
- 	      return values[keys.indexOf(key)];
 
- 	    },
 
- 	    set: function set(key, value) {
 
- 	      if (keys.indexOf(key) === -1) {
 
- 	        keys.push(key);
 
- 	        values.push(value);
 
- 	      }
 
- 	    },
 
- 	    "delete": function _delete(key) {
 
- 	      var index = keys.indexOf(key);
 
- 	      if (index > -1) {
 
- 	        keys.splice(index, 1);
 
- 	        values.splice(index, 1);
 
- 	      }
 
- 	    }
 
- 	  };
 
- 	}();
 
- 	var createEvent = function createEvent(name) {
 
- 	  return new Event(name, {
 
- 	    bubbles: true
 
- 	  });
 
- 	};
 
- 	try {
 
- 	  new Event('test');
 
- 	} catch (e) {
 
- 	  // IE does not support `new Event()`
 
- 	  createEvent = function createEvent(name) {
 
- 	    var evt = document.createEvent('Event');
 
- 	    evt.initEvent(name, true, false);
 
- 	    return evt;
 
- 	  };
 
- 	}
 
- 	function assign(ta) {
 
- 	  if (!ta || !ta.nodeName || ta.nodeName !== 'TEXTAREA' || map.has(ta)) return;
 
- 	  var heightOffset = null;
 
- 	  var clientWidth = null;
 
- 	  var cachedHeight = null;
 
- 	  function init() {
 
- 	    var style = window.getComputedStyle(ta, null);
 
- 	    if (style.resize === 'vertical') {
 
- 	      ta.style.resize = 'none';
 
- 	    } else if (style.resize === 'both') {
 
- 	      ta.style.resize = 'horizontal';
 
- 	    }
 
- 	    if (style.boxSizing === 'content-box') {
 
- 	      heightOffset = -(parseFloat(style.paddingTop) + parseFloat(style.paddingBottom));
 
- 	    } else {
 
- 	      heightOffset = parseFloat(style.borderTopWidth) + parseFloat(style.borderBottomWidth);
 
- 	    } // Fix when a textarea is not on document body and heightOffset is Not a Number
 
- 	    if (isNaN(heightOffset)) {
 
- 	      heightOffset = 0;
 
- 	    }
 
- 	    update();
 
- 	  }
 
- 	  function changeOverflow(value) {
 
- 	    {
 
- 	      // Chrome/Safari-specific fix:
 
- 	      // When the textarea y-overflow is hidden, Chrome/Safari do not reflow the text to account for the space
 
- 	      // made available by removing the scrollbar. The following forces the necessary text reflow.
 
- 	      var width = ta.style.width;
 
- 	      ta.style.width = '0px'; // Force reflow:
 
- 	      /* jshint ignore:end */
 
- 	      ta.style.width = width;
 
- 	    }
 
- 	    ta.style.overflowY = value;
 
- 	  }
 
- 	  function getParentOverflows(el) {
 
- 	    var arr = [];
 
- 	    while (el && el.parentNode && el.parentNode instanceof Element) {
 
- 	      if (el.parentNode.scrollTop) {
 
- 	        arr.push({
 
- 	          node: el.parentNode,
 
- 	          scrollTop: el.parentNode.scrollTop
 
- 	        });
 
- 	      }
 
- 	      el = el.parentNode;
 
- 	    }
 
- 	    return arr;
 
- 	  }
 
- 	  function resize() {
 
- 	    if (ta.scrollHeight === 0) {
 
- 	      // If the scrollHeight is 0, then the element probably has display:none or is detached from the DOM.
 
- 	      return;
 
- 	    }
 
- 	    var overflows = getParentOverflows(ta);
 
- 	    var docTop = document.documentElement && document.documentElement.scrollTop; // Needed for Mobile IE (ticket #240)
 
- 	    ta.style.height = '';
 
- 	    ta.style.height = ta.scrollHeight + heightOffset + 'px'; // used to check if an update is actually necessary on window.resize
 
- 	    clientWidth = ta.clientWidth; // prevents scroll-position jumping
 
- 	    overflows.forEach(function (el) {
 
- 	      el.node.scrollTop = el.scrollTop;
 
- 	    });
 
- 	    if (docTop) {
 
- 	      document.documentElement.scrollTop = docTop;
 
- 	    }
 
- 	  }
 
- 	  function update() {
 
- 	    resize();
 
- 	    var styleHeight = Math.round(parseFloat(ta.style.height));
 
- 	    var computed = window.getComputedStyle(ta, null); // Using offsetHeight as a replacement for computed.height in IE, because IE does not account use of border-box
 
- 	    var actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(computed.height)) : ta.offsetHeight; // The actual height not matching the style height (set via the resize method) indicates that 
 
- 	    // the max-height has been exceeded, in which case the overflow should be allowed.
 
- 	    if (actualHeight < styleHeight) {
 
- 	      if (computed.overflowY === 'hidden') {
 
- 	        changeOverflow('scroll');
 
- 	        resize();
 
- 	        actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(window.getComputedStyle(ta, null).height)) : ta.offsetHeight;
 
- 	      }
 
- 	    } else {
 
- 	      // Normally keep overflow set to hidden, to avoid flash of scrollbar as the textarea expands.
 
- 	      if (computed.overflowY !== 'hidden') {
 
- 	        changeOverflow('hidden');
 
- 	        resize();
 
- 	        actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(window.getComputedStyle(ta, null).height)) : ta.offsetHeight;
 
- 	      }
 
- 	    }
 
- 	    if (cachedHeight !== actualHeight) {
 
- 	      cachedHeight = actualHeight;
 
- 	      var evt = createEvent('autosize:resized');
 
- 	      try {
 
- 	        ta.dispatchEvent(evt);
 
- 	      } catch (err) {// Firefox will throw an error on dispatchEvent for a detached element
 
- 	        // https://bugzilla.mozilla.org/show_bug.cgi?id=889376
 
- 	      }
 
- 	    }
 
- 	  }
 
- 	  var pageResize = function pageResize() {
 
- 	    if (ta.clientWidth !== clientWidth) {
 
- 	      update();
 
- 	    }
 
- 	  };
 
- 	  var destroy = function (style) {
 
- 	    window.removeEventListener('resize', pageResize, false);
 
- 	    ta.removeEventListener('input', update, false);
 
- 	    ta.removeEventListener('keyup', update, false);
 
- 	    ta.removeEventListener('autosize:destroy', destroy, false);
 
- 	    ta.removeEventListener('autosize:update', update, false);
 
- 	    Object.keys(style).forEach(function (key) {
 
- 	      ta.style[key] = style[key];
 
- 	    });
 
- 	    map["delete"](ta);
 
- 	  }.bind(ta, {
 
- 	    height: ta.style.height,
 
- 	    resize: ta.style.resize,
 
- 	    overflowY: ta.style.overflowY,
 
- 	    overflowX: ta.style.overflowX,
 
- 	    wordWrap: ta.style.wordWrap
 
- 	  });
 
- 	  ta.addEventListener('autosize:destroy', destroy, false); // IE9 does not fire onpropertychange or oninput for deletions,
 
- 	  // so binding to onkeyup to catch most of those events.
 
- 	  // There is no way that I know of to detect something like 'cut' in IE9.
 
- 	  if ('onpropertychange' in ta && 'oninput' in ta) {
 
- 	    ta.addEventListener('keyup', update, false);
 
- 	  }
 
- 	  window.addEventListener('resize', pageResize, false);
 
- 	  ta.addEventListener('input', update, false);
 
- 	  ta.addEventListener('autosize:update', update, false);
 
- 	  ta.style.overflowX = 'hidden';
 
- 	  ta.style.wordWrap = 'break-word';
 
- 	  map.set(ta, {
 
- 	    destroy: destroy,
 
- 	    update: update
 
- 	  });
 
- 	  init();
 
- 	}
 
- 	function destroy(ta) {
 
- 	  var methods = map.get(ta);
 
- 	  if (methods) {
 
- 	    methods.destroy();
 
- 	  }
 
- 	}
 
- 	function update(ta) {
 
- 	  var methods = map.get(ta);
 
- 	  if (methods) {
 
- 	    methods.update();
 
- 	  }
 
- 	}
 
- 	var autosize = null; // Do nothing in Node.js environment and IE8 (or lower)
 
- 	if (typeof window === 'undefined' || typeof window.getComputedStyle !== 'function') {
 
- 	  autosize = function autosize(el) {
 
- 	    return el;
 
- 	  };
 
- 	  autosize.destroy = function (el) {
 
- 	    return el;
 
- 	  };
 
- 	  autosize.update = function (el) {
 
- 	    return el;
 
- 	  };
 
- 	} else {
 
- 	  autosize = function autosize(el, options) {
 
- 	    if (el) {
 
- 	      Array.prototype.forEach.call(el.length ? el : [el], function (x) {
 
- 	        return assign(x);
 
- 	      });
 
- 	    }
 
- 	    return el;
 
- 	  };
 
- 	  autosize.destroy = function (el) {
 
- 	    if (el) {
 
- 	      Array.prototype.forEach.call(el.length ? el : [el], destroy);
 
- 	    }
 
- 	    return el;
 
- 	  };
 
- 	  autosize.update = function (el) {
 
- 	    if (el) {
 
- 	      Array.prototype.forEach.call(el.length ? el : [el], update);
 
- 	    }
 
- 	    return el;
 
- 	  };
 
- 	}
 
- 	var autosize$1 = autosize;
 
- 	return autosize$1;
 
- })));
 
 
  |