@frsource/autoresize-textarea 1.3.90 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/index.es.js +1 -1
- package/dist/index.es.js.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/index.modern.mjs +1 -1
- package/dist/index.modern.mjs.map +1 -1
- package/dist/index.umd.js +1 -1
- package/dist/index.umd.js.map +1 -1
- package/package.json +5 -5
package/README.md
CHANGED
|
@@ -33,7 +33,7 @@
|
|
|
33
33
|
<br>
|
|
34
34
|
<i>Tiny library which make your textareas fluid.
|
|
35
35
|
<br>Mobile & desktop-friendly
|
|
36
|
-
<br>Performant & with small bundle size (less than
|
|
36
|
+
<br>Performant & with small bundle size (less than 1.2kB!)
|
|
37
37
|
<br>Published as separate bundles for JS ES5 or modern browsers thanks to <a href="https://www.npmjs.com/package/microbundle">microbundle</a>
|
|
38
38
|
<br>Written completely in <a href="https://www.typescriptlang.org">typescript</a></i>
|
|
39
39
|
<br>Published under <a href="https://opensource.org/licenses/MIT" target="_blank">MIT</a> license</i>
|
package/dist/index.es.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
function t(){return t=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var
|
|
1
|
+
function t(){return t=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(t[n]=r[n])}return t},t.apply(this,arguments)}function e(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r<e;r++)n[r]=t[r];return n}var r="data-frs-autoresize-textarea",n=function(n){if(!n.getAttribute(r)){n.setAttribute(r,"");var o="",i=function(){if(n.scrollHeight>n.clientHeight||o===n.style.height){var t=function(t){var r=new Map;do{var n;r.set(t,t.scrollTop)}while((t=null==(n=t)?void 0:n.parentNode)instanceof Element);return function(){for(var t,n=function(t,r){var n="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(n)return(n=n.call(t)).next.bind(n);if(Array.isArray(t)||(n=function(t,r){if(t){if("string"==typeof t)return e(t,r);var n=Object.prototype.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?e(t,r):void 0}}(t))){n&&(t=n);var o=0;return function(){return o>=t.length?{done:!0}:{done:!1,value:t[o++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(r);!(t=n()).done;){var o=t.value,i=o[0],a=o[1];if("style"in i){var l=i.style.scrollBehavior;i.style.scrollBehavior="auto",i.scrollTop=a,i.style.scrollBehavior=l}else i.scrollTop=a}}}(n);n.style.height="auto";var r=n.style.overflow;n.style.overflow="hidden",n.style.height=o=n.scrollHeight+(n.offsetHeight-n.clientHeight)+"px",n.style.overflow=r,t()}};n.style.boxSizing="border-box",i(),n.addEventListener("input",i);var a=Object.getPrototypeOf(n),l=Object.getOwnPropertyDescriptor(a,"value");return Object.defineProperty(n,"value",t({},l,{set:function(){var t;null==l||null==(t=l.set)||t.apply(this,arguments),i()}})),{detach:function(){n.removeAttribute(r),n.removeEventListener("input",i)},update:i}}};export{n as attach};
|
|
2
2
|
//# sourceMappingURL=index.es.js.map
|
package/dist/index.es.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.es.js","sources":["../src/index.ts"],"sourcesContent":["const ATTRIBUTE_NAME = \"data-frs-autoresize-textarea\";\n\nexport const attach = (element: HTMLTextAreaElement) => {\n if (element.getAttribute(ATTRIBUTE_NAME)) return;\n element.setAttribute(ATTRIBUTE_NAME, \"\");\n\n let prevHeight = \"\";\n const inputHandler = () => {\n if (\n element.scrollHeight > element.clientHeight ||\n prevHeight === element.style.height\n ) {\n const
|
|
1
|
+
{"version":3,"file":"index.es.js","sources":["../src/index.ts"],"sourcesContent":["const ATTRIBUTE_NAME = \"data-frs-autoresize-textarea\";\n\nconst cacheParentsScrollTop = (element: Element) => {\n const scrollTopMap = new Map<Element | HTMLElement, number>();\n\n do {\n scrollTopMap.set(element, element.scrollTop);\n } while ((element = element?.parentNode as Element) instanceof Element);\n\n return () => {\n for (const [element, scrollTop] of scrollTopMap) {\n if (\"style\" in element) {\n const currentValue = element.style.scrollBehavior;\n element.style.scrollBehavior = \"auto\";\n element.scrollTop = scrollTop;\n element.style.scrollBehavior = currentValue;\n } else element.scrollTop = scrollTop;\n }\n };\n};\n\nexport const attach = (element: HTMLTextAreaElement) => {\n if (element.getAttribute(ATTRIBUTE_NAME)) return;\n element.setAttribute(ATTRIBUTE_NAME, \"\");\n\n let prevHeight = \"\";\n const inputHandler = () => {\n if (\n element.scrollHeight > element.clientHeight ||\n prevHeight === element.style.height\n ) {\n const resetScrollTops = cacheParentsScrollTop(element);\n element.style.height = \"auto\";\n\n const currentValue = element.style.overflow;\n element.style.overflow = \"hidden\";\n element.style.height = prevHeight = `${\n element.scrollHeight + (element.offsetHeight - element.clientHeight)\n }px`;\n element.style.overflow = currentValue;\n\n resetScrollTops();\n }\n };\n\n element.style.boxSizing = \"border-box\";\n\n inputHandler();\n\n element.addEventListener(\"input\", inputHandler);\n\n const elementPrototype = Object.getPrototypeOf(element);\n const descriptor = Object.getOwnPropertyDescriptor(elementPrototype, \"value\");\n Object.defineProperty(element, \"value\", {\n ...descriptor,\n set() {\n descriptor?.set?.apply(\n this,\n // eslint-disable-next-line prefer-rest-params\n arguments as unknown as [unknown],\n );\n inputHandler();\n },\n });\n return {\n detach() {\n element.removeAttribute(ATTRIBUTE_NAME);\n element.removeEventListener(\"input\", inputHandler);\n },\n update: inputHandler,\n };\n};\n"],"names":["ATTRIBUTE_NAME","attach","element","getAttribute","setAttribute","prevHeight","inputHandler","scrollHeight","clientHeight","style","height","resetScrollTops","scrollTopMap","Map","_element","set","scrollTop","parentNode","Element","_step","_iterator","_createForOfIteratorHelperLoose","done","_step$value","value","currentValue","scrollBehavior","cacheParentsScrollTop","overflow","offsetHeight","boxSizing","addEventListener","elementPrototype","Object","getPrototypeOf","descriptor","getOwnPropertyDescriptor","defineProperty","_extends","_descriptor$set","apply","this","arguments","detach","removeAttribute","removeEventListener","update"],"mappings":"8UAAA,IAAMA,EAAiB,+BAqBVC,EAAS,SAACC,GACrB,IAAIA,EAAQC,aAAaH,GAAzB,CACAE,EAAQE,aAAaJ,EAAgB,IAErC,IAAIK,EAAa,GACXC,EAAe,WACnB,GACEJ,EAAQK,aAAeL,EAAQM,cAC/BH,IAAeH,EAAQO,MAAMC,OAC7B,CACA,IAAMC,EA7BkB,SAACT,GAC7B,IAAMU,EAAe,IAAIC,IAEzB,EAAG,KAAAC,EACDF,EAAaG,IAAIb,EAASA,EAAQc,kBAC1Bd,SAAOY,EAAGZ,UAAAY,EAASG,sBAAkCC,SAE/D,kBACE,IAAA,IAA+CC,EAA/CC,2qBAAAC,CAAmCT,KAAYO,EAAAC,KAAAE,MAAE,CAAA,IAAAC,EAAAJ,EAAAK,MAArCtB,EAAOqB,KAAEP,EAASO,EAC5B,GAAA,GAAI,UAAWrB,EAAS,CACtB,IAAMuB,EAAevB,EAAQO,MAAMiB,eACnCxB,EAAQO,MAAMiB,eAAiB,OAC/BxB,EAAQc,UAAYA,EACpBd,EAAQO,MAAMiB,eAAiBD,CAChC,MAAMvB,EAAQc,UAAYA,CAC5B,CACH,CACF,CAY8BW,CAAsBzB,GAC9CA,EAAQO,MAAMC,OAAS,OAEvB,IAAMe,EAAevB,EAAQO,MAAMmB,SACnC1B,EAAQO,MAAMmB,SAAW,SACzB1B,EAAQO,MAAMC,OAASL,EACrBH,EAAQK,cAAgBL,EAAQ2B,aAAe3B,EAAQM,cACrD,KACJN,EAAQO,MAAMmB,SAAWH,EAEzBd,GACD,CACH,EAEAT,EAAQO,MAAMqB,UAAY,aAE1BxB,IAEAJ,EAAQ6B,iBAAiB,QAASzB,GAElC,IAAM0B,EAAmBC,OAAOC,eAAehC,GACzCiC,EAAaF,OAAOG,yBAAyBJ,EAAkB,SAYrE,OAXAC,OAAOI,eAAenC,EAAS,QAAOoC,EAAA,CAAA,EACjCH,EACHpB,CAAAA,mBAAGwB,EACSA,MAAVJ,GAAAI,OAAUA,EAAVJ,EAAYpB,MAAZwB,EAAiBC,MACfC,KAEAC,WAEFpC,GACF,KAEK,CACLqC,OAAMA,WACJzC,EAAQ0C,gBAAgB5C,GACxBE,EAAQ2C,oBAAoB,QAASvC,EACvC,EACAwC,OAAQxC,EA/CgC,CAiD5C"}
|
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
function t(){return t=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var
|
|
1
|
+
function t(){return t=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(t[n]=r[n])}return t},t.apply(this,arguments)}function e(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r<e;r++)n[r]=t[r];return n}var r="data-frs-autoresize-textarea";exports.attach=function(n){if(!n.getAttribute(r)){n.setAttribute(r,"");var o="",i=function(){if(n.scrollHeight>n.clientHeight||o===n.style.height){var t=function(t){var r=new Map;do{var n;r.set(t,t.scrollTop)}while((t=null==(n=t)?void 0:n.parentNode)instanceof Element);return function(){for(var t,n=function(t,r){var n="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(n)return(n=n.call(t)).next.bind(n);if(Array.isArray(t)||(n=function(t,r){if(t){if("string"==typeof t)return e(t,r);var n=Object.prototype.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?e(t,r):void 0}}(t))){n&&(t=n);var o=0;return function(){return o>=t.length?{done:!0}:{done:!1,value:t[o++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(r);!(t=n()).done;){var o=t.value,i=o[0],a=o[1];if("style"in i){var l=i.style.scrollBehavior;i.style.scrollBehavior="auto",i.scrollTop=a,i.style.scrollBehavior=l}else i.scrollTop=a}}}(n);n.style.height="auto";var r=n.style.overflow;n.style.overflow="hidden",n.style.height=o=n.scrollHeight+(n.offsetHeight-n.clientHeight)+"px",n.style.overflow=r,t()}};n.style.boxSizing="border-box",i(),n.addEventListener("input",i);var a=Object.getPrototypeOf(n),l=Object.getOwnPropertyDescriptor(a,"value");return Object.defineProperty(n,"value",t({},l,{set:function(){var t;null==l||null==(t=l.set)||t.apply(this,arguments),i()}})),{detach:function(){n.removeAttribute(r),n.removeEventListener("input",i)},update:i}}};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../src/index.ts"],"sourcesContent":["const ATTRIBUTE_NAME = \"data-frs-autoresize-textarea\";\n\nexport const attach = (element: HTMLTextAreaElement) => {\n if (element.getAttribute(ATTRIBUTE_NAME)) return;\n element.setAttribute(ATTRIBUTE_NAME, \"\");\n\n let prevHeight = \"\";\n const inputHandler = () => {\n if (\n element.scrollHeight > element.clientHeight ||\n prevHeight === element.style.height\n ) {\n const
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../src/index.ts"],"sourcesContent":["const ATTRIBUTE_NAME = \"data-frs-autoresize-textarea\";\n\nconst cacheParentsScrollTop = (element: Element) => {\n const scrollTopMap = new Map<Element | HTMLElement, number>();\n\n do {\n scrollTopMap.set(element, element.scrollTop);\n } while ((element = element?.parentNode as Element) instanceof Element);\n\n return () => {\n for (const [element, scrollTop] of scrollTopMap) {\n if (\"style\" in element) {\n const currentValue = element.style.scrollBehavior;\n element.style.scrollBehavior = \"auto\";\n element.scrollTop = scrollTop;\n element.style.scrollBehavior = currentValue;\n } else element.scrollTop = scrollTop;\n }\n };\n};\n\nexport const attach = (element: HTMLTextAreaElement) => {\n if (element.getAttribute(ATTRIBUTE_NAME)) return;\n element.setAttribute(ATTRIBUTE_NAME, \"\");\n\n let prevHeight = \"\";\n const inputHandler = () => {\n if (\n element.scrollHeight > element.clientHeight ||\n prevHeight === element.style.height\n ) {\n const resetScrollTops = cacheParentsScrollTop(element);\n element.style.height = \"auto\";\n\n const currentValue = element.style.overflow;\n element.style.overflow = \"hidden\";\n element.style.height = prevHeight = `${\n element.scrollHeight + (element.offsetHeight - element.clientHeight)\n }px`;\n element.style.overflow = currentValue;\n\n resetScrollTops();\n }\n };\n\n element.style.boxSizing = \"border-box\";\n\n inputHandler();\n\n element.addEventListener(\"input\", inputHandler);\n\n const elementPrototype = Object.getPrototypeOf(element);\n const descriptor = Object.getOwnPropertyDescriptor(elementPrototype, \"value\");\n Object.defineProperty(element, \"value\", {\n ...descriptor,\n set() {\n descriptor?.set?.apply(\n this,\n // eslint-disable-next-line prefer-rest-params\n arguments as unknown as [unknown],\n );\n inputHandler();\n },\n });\n return {\n detach() {\n element.removeAttribute(ATTRIBUTE_NAME);\n element.removeEventListener(\"input\", inputHandler);\n },\n update: inputHandler,\n };\n};\n"],"names":["ATTRIBUTE_NAME","element","getAttribute","setAttribute","prevHeight","inputHandler","scrollHeight","clientHeight","style","height","resetScrollTops","scrollTopMap","Map","_element","set","scrollTop","parentNode","Element","_step","_iterator","_createForOfIteratorHelperLoose","done","_step$value","value","currentValue","scrollBehavior","cacheParentsScrollTop","overflow","offsetHeight","boxSizing","addEventListener","elementPrototype","Object","getPrototypeOf","descriptor","getOwnPropertyDescriptor","defineProperty","_extends","_descriptor$set","apply","this","arguments","detach","removeAttribute","removeEventListener","update"],"mappings":"8UAAA,IAAMA,EAAiB,8CAqBD,SAACC,GACrB,IAAIA,EAAQC,aAAaF,GAAzB,CACAC,EAAQE,aAAaH,EAAgB,IAErC,IAAII,EAAa,GACXC,EAAe,WACnB,GACEJ,EAAQK,aAAeL,EAAQM,cAC/BH,IAAeH,EAAQO,MAAMC,OAC7B,CACA,IAAMC,EA7BkB,SAACT,GAC7B,IAAMU,EAAe,IAAIC,IAEzB,EAAG,KAAAC,EACDF,EAAaG,IAAIb,EAASA,EAAQc,kBAC1Bd,SAAOY,EAAGZ,UAAAY,EAASG,sBAAkCC,SAE/D,kBACE,IAAA,IAA+CC,EAA/CC,2qBAAAC,CAAmCT,KAAYO,EAAAC,KAAAE,MAAE,CAAA,IAAAC,EAAAJ,EAAAK,MAArCtB,EAAOqB,KAAEP,EAASO,EAC5B,GAAA,GAAI,UAAWrB,EAAS,CACtB,IAAMuB,EAAevB,EAAQO,MAAMiB,eACnCxB,EAAQO,MAAMiB,eAAiB,OAC/BxB,EAAQc,UAAYA,EACpBd,EAAQO,MAAMiB,eAAiBD,CAChC,MAAMvB,EAAQc,UAAYA,CAC5B,CACH,CACF,CAY8BW,CAAsBzB,GAC9CA,EAAQO,MAAMC,OAAS,OAEvB,IAAMe,EAAevB,EAAQO,MAAMmB,SACnC1B,EAAQO,MAAMmB,SAAW,SACzB1B,EAAQO,MAAMC,OAASL,EACrBH,EAAQK,cAAgBL,EAAQ2B,aAAe3B,EAAQM,cACrD,KACJN,EAAQO,MAAMmB,SAAWH,EAEzBd,GACD,CACH,EAEAT,EAAQO,MAAMqB,UAAY,aAE1BxB,IAEAJ,EAAQ6B,iBAAiB,QAASzB,GAElC,IAAM0B,EAAmBC,OAAOC,eAAehC,GACzCiC,EAAaF,OAAOG,yBAAyBJ,EAAkB,SAYrE,OAXAC,OAAOI,eAAenC,EAAS,QAAOoC,EAAA,CAAA,EACjCH,EACHpB,CAAAA,mBAAGwB,EACSA,MAAVJ,GAAAI,OAAUA,EAAVJ,EAAYpB,MAAZwB,EAAiBC,MACfC,KAEAC,WAEFpC,GACF,KAEK,CACLqC,OAAMA,WACJzC,EAAQ0C,gBAAgB3C,GACxBC,EAAQ2C,oBAAoB,QAASvC,EACvC,EACAwC,OAAQxC,EA/CgC,CAiD5C"}
|
package/dist/index.modern.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
function
|
|
1
|
+
function e(){return e=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var o=arguments[t];for(var r in o)Object.prototype.hasOwnProperty.call(o,r)&&(e[r]=o[r])}return e},e.apply(this,arguments)}const t="data-frs-autoresize-textarea",o=o=>{if(o.getAttribute(t))return;o.setAttribute(t,"");let r="";const l=()=>{if(o.scrollHeight>o.clientHeight||r===o.style.height){const e=(e=>{const t=new Map;do{var o;t.set(e,e.scrollTop)}while((e=null==(o=e)?void 0:o.parentNode)instanceof Element);return()=>{for(const[e,o]of t)if("style"in e){const t=e.style.scrollBehavior;e.style.scrollBehavior="auto",e.scrollTop=o,e.style.scrollBehavior=t}else e.scrollTop=o}})(o);o.style.height="auto";const t=o.style.overflow;o.style.overflow="hidden",o.style.height=r=`${o.scrollHeight+(o.offsetHeight-o.clientHeight)}px`,o.style.overflow=t,e()}};o.style.boxSizing="border-box",l(),o.addEventListener("input",l);const s=Object.getPrototypeOf(o),n=Object.getOwnPropertyDescriptor(s,"value");return Object.defineProperty(o,"value",e({},n,{set(){var e;null==n||null==(e=n.set)||e.apply(this,arguments),l()}})),{detach(){o.removeAttribute(t),o.removeEventListener("input",l)},update:l}};export{o as attach};
|
|
2
2
|
//# sourceMappingURL=index.modern.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.modern.mjs","sources":["../src/index.ts"],"sourcesContent":["const ATTRIBUTE_NAME = \"data-frs-autoresize-textarea\";\n\nexport const attach = (element: HTMLTextAreaElement) => {\n if (element.getAttribute(ATTRIBUTE_NAME)) return;\n element.setAttribute(ATTRIBUTE_NAME, \"\");\n\n let prevHeight = \"\";\n const inputHandler = () => {\n if (\n element.scrollHeight > element.clientHeight ||\n prevHeight === element.style.height\n ) {\n const
|
|
1
|
+
{"version":3,"file":"index.modern.mjs","sources":["../src/index.ts"],"sourcesContent":["const ATTRIBUTE_NAME = \"data-frs-autoresize-textarea\";\n\nconst cacheParentsScrollTop = (element: Element) => {\n const scrollTopMap = new Map<Element | HTMLElement, number>();\n\n do {\n scrollTopMap.set(element, element.scrollTop);\n } while ((element = element?.parentNode as Element) instanceof Element);\n\n return () => {\n for (const [element, scrollTop] of scrollTopMap) {\n if (\"style\" in element) {\n const currentValue = element.style.scrollBehavior;\n element.style.scrollBehavior = \"auto\";\n element.scrollTop = scrollTop;\n element.style.scrollBehavior = currentValue;\n } else element.scrollTop = scrollTop;\n }\n };\n};\n\nexport const attach = (element: HTMLTextAreaElement) => {\n if (element.getAttribute(ATTRIBUTE_NAME)) return;\n element.setAttribute(ATTRIBUTE_NAME, \"\");\n\n let prevHeight = \"\";\n const inputHandler = () => {\n if (\n element.scrollHeight > element.clientHeight ||\n prevHeight === element.style.height\n ) {\n const resetScrollTops = cacheParentsScrollTop(element);\n element.style.height = \"auto\";\n\n const currentValue = element.style.overflow;\n element.style.overflow = \"hidden\";\n element.style.height = prevHeight = `${\n element.scrollHeight + (element.offsetHeight - element.clientHeight)\n }px`;\n element.style.overflow = currentValue;\n\n resetScrollTops();\n }\n };\n\n element.style.boxSizing = \"border-box\";\n\n inputHandler();\n\n element.addEventListener(\"input\", inputHandler);\n\n const elementPrototype = Object.getPrototypeOf(element);\n const descriptor = Object.getOwnPropertyDescriptor(elementPrototype, \"value\");\n Object.defineProperty(element, \"value\", {\n ...descriptor,\n set() {\n descriptor?.set?.apply(\n this,\n // eslint-disable-next-line prefer-rest-params\n arguments as unknown as [unknown],\n );\n inputHandler();\n },\n });\n return {\n detach() {\n element.removeAttribute(ATTRIBUTE_NAME);\n element.removeEventListener(\"input\", inputHandler);\n },\n update: inputHandler,\n };\n};\n"],"names":["ATTRIBUTE_NAME","attach","element","getAttribute","setAttribute","prevHeight","inputHandler","scrollHeight","clientHeight","style","height","resetScrollTops","scrollTopMap","Map","_element","set","scrollTop","parentNode","Element","currentValue","scrollBehavior","cacheParentsScrollTop","overflow","offsetHeight","boxSizing","addEventListener","elementPrototype","Object","getPrototypeOf","descriptor","getOwnPropertyDescriptor","defineProperty","_extends","_descriptor$set","apply","this","arguments","detach","removeAttribute","removeEventListener","update"],"mappings":"oOAAA,MAAMA,EAAiB,+BAqBVC,EAAUC,IACrB,GAAIA,EAAQC,aAAaH,GAAiB,OAC1CE,EAAQE,aAAaJ,EAAgB,IAErC,IAAIK,EAAa,GACjB,MAAMC,EAAeA,KACnB,GACEJ,EAAQK,aAAeL,EAAQM,cAC/BH,IAAeH,EAAQO,MAAMC,OAC7B,CACA,MAAMC,EA7BmBT,KAC7B,MAAMU,EAAe,IAAIC,IAEzB,EAAG,CAAA,IAAAC,EACDF,EAAaG,IAAIb,EAASA,EAAQc,kBAC1Bd,EAAUY,OAAHA,EAAGZ,QAAAY,EAAAA,EAASG,sBAAkCC,SAE/D,MAAO,KACL,IAAK,MAAOhB,EAASc,KAAcJ,EACjC,GAAI,UAAWV,EAAS,CACtB,MAAMiB,EAAejB,EAAQO,MAAMW,eACnClB,EAAQO,MAAMW,eAAiB,OAC/BlB,EAAQc,UAAYA,EACpBd,EAAQO,MAAMW,eAAiBD,CAChC,MAAMjB,EAAQc,UAAYA,CAC5B,CACH,EAa4BK,CAAsBnB,GAC9CA,EAAQO,MAAMC,OAAS,OAEvB,MAAMS,EAAejB,EAAQO,MAAMa,SACnCpB,EAAQO,MAAMa,SAAW,SACzBpB,EAAQO,MAAMC,OAASL,EACrB,GAAAH,EAAQK,cAAgBL,EAAQqB,aAAerB,EAAQM,kBAEzDN,EAAQO,MAAMa,SAAWH,EAEzBR,GACD,GAGHT,EAAQO,MAAMe,UAAY,aAE1BlB,IAEAJ,EAAQuB,iBAAiB,QAASnB,GAElC,MAAMoB,EAAmBC,OAAOC,eAAe1B,GACzC2B,EAAaF,OAAOG,yBAAyBJ,EAAkB,SAYrE,OAXAC,OAAOI,eAAe7B,EAAS,QAAO8B,KACjCH,EAAU,CACbd,UAAGkB,EACSA,MAAVJ,GAAe,OAALI,EAAVJ,EAAYd,MAAZkB,EAAiBC,MACfC,KAEAC,WAEF9B,GACF,KAEK,CACL+B,SACEnC,EAAQoC,gBAAgBtC,GACxBE,EAAQqC,oBAAoB,QAASjC,EACvC,EACAkC,OAAQlC"}
|
package/dist/index.umd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e||self).autoresizeTextarea={})}(this,function(e){function t(){return t=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e||self).autoresizeTextarea={})}(this,function(e){function t(){return t=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},t.apply(this,arguments)}function r(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=new Array(t);r<t;r++)n[r]=e[r];return n}var n="data-frs-autoresize-textarea";e.attach=function(e){if(!e.getAttribute(n)){e.setAttribute(n,"");var o="",i=function(){if(e.scrollHeight>e.clientHeight||o===e.style.height){var t=function(e){var t=new Map;do{var n;t.set(e,e.scrollTop)}while((e=null==(n=e)?void 0:n.parentNode)instanceof Element);return function(){for(var e,n=function(e,t){var n="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(n)return(n=n.call(e)).next.bind(n);if(Array.isArray(e)||(n=function(e,t){if(e){if("string"==typeof e)return r(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?r(e,t):void 0}}(e))){n&&(e=n);var o=0;return function(){return o>=e.length?{done:!0}:{done:!1,value:e[o++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(t);!(e=n()).done;){var o=e.value,i=o[0],a=o[1];if("style"in i){var l=i.style.scrollBehavior;i.style.scrollBehavior="auto",i.scrollTop=a,i.style.scrollBehavior=l}else i.scrollTop=a}}}(e);e.style.height="auto";var n=e.style.overflow;e.style.overflow="hidden",e.style.height=o=e.scrollHeight+(e.offsetHeight-e.clientHeight)+"px",e.style.overflow=n,t()}};e.style.boxSizing="border-box",i(),e.addEventListener("input",i);var a=Object.getPrototypeOf(e),l=Object.getOwnPropertyDescriptor(a,"value");return Object.defineProperty(e,"value",t({},l,{set:function(){var e;null==l||null==(e=l.set)||e.apply(this,arguments),i()}})),{detach:function(){e.removeAttribute(n),e.removeEventListener("input",i)},update:i}}}});
|
|
2
2
|
//# sourceMappingURL=index.umd.js.map
|
package/dist/index.umd.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.umd.js","sources":["../src/index.ts"],"sourcesContent":["const ATTRIBUTE_NAME = \"data-frs-autoresize-textarea\";\n\nexport const attach = (element: HTMLTextAreaElement) => {\n if (element.getAttribute(ATTRIBUTE_NAME)) return;\n element.setAttribute(ATTRIBUTE_NAME, \"\");\n\n let prevHeight = \"\";\n const inputHandler = () => {\n if (\n element.scrollHeight > element.clientHeight ||\n prevHeight === element.style.height\n ) {\n const
|
|
1
|
+
{"version":3,"file":"index.umd.js","sources":["../src/index.ts"],"sourcesContent":["const ATTRIBUTE_NAME = \"data-frs-autoresize-textarea\";\n\nconst cacheParentsScrollTop = (element: Element) => {\n const scrollTopMap = new Map<Element | HTMLElement, number>();\n\n do {\n scrollTopMap.set(element, element.scrollTop);\n } while ((element = element?.parentNode as Element) instanceof Element);\n\n return () => {\n for (const [element, scrollTop] of scrollTopMap) {\n if (\"style\" in element) {\n const currentValue = element.style.scrollBehavior;\n element.style.scrollBehavior = \"auto\";\n element.scrollTop = scrollTop;\n element.style.scrollBehavior = currentValue;\n } else element.scrollTop = scrollTop;\n }\n };\n};\n\nexport const attach = (element: HTMLTextAreaElement) => {\n if (element.getAttribute(ATTRIBUTE_NAME)) return;\n element.setAttribute(ATTRIBUTE_NAME, \"\");\n\n let prevHeight = \"\";\n const inputHandler = () => {\n if (\n element.scrollHeight > element.clientHeight ||\n prevHeight === element.style.height\n ) {\n const resetScrollTops = cacheParentsScrollTop(element);\n element.style.height = \"auto\";\n\n const currentValue = element.style.overflow;\n element.style.overflow = \"hidden\";\n element.style.height = prevHeight = `${\n element.scrollHeight + (element.offsetHeight - element.clientHeight)\n }px`;\n element.style.overflow = currentValue;\n\n resetScrollTops();\n }\n };\n\n element.style.boxSizing = \"border-box\";\n\n inputHandler();\n\n element.addEventListener(\"input\", inputHandler);\n\n const elementPrototype = Object.getPrototypeOf(element);\n const descriptor = Object.getOwnPropertyDescriptor(elementPrototype, \"value\");\n Object.defineProperty(element, \"value\", {\n ...descriptor,\n set() {\n descriptor?.set?.apply(\n this,\n // eslint-disable-next-line prefer-rest-params\n arguments as unknown as [unknown],\n );\n inputHandler();\n },\n });\n return {\n detach() {\n element.removeAttribute(ATTRIBUTE_NAME);\n element.removeEventListener(\"input\", inputHandler);\n },\n update: inputHandler,\n };\n};\n"],"names":["ATTRIBUTE_NAME","element","getAttribute","setAttribute","prevHeight","inputHandler","scrollHeight","clientHeight","style","height","resetScrollTops","scrollTopMap","Map","_element","set","scrollTop","parentNode","Element","_step","_iterator","_createForOfIteratorHelperLoose","done","_step$value","value","currentValue","scrollBehavior","cacheParentsScrollTop","overflow","offsetHeight","boxSizing","addEventListener","elementPrototype","Object","getPrototypeOf","descriptor","getOwnPropertyDescriptor","defineProperty","_extends","_descriptor$set","apply","this","arguments","detach","removeAttribute","removeEventListener","update"],"mappings":"0jBAAA,IAAMA,EAAiB,wCAqBD,SAACC,GACrB,IAAIA,EAAQC,aAAaF,GAAzB,CACAC,EAAQE,aAAaH,EAAgB,IAErC,IAAII,EAAa,GACXC,EAAe,WACnB,GACEJ,EAAQK,aAAeL,EAAQM,cAC/BH,IAAeH,EAAQO,MAAMC,OAC7B,CACA,IAAMC,EA7BkB,SAACT,GAC7B,IAAMU,EAAe,IAAIC,IAEzB,EAAG,KAAAC,EACDF,EAAaG,IAAIb,EAASA,EAAQc,kBAC1Bd,SAAOY,EAAGZ,UAAAY,EAASG,sBAAkCC,SAE/D,kBACE,IAAA,IAA+CC,EAA/CC,2qBAAAC,CAAmCT,KAAYO,EAAAC,KAAAE,MAAE,CAAA,IAAAC,EAAAJ,EAAAK,MAArCtB,EAAOqB,KAAEP,EAASO,EAC5B,GAAA,GAAI,UAAWrB,EAAS,CACtB,IAAMuB,EAAevB,EAAQO,MAAMiB,eACnCxB,EAAQO,MAAMiB,eAAiB,OAC/BxB,EAAQc,UAAYA,EACpBd,EAAQO,MAAMiB,eAAiBD,CAChC,MAAMvB,EAAQc,UAAYA,CAC5B,CACH,CACF,CAY8BW,CAAsBzB,GAC9CA,EAAQO,MAAMC,OAAS,OAEvB,IAAMe,EAAevB,EAAQO,MAAMmB,SACnC1B,EAAQO,MAAMmB,SAAW,SACzB1B,EAAQO,MAAMC,OAASL,EACrBH,EAAQK,cAAgBL,EAAQ2B,aAAe3B,EAAQM,cACrD,KACJN,EAAQO,MAAMmB,SAAWH,EAEzBd,GACD,CACH,EAEAT,EAAQO,MAAMqB,UAAY,aAE1BxB,IAEAJ,EAAQ6B,iBAAiB,QAASzB,GAElC,IAAM0B,EAAmBC,OAAOC,eAAehC,GACzCiC,EAAaF,OAAOG,yBAAyBJ,EAAkB,SAYrE,OAXAC,OAAOI,eAAenC,EAAS,QAAOoC,EAAA,CAAA,EACjCH,EACHpB,CAAAA,mBAAGwB,EACSA,MAAVJ,GAAAI,OAAUA,EAAVJ,EAAYpB,MAAZwB,EAAiBC,MACfC,KAEAC,WAEFpC,GACF,KAEK,CACLqC,OAAMA,WACJzC,EAAQ0C,gBAAgB3C,GACxBC,EAAQ2C,oBAAoB,QAASvC,EACvC,EACAwC,OAAQxC,EA/CgC,CAiD5C"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@frsource/autoresize-textarea",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "2.0.1",
|
|
4
4
|
"description": "Minimalistic plugin to autosize your textareas! 💪",
|
|
5
5
|
"sideEffects": false,
|
|
6
6
|
"source": "src/index.ts",
|
|
@@ -50,13 +50,13 @@
|
|
|
50
50
|
"@semantic-release/github": "9.0.4",
|
|
51
51
|
"@semantic-release/npm": "10.0.5",
|
|
52
52
|
"@semantic-release/release-notes-generator": "11.0.4",
|
|
53
|
-
"@typescript-eslint/eslint-plugin": "
|
|
54
|
-
"@typescript-eslint/parser": "
|
|
53
|
+
"@typescript-eslint/eslint-plugin": "6.4.1",
|
|
54
|
+
"@typescript-eslint/parser": "6.4.1",
|
|
55
55
|
"eslint": "8.47.0",
|
|
56
|
-
"eslint-config-prettier": "
|
|
56
|
+
"eslint-config-prettier": "9.0.0",
|
|
57
57
|
"eslint-plugin-eslint-comments": "3.2.0",
|
|
58
58
|
"microbundle": "0.15.1",
|
|
59
|
-
"prettier": "
|
|
59
|
+
"prettier": "3.0.2",
|
|
60
60
|
"rimraf": "^5.0.0",
|
|
61
61
|
"semantic-release": "21.0.9",
|
|
62
62
|
"typescript": "5.1.6"
|