parent
497fe1682f
commit
7d72ae3011
@ -1,290 +0,0 @@ |
||||
/*! |
||||
Autosize 3.0.20 |
||||
license: MIT |
||||
http://www.jacklmoore.com/autosize
|
||||
*/ |
||||
(function (global, factory) { |
||||
if (typeof define === 'function' && define.amd) { |
||||
define(['exports', 'module'], factory); |
||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') { |
||||
factory(exports, module); |
||||
} else { |
||||
var mod = { |
||||
exports: {} |
||||
}; |
||||
factory(mod.exports, mod); |
||||
global.autosize = mod.exports; |
||||
} |
||||
})(this, function (exports, module) { |
||||
'use strict'; |
||||
|
||||
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 (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 = ta.clientWidth; |
||||
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:start */ |
||||
ta.offsetWidth; |
||||
/* 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() { |
||||
var originalHeight = ta.style.height; |
||||
var overflows = getParentOverflows(ta); |
||||
var docTop = document.documentElement && document.documentElement.scrollTop; // Needed for Mobile IE (ticket #240)
|
||||
|
||||
ta.style.height = 'auto'; |
||||
|
||||
var endHeight = ta.scrollHeight + heightOffset; |
||||
|
||||
if (ta.scrollHeight === 0) { |
||||
// If the scrollHeight is 0, then the element probably has display:none or is detached from the DOM.
|
||||
ta.style.height = originalHeight; |
||||
return; |
||||
} |
||||
|
||||
ta.style.height = endHeight + '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); |
||||
var actualHeight = Math.round(parseFloat(computed.height)); |
||||
|
||||
// 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 set to visible.
|
||||
if (actualHeight !== styleHeight) { |
||||
if (computed.overflowY !== 'visible') { |
||||
changeOverflow('visible'); |
||||
resize(); |
||||
actualHeight = Math.round(parseFloat(window.getComputedStyle(ta, null).height)); |
||||
} |
||||
} else { |
||||
// Normally keep overflow set to hidden, to avoid flash of scrollbar as the textarea expands.
|
||||
if (computed.overflowY !== 'hidden') { |
||||
changeOverflow('hidden'); |
||||
resize(); |
||||
actualHeight = Math.round(parseFloat(window.getComputedStyle(ta, null).height)); |
||||
} |
||||
} |
||||
|
||||
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 (el) { |
||||
return el; |
||||
}; |
||||
autosize.destroy = function (el) { |
||||
return el; |
||||
}; |
||||
autosize.update = function (el) { |
||||
return el; |
||||
}; |
||||
} else { |
||||
autosize = function (el, options) { |
||||
if (el) { |
||||
Array.prototype.forEach.call(el.length ? el : [el], function (x) { |
||||
return assign(x, options); |
||||
}); |
||||
} |
||||
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; |
||||
}; |
||||
} |
||||
|
||||
module.exports = autosize; |
||||
}); |
@ -0,0 +1,6 @@ |
||||
/*! |
||||
Autosize 3.0.20 |
||||
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);"vertical"===t.resize?e.style.resize="none":"both"===t.resize&&(e.style.resize="horizontal"),s="content-box"===t.boxSizing?-(parseFloat(t.paddingTop)+parseFloat(t.paddingBottom)):parseFloat(t.borderTopWidth)+parseFloat(t.borderBottomWidth),isNaN(s)&&(s=0),l()}function n(t){var n=e.style.width;e.style.width="0px",e.offsetWidth,e.style.width=n,e.style.overflowY=t}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+s;return 0===e.scrollHeight?void(e.style.height=t):(e.style.height=i+"px",u=e.clientWidth,n.forEach(function(e){e.node.scrollTop=e.scrollTop}),void(r&&(document.documentElement.scrollTop=r)))}function l(){r();var t=Math.round(parseFloat(e.style.height)),o=window.getComputedStyle(e,null),i=Math.round(parseFloat(o.height));if(i!==t?"visible"!==o.overflowY&&(n("visible"),r(),i=Math.round(parseFloat(window.getComputedStyle(e,null).height))):"hidden"!==o.overflowY&&(n("hidden"),r(),i=Math.round(parseFloat(window.getComputedStyle(e,null).height))),a!==i){a=i;var l=d("autosize:resized");try{e.dispatchEvent(l)}catch(e){}}}if(e&&e.nodeName&&"TEXTAREA"===e.nodeName&&!i.has(e)){var s=null,u=e.clientWidth,a=null,p=function(){e.clientWidth!==u&&l()},c=function(t){window.removeEventListener("resize",p,!1),e.removeEventListener("input",l,!1),e.removeEventListener("keyup",l,!1),e.removeEventListener("autosize:destroy",c,!1),e.removeEventListener("autosize:update",l,!1),Object.keys(t).forEach(function(n){e.style[n]=t[n]}),i.delete(e)}.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",c,!1),"onpropertychange"in e&&"oninput"in e&&e.addEventListener("keyup",l,!1),window.addEventListener("resize",p,!1),e.addEventListener("input",l,!1),e.addEventListener("autosize:update",l,!1),e.style.overflowX="hidden",e.style.wordWrap="break-word",i.set(e,{destroy:c,update:l}),t()}}function o(e){var t=i.get(e);t&&t.destroy()}function r(e){var t=i.get(e);t&&t.update()}var i="function"==typeof Map?new Map:function(){var e=[],t=[];return{has:function(t){return e.indexOf(t)>-1},get:function(n){return t[e.indexOf(n)]},set:function(n,o){e.indexOf(n)===-1&&(e.push(n),t.push(o))},delete:function(n){var o=e.indexOf(n);o>-1&&(e.splice(o,1),t.splice(o,1))}}}(),d=function(e){return new Event(e,{bubbles:!0})};try{new Event("test")}catch(e){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}); |
File diff suppressed because one or more lines are too long
Loading…
Reference in new issue