aha-components 1.7.12 → 1.8.2

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.
Files changed (126) hide show
  1. package/README.md +10 -0
  2. package/dist/Avatar.esm.js +2 -0
  3. package/dist/Avatar.esm.js.map +1 -0
  4. package/dist/Avatar.js +2 -0
  5. package/dist/Avatar.js.map +1 -0
  6. package/dist/Badge.esm.js +2 -0
  7. package/dist/Badge.esm.js.map +1 -0
  8. package/dist/Badge.js +2 -0
  9. package/dist/Badge.js.map +1 -0
  10. package/dist/Checkbox.esm.js +1 -1
  11. package/dist/Checkbox.esm.js.map +1 -1
  12. package/dist/Checkbox.js +1 -1
  13. package/dist/Checkbox.js.map +1 -1
  14. package/dist/Input.esm.js +1 -1
  15. package/dist/Input.esm.js.map +1 -1
  16. package/dist/Input.js +1 -1
  17. package/dist/Input.js.map +1 -1
  18. package/dist/Pagination.esm.js +1 -1
  19. package/dist/Pagination.esm.js.map +1 -1
  20. package/dist/Pagination.js +1 -1
  21. package/dist/Pagination.js.map +1 -1
  22. package/dist/Radio.esm.js +1 -1
  23. package/dist/Radio.esm.js.map +1 -1
  24. package/dist/Radio.js +1 -1
  25. package/dist/Radio.js.map +1 -1
  26. package/dist/Table.esm.js +1 -1
  27. package/dist/Table.esm.js.map +1 -1
  28. package/dist/Table.js +1 -1
  29. package/dist/Table.js.map +1 -1
  30. package/dist/Tag.esm.js +1 -1
  31. package/dist/Tag.esm.js.map +1 -1
  32. package/dist/Tag.js +1 -1
  33. package/dist/Tag.js.map +1 -1
  34. package/dist/Textarea.esm.js +1 -1
  35. package/dist/Textarea.esm.js.map +1 -1
  36. package/dist/Textarea.js +1 -1
  37. package/dist/Textarea.js.map +1 -1
  38. package/dist/components/Avatar/Avatar.stories.d.ts +12 -0
  39. package/dist/components/Avatar/index.d.ts +42 -0
  40. package/dist/components/Badge/Badge.stories.d.ts +15 -0
  41. package/dist/components/Badge/index.d.ts +71 -0
  42. package/dist/components/Checkbox/Checkbox.stories 2.d.ts +12 -0
  43. package/dist/components/Checkbox/Checkbox.stories.d.ts +5 -4
  44. package/dist/components/Checkbox/index 2.d.ts +12 -0
  45. package/dist/components/Checkbox/index.d.ts +6 -0
  46. package/dist/components/DatePicker/DatePicker.stories 2.d.ts +25 -0
  47. package/dist/components/DatePicker/index 2.d.ts +96 -0
  48. package/dist/components/Drawer/Drawer.stories 2.d.ts +9 -0
  49. package/dist/components/Drawer/index 2.d.ts +58 -0
  50. package/dist/components/Form/Form.stories 2.d.ts +15 -0
  51. package/dist/components/Form/FormContext 2.d.ts +41 -0
  52. package/dist/components/Form/FormItem 2.d.ts +58 -0
  53. package/dist/components/Form/index 2.d.ts +85 -0
  54. package/dist/components/Input/Input.stories 2.d.ts +16 -0
  55. package/dist/components/Input/Input.stories.d.ts +7 -4
  56. package/dist/components/Input/InputGroup.d.ts +25 -0
  57. package/dist/components/Input/InputTags.d.ts +17 -0
  58. package/dist/components/Input/index 2.d.ts +41 -0
  59. package/dist/components/Input/index.d.ts +7 -18
  60. package/dist/components/Loading/Loading.stories 2.d.ts +11 -0
  61. package/dist/components/Loading/index 2.d.ts +10 -0
  62. package/dist/components/MenuList/MenuList.stories 2.d.ts +17 -0
  63. package/dist/components/MenuList/MenuList.test 2.d.ts +1 -0
  64. package/dist/components/MenuList/index 2.d.ts +85 -0
  65. package/dist/components/Pagination/Pagination.stories 2.d.ts +16 -0
  66. package/dist/components/Pagination/index 2.d.ts +27 -0
  67. package/dist/components/Popover/Popover.stories 2.d.ts +11 -0
  68. package/dist/components/Popover/index 2.d.ts +31 -0
  69. package/dist/components/Progress/Progress.stories 2.d.ts +18 -0
  70. package/dist/components/Progress/Progress.test 2.d.ts +1 -0
  71. package/dist/components/Progress/index 2.d.ts +33 -0
  72. package/dist/components/Radio/Radio.stories 2.d.ts +10 -0
  73. package/dist/components/Radio/Radio.stories.d.ts +6 -4
  74. package/dist/components/Radio/index 2.d.ts +13 -0
  75. package/dist/components/Radio/index.d.ts +6 -0
  76. package/dist/components/Select/Select.stories 2.d.ts +17 -0
  77. package/dist/components/Select/index 2.d.ts +74 -0
  78. package/dist/components/Switch/Switch.stories 2.d.ts +14 -0
  79. package/dist/components/Switch/index 2.d.ts +27 -0
  80. package/dist/components/Tab/Tab.stories 2.d.ts +19 -0
  81. package/dist/components/Tab/index 2.d.ts +26 -0
  82. package/dist/components/Table/Table.stories 2.d.ts +21 -0
  83. package/dist/components/Table/index 2.d.ts +167 -0
  84. package/dist/components/Tag/Tag.stories.d.ts +5 -8
  85. package/dist/components/Tag/index.d.ts +24 -2
  86. package/dist/components/Textarea/Textarea.stories 2.d.ts +15 -0
  87. package/dist/components/Textarea/Textarea.stories.d.ts +3 -6
  88. package/dist/components/Textarea/TextareaTags.d.ts +8 -0
  89. package/dist/components/Textarea/index 2.d.ts +38 -0
  90. package/dist/components/Textarea/index.d.ts +6 -17
  91. package/dist/components/Tooltip/Tooltip.stories 2.d.ts +20 -0
  92. package/dist/components/Tooltip/index 2.d.ts +35 -0
  93. package/dist/design-tokens/theme.css +26 -0
  94. package/dist/design-tokens/theme.tailwind4.css +26 -0
  95. package/dist/icons/index 2.d.ts +33 -0
  96. package/dist/index.css +4810 -1
  97. package/dist/index.d.ts +195 -39
  98. package/dist/index.esm.css +4810 -1
  99. package/dist/index.esm.js +1 -1
  100. package/dist/index.esm.js.map +1 -1
  101. package/dist/index.js +1 -1
  102. package/dist/index.js.map +1 -1
  103. package/dist/stories/DesignTokens.stories 2.d.ts +5 -0
  104. package/dist/theme/Theme.stories 2.d.ts +10 -0
  105. package/dist/theme/ThemeContext 2.d.ts +11 -0
  106. package/dist/theme/utils 2.d.ts +10 -0
  107. package/dist/theme.css +26 -0
  108. package/dist/tokens.d.ts +30 -0
  109. package/package.json +1 -1
  110. package/dist/AlertComponent.esm.js +0 -2
  111. package/dist/AlertComponent.esm.js.map +0 -1
  112. package/dist/AlertComponent.js +0 -2
  113. package/dist/AlertComponent.js.map +0 -1
  114. package/dist/Card.esm.js +0 -2
  115. package/dist/Card.esm.js.map +0 -1
  116. package/dist/Card.js +0 -2
  117. package/dist/Card.js.map +0 -1
  118. package/dist/TestComponent.esm.js +0 -2
  119. package/dist/TestComponent.esm.js.map +0 -1
  120. package/dist/TestComponent.js +0 -2
  121. package/dist/TestComponent.js.map +0 -1
  122. package/dist/Toast.css +0 -1
  123. package/dist/Toast.esm.css +0 -1
  124. package/dist/components/AlertComponent/index.d.ts +0 -9
  125. package/dist/components/Card/index.d.ts +0 -10
  126. package/dist/components/TestComponent/index.d.ts +0 -7
@@ -1,2 +1,2 @@
1
- import{jsxs as e,Fragment as t,jsx as n}from"react/jsx-runtime";import r,{createContext as a,useContext as o,forwardRef as i,useRef as l,useEffect as c,useMemo as u,useLayoutEffect as s}from"react";var p=function(){return p=Object.assign||function(e){for(var t,n=1,r=arguments.length;n<r;n++)for(var a in t=arguments[n])Object.prototype.hasOwnProperty.call(t,a)&&(e[a]=t[a]);return e},p.apply(this,arguments)};"function"==typeof SuppressedError&&SuppressedError;var d={primaryColor:"#FB6011"},f=a(d),h=/^(?:[a-zA-Z0-9-]+\.)+[a-zA-Z]{2,}$/,v=/(https?:\/\/[^\s<]+|www\.[^\s<]+|(?:[a-zA-Z0-9-]+\.)+[a-zA-Z]{2,}(?:\/[^\s<]*)?)/gi,g=new Set(["com","cn","net","org","io","co","edu","gov","ai","app","dev","me","info","biz","tech","cc","tv","xyz","top","vip","pro","store","site","online","cloud"]),x=function(e,t,n,r){if(void 0===t&&(t=!0),void 0===n&&(n=!0),!e||"string"!=typeof e)return!1;var a=e.trim();if(!a)return!1;var o=/^[a-zA-Z][a-zA-Z\d+\-.]*:\/\//.test(a);if(t&&!o)return!1;var i=o?a:"https://".concat(a);try{var l=new URL(i),c=l.protocol.toLowerCase();if("http:"!==c&&"https:"!==c)return!1;if(n){var u=l.hostname.toLowerCase();if(!u)return!1;if("localhost"===u)return!0;if(/^\d{1,3}(\.\d{1,3}){3}$/.test(u))return u.split(".").every(function(e){var t=Number(e);return Number.isInteger(t)&&t>=0&&t<=255});if(!h.test(u))return!1;var s=u.split(".").pop()||"";if(!(r?new Set(r.map(function(e){return e.toLowerCase()})):g).has(s))return!1}return!0}catch(e){return!1}},m=function(e){var t=e.match(/^(.*?)([),.;!?]+)?$/);return{core:(null==t?void 0:t[1])||e,suffix:(null==t?void 0:t[2])||""}},y=function(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")},w=function(e){return e.replace(new RegExp("​","g"),"")},C=function(e,t,n){var r=function(e,t){var n,r;if(!e)return[];for(var a=[],o=0,i=new RegExp(v),l=i.exec(e);l;){var c=l[0],u=l.index,s=u+c.length;u>o&&a.push({type:"text",text:e.slice(o,u)});var p=m(c),d=p.core,f=p.suffix,h=/^[a-zA-Z][a-zA-Z\d+\-.]*:\/\//.test(d)?d:"https://".concat(d),g=x(d,null!==(n=null==t?void 0:t.needProtocol)&&void 0!==n&&n,null===(r=null==t?void 0:t.needHost)||void 0===r||r,null==t?void 0:t.allowedTlds);((null==t?void 0:t.validate)?t.validate(h):g)&&d?(a.push({type:"url",text:d,href:h}),f&&a.push({type:"text",text:f})):a.push({type:"text",text:c}),o=s,l=i.exec(e)}return o<e.length&&a.push({type:"text",text:e.slice(o)}),a}(e,t);if(0===r.length)return"";var a=r.map(function(e){if("text"===e.type)return y(e.text);var r=(null==t?void 0:t.className)?' class="'.concat(t.className,'"'):"",a=n?"pointer-events: none;":"";return'<a href="'.concat(y(e.href),'" target="_blank" rel="noopener noreferrer"').concat(r,' style="color: #2563EB; text-decoration: underline; ').concat(a,'">').concat(y(e.text),"</a>")}).join("");return e.endsWith("\n")?"".concat(a,'<span data-aha-zwsp="true">').concat("​","</span>"):a},b=function(e){var t=window.getSelection();if(!t||0===t.rangeCount)return 0;var n=t.getRangeAt(0);if(!e.contains(n.startContainer))return 0;var r=n.cloneRange();return r.selectNodeContents(e),r.setEnd(n.startContainer,n.startOffset),w(r.toString()).length},S=i(function(a,i){var h=a.disabled,v=void 0!==h&&h,g=a.error,x=void 0!==g&&g,m=a.readOnly,y=void 0!==m&&m,S=a.showCount,z=void 0!==S&&S,O=a.maxLength,R=a.className,k=void 0===R?"":R,A=a.style,F=a.placeholder,E=a.value,N=a.defaultValue,B=a.rows,j=void 0===B?3:B,H=a.autoSize,M=void 0!==H&&H,D=a.onChange,L=a.onFocus,T=a.onBlur,Z=a.linkify,P=void 0!==Z&&Z,W=a.linkifyOptions,I=function(e,t){var n={};for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&t.indexOf(r)<0&&(n[r]=e[r]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var a=0;for(r=Object.getOwnPropertySymbols(e);a<r.length;a++)t.indexOf(r[a])<0&&Object.prototype.propertyIsEnumerable.call(e,r[a])&&(n[r[a]]=e[r[a]])}return n}(a,["disabled","error","readOnly","showCount","maxLength","className","style","placeholder","value","defaultValue","rows","autoSize","onChange","onFocus","onBlur","linkify","linkifyOptions"]),$=(o(f)||d).primaryColor,V=void 0===$?"#FB6011":$,Y=l(null),_=l(null),q=l(!1),K=l(null),U=r.useState(N||E||""),X=U[0],G=U[1],J=r.useState(!1),Q=J[0],ee=J[1],te=r.useState(void 0),ne=te[0],re=te[1];c(function(){"function"==typeof i?i(P?null:Y.current):i&&(i.current=P?null:Y.current)},[i,P]);var ae=void 0!==E,oe=ae?E:X,ie=String(oe||"").length,le=function(e){ee(!0),null==L||L(e)},ce=function(e){ee(!1),null==T||T(e)},ue=u(function(){return"number"==typeof O?O:void 0},[O]);c(function(){if(!P&&M&&Y.current){var e=Y.current,t="object"==typeof M&&M.minRows||1,n="object"==typeof M?M.maxRows:void 0;e.style.height="auto";var r=e.scrollHeight,a=parseInt(window.getComputedStyle(e).lineHeight||"22",10),o=t*a,i=n?n*a:void 0,l=Math.max(r,o);i&&(l=Math.min(l,i)),e.style.height="".concat(l,"px"),re(l)}},[oe,M,P]),c(function(){if(P&&M&&_.current){var e=_.current,t="object"==typeof M&&M.minRows||1,n="object"==typeof M?M.maxRows:void 0,r=parseInt(window.getComputedStyle(e).lineHeight||"24",10),a=t*r+24,o=n?n*r+24:void 0;e.style.height="auto";var i=Math.max(e.scrollHeight,a);o&&(i=Math.min(i,o)),e.style.height="".concat(i,"px"),e.style.overflowY=o&&e.scrollHeight>o?"auto":"hidden",re(i)}},[M,oe,P]),s(function(){var e;if(P&&_.current&&!q.current){var t=_.current,n=document.activeElement===t,r=n?b(t):0,a=null!==(e=K.current)&&void 0!==e?e:r,o=C(String(oe||""),W,v);if(t.innerHTML!==o&&(t.innerHTML=o),n){var i=String(oe||"").length;!function(e,t){var n=document.createRange(),r=window.getSelection();if(r){for(var a=Math.max(0,t),o=document.createTreeWalker(e,NodeFilter.SHOW_TEXT),i=o.nextNode();i;){for(var l=i.textContent||"",c=0,u=-1,s=0;s<l.length;s+=1)if("​"!==l[s]&&(c+=1),c===a){u=s+1;break}if(0===a)return n.setStart(i,0),n.collapse(!0),r.removeAllRanges(),void r.addRange(n);if(-1!==u)return n.setStart(i,u),n.collapse(!0),r.removeAllRanges(),void r.addRange(n);a-=c,i=o.nextNode()}n.selectNodeContents(e),n.collapse(!1),r.removeAllRanges(),r.addRange(n)}}(t,Math.min(a,i))}K.current=null}},[oe,v,P,W]);var se=function(e){null==D||D({target:{value:e},currentTarget:{value:e}})},pe=function(){if(_.current&&!q.current){K.current=b(_.current);var e=w(_.current.textContent||""),t=ue?e.slice(0,ue):e;ae||G(t),se(t)}},de=p(p({width:"100%",boxSizing:"border-box",fontFamily:"DM Sans, sans-serif",borderRadius:"8px",border:"1px solid ".concat(x?"#F04438":Q?V:"#D7D3D0"),backgroundColor:v||y?"#FAFAF9":"#FFFFFF",color:v?"#98A2B3":"#1C1917",fontSize:"16px",fontWeight:400,lineHeight:"24px",padding:"12px 14px",boxShadow:"0 1px 2px rgba(10, 13, 18, 0.05)",transition:"all 0.2s",outline:"none",resize:M||P?"none":"vertical",cursor:v?"not-allowed":"text",WebkitAppearance:"none",appearance:"none"},void 0!==ne&&M?{height:"".concat(ne,"px")}:{}),A);return e(t,{children:[n("style",{children:"\n .aha-textarea-wrapper textarea::placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea::-webkit-input-placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea::-moz-placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea:-ms-input-placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n /* 移动端优化 */\n .aha-textarea-wrapper textarea {\n -webkit-tap-highlight-color: transparent;\n -webkit-touch-callout: none;\n touch-action: manipulation;\n }\n .aha-textarea-wrapper .aha-textarea-editable {\n white-space: pre-wrap;\n word-break: break-word;\n }\n .aha-textarea-wrapper .aha-textarea-editable:empty::before {\n content: attr(data-placeholder);\n color: #79716B;\n }\n .aha-textarea-wrapper .aha-textarea-editable a {\n color: #2563EB;\n }\n "}),e("div",{className:"aha-textarea-wrapper ".concat(k),style:{position:"relative",display:"inline-flex",flexDirection:"column",width:"100%"},children:[P?n("div",{ref:_,className:"aha-textarea-editable",contentEditable:!v&&!y,suppressContentEditableWarning:!0,role:"textbox","aria-multiline":"true","aria-disabled":v,"data-placeholder":F||"",onInput:pe,onPaste:function(e){var t;if(e.preventDefault(),!y&&!v){var n,r,a=e.clipboardData.getData("text/plain"),o=String(oe||""),i=window.getSelection(),l="".concat(o).concat(a),c=o.length+a.length;if(i&&i.rangeCount>0&&(null===(t=_.current)||void 0===t?void 0:t.contains(i.anchorNode))){var u=b(_.current),s=(n=i.getRangeAt(0),(r=n.cloneRange()).selectNodeContents(_.current),r.setEnd(n.endContainer,n.endOffset),r.toString().length);l=o.slice(0,u)+a+o.slice(s),c=u+a.length}ue&&(l=l.slice(0,ue),c=Math.min(c,l.length)),K.current=c,ae||G(l),se(l)}},onKeyDown:function(e){var t,n;if("Enter"===e.key&&!e.nativeEvent.isComposing&&!v&&!y&&_.current){e.preventDefault();var r=String(oe||""),a=function(e){var t=window.getSelection();if(!t||0===t.rangeCount)return null;var n=t.getRangeAt(0);if(!e.contains(n.startContainer)||!e.contains(n.endContainer))return null;var r=n.cloneRange();r.selectNodeContents(e),r.setEnd(n.startContainer,n.startOffset);var a=n.cloneRange();return a.selectNodeContents(e),a.setEnd(n.endContainer,n.endOffset),{start:w(r.toString()).length,end:w(a.toString()).length}}(_.current),o=null!==(t=null==a?void 0:a.start)&&void 0!==t?t:r.length,i=null!==(n=null==a?void 0:a.end)&&void 0!==n?n:o,l="".concat(r.slice(0,o),"\n").concat(r.slice(i));ue&&(l=l.slice(0,ue));var c=Math.min(o+1,l.length);K.current=c,ae||G(l),se(l)}},onFocus:function(e){return le(e)},onBlur:function(e){return ce(e)},onCompositionStart:function(){q.current=!0},onCompositionEnd:function(){q.current=!1,pe()},style:p(p({},de),{minHeight:M?void 0:"".concat(24*j+24,"px"),overflowY:M?"hidden":"auto"}),autoCorrect:I.autoCorrect||"off",autoCapitalize:I.autoCapitalize||"off",spellCheck:I.spellCheck||!1}):n("textarea",p({ref:Y,value:oe,placeholder:F,disabled:v,readOnly:y,rows:M?void 0:j,maxLength:O,onChange:function(e){ae||G(e.target.value),null==D||D(e)},onFocus:le,onBlur:ce,style:de,autoComplete:I.autoComplete||"off",autoCorrect:I.autoCorrect||"off",autoCapitalize:I.autoCapitalize||"off",spellCheck:I.spellCheck||!1},I)),(z||O)&&n("div",{style:{display:"flex",justifyContent:"flex-end",marginTop:"4px",fontSize:"12px",lineHeight:"18px",color:v?"#98A2B3":"#78716C",fontFamily:"DM Sans, sans-serif"},children:O?e("span",{children:[ie," / ",O]}):n("span",{children:ie})})]})]})});S.displayName="Textarea";export{S as default,x as websiteValidator};
1
+ import{jsxs as e,jsx as t,Fragment as r}from"react/jsx-runtime";import o,{createContext as n,useContext as a,useState as i,useRef as l,forwardRef as c,useEffect as d,useMemo as s,useLayoutEffect as u}from"react";var p=function(){return p=Object.assign||function(e){for(var t,r=1,o=arguments.length;r<o;r++)for(var n in t=arguments[r])Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e},p.apply(this,arguments)};function f(e,t){var r={};for(var o in e)Object.prototype.hasOwnProperty.call(e,o)&&t.indexOf(o)<0&&(r[o]=e[o]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var n=0;for(o=Object.getOwnPropertySymbols(e);n<o.length;n++)t.indexOf(o[n])<0&&Object.prototype.propertyIsEnumerable.call(e,o[n])&&(r[o[n]]=e[o[n]])}return r}function h(e,t,r){if(r||2===arguments.length)for(var o,n=0,a=t.length;n<a;n++)!o&&n in t||(o||(o=Array.prototype.slice.call(t,0,n)),o[n]=t[n]);return e.concat(o||Array.prototype.slice.call(t))}"function"==typeof SuppressedError&&SuppressedError;var g={primaryColor:"#FB6011"},x=n(g),v={Green:{light:{bg:"#ECFDF5",text:"#006045",border:"#A4F4CF"},fill:{bg:"#00BC7D",text:"#FFFFFF"}},Red:{light:{bg:"#FEF2F2",text:"#9F0712",border:"#FFC9C9"},fill:{bg:"#FB2C36",text:"#FFFFFF"}},Orange:{light:{bg:"#FFF6ED",text:"#9B2911",border:"#FFD1A9"},fill:{bg:"#FB6011",text:"#FFFFFF"}},Cyan:{light:{bg:"#ECFEFF",text:"#005F78",border:"#A2F4FD"},fill:{bg:"#00B8DB",text:"#FFFFFF"}},Violet:{light:{bg:"#F5F3FF",text:"#5D0EC0",border:"#DDD6FF"},fill:{bg:"#8E51FF",text:"#FFFFFF"}},Pink:{light:{bg:"#FDF2F8",text:"#A3004C",border:"#FCCEE8"},fill:{bg:"#F6339A",text:"#FFFFFF"}},Gray:{light:{bg:"#F5F5F4",text:"#292524",border:"#E7E5E4"},fill:{bg:"#292524",text:"#FFFFFF"}},Yellow:{light:{bg:"#FFFBEB",text:"#973C00",border:"#FEE685"},fill:{bg:"#FE9A00",text:"#FFFFFF"}},Blue:{light:{bg:"#EFF6FF",text:"#193CB8",border:"#BEDBFF"},fill:{bg:"#2B7FFF",text:"#FFFFFF"}}},b={sm:{basePx:8,basePy:3,plCheckbox:5,plAvatar:4,plDot:6,plIcon:4,prClose:4,prCount:4,fontSize:12,lineHeight:"18px",height:24,avatarSize:16,checkboxSize:14,contentGap:4,rootGap:3,countPx:4,countFontSize:12,closeSize:10,closePad:2},md:{basePx:9,basePy:2,plCheckbox:4,plAvatar:5,plDot:7,plIcon:5,prClose:4,prCount:3,fontSize:14,lineHeight:"20px",height:24,avatarSize:16,checkboxSize:16,contentGap:5,rootGap:4,countPx:5,countFontSize:12,closeSize:12,closePad:2},lg:{basePx:10,basePy:4,plCheckbox:5,plAvatar:7,plDot:9,plIcon:7,prClose:4,prCount:4,fontSize:14,lineHeight:"20px",height:28,avatarSize:18,checkboxSize:18,contentGap:6,rootGap:4,countPx:6,countFontSize:14,closeSize:14,closePad:3}},y=function(r){var o=r.src,n=r.alt,a=void 0===n?"Avatar":n,l=r.size,c=void 0===l?16:l,d=i(!1),s=d[0],u=d[1];return t("div",{style:{width:c,height:c,borderRadius:"50%",overflow:"hidden",flexShrink:0,border:"0.667px solid rgba(0,0,0,0.08)",background:"#e5e5e4",display:"flex",alignItems:"center",justifyContent:"center"},children:o&&!s?t("img",{src:o,alt:a,onError:function(){return u(!0)},style:{width:"100%",height:"100%",objectFit:"cover",display:"block"}}):e("svg",{width:.625*c,height:.625*c,viewBox:"0 0 10 10",fill:"none",children:[t("circle",{cx:"5",cy:"3.5",r:"2",stroke:"#999",strokeWidth:"1.2"}),t("path",{d:"M1 9.5c0-2.2 1.8-4 4-4s4 1.8 4 4",stroke:"#999",strokeWidth:"1.2",strokeLinecap:"round"})]})})},m=function(r){var n=r.children,l=r.color,c=r.variant,d=void 0===c?"light":c,s=r.size,u=void 0===s?"md":s,h=r.stroke,m=void 0!==h&&h,F=r.iconType,C=r.icon,w=r.avatarSrc,S=r.dotColor,k=r.action,z=void 0===k?"none":k,E=r.count,D=r.onClose,A=r.checkbox,O=void 0!==A&&A,R=r.checked,I=r.onCheckedChange,B=r.iconPosition,P=r.className,H=void 0===P?"":P,N=r.onClick,L=f(r,["children","color","variant","size","stroke","iconType","icon","avatarSrc","dotColor","action","count","onClose","checkbox","checked","onCheckedChange","iconPosition","className","onClick"]),W=(a(x)||g).primaryColor,j=i(!1),T=j[0],M=j[1],G=function(e){return"large"===e?"lg":"small"===e?"sm":e}(u),q=b[G],Z=void 0!==R?R:T,_=null!=F?F:C&&"leading"===B?"icon":"none",V="none"!==z?z:void 0,Y=O?q.plCheckbox:"dot"===_?q.plDot:"avatar"===_||"icon"===_?q.plAvatar:q.basePx,$="x-close"===V?q.prClose:"count"===V?q.prCount:q.basePx,K={display:"inline-flex",alignItems:"center",gap:"x-close"===V?q.rootGap:0,paddingLeft:Y,paddingRight:$,paddingTop:q.basePy,paddingBottom:q.basePy,height:q.height,borderRadius:6,fontFamily:"DM Sans, sans-serif",fontWeight:500,fontSize:q.fontSize,lineHeight:q.lineHeight,transition:"all 0.2s",cursor:N?"pointer":"default",boxSizing:"border-box",backgroundColor:"#ffffff",color:"#44403c",outline:"1px solid #d7d3d0",outlineOffset:"-1px"};if(l){var U=function(e,t){if(e in v){var r=v[e];return"Orange"===e&&t?p(p({},r),{fill:p(p({},r.fill),{bg:t})}):r}if(e.startsWith("#")){var o=parseInt(e.slice(1,3),16),n=parseInt(e.slice(3,5),16),a=parseInt(e.slice(5,7),16);return{light:{bg:"rgba(".concat(o,",").concat(n,",").concat(a,",0.1)"),text:e,border:"rgba(".concat(o,",").concat(n,",").concat(a,",0.3)")},fill:{bg:e,text:"#FFFFFF"}}}return v.Gray}(l,W);"light"===d?(K.backgroundColor=U.light.bg,K.color=U.light.text,K.outline=m?"1px solid ".concat(function(e){var t={Green:"#A4F4CF",Red:"#FFC9C9",Orange:"#FFD1A9",Blue:"#BEDBFF",Yellow:"#FFD1A9",Cyan:"#A2F4FD",Violet:"#DDD6FF",Pink:"#FCCEE8",Gray:"#E7E5E4"};if(e in t)return t[e];if(e.startsWith("#")){var r=parseInt(e.slice(1,3),16),o=parseInt(e.slice(3,5),16),n=parseInt(e.slice(5,7),16);return"rgba(".concat(r,",").concat(o,",").concat(n,",0.3)")}return"#E7E5E4"}(l)):"none",K.outlineOffset=m?"-1px":void 0):(K.backgroundColor=U.fill.bg,K.color=U.fill.text,K.outline="none")}N&&(K.cursor="pointer");return e("div",p({className:H,style:K,onClick:N},L,{children:[e("div",{style:{display:"flex",alignItems:"center",gap:q.contentGap,flexShrink:0},children:[O&&t("div",{role:"checkbox","aria-checked":Z,onClick:function(e){e.stopPropagation();var t=!Z;void 0===R&&M(t),null==I||I(t)},style:{width:q.checkboxSize,height:q.checkboxSize,borderRadius:4,flexShrink:0,border:Z?"none":"1px solid #d7d3d0",background:Z?W||"#7F56D9":"#ffffff",display:"flex",alignItems:"center",justifyContent:"center",cursor:"pointer"},children:Z&&t("svg",{width:Math.round(.65*q.checkboxSize),height:Math.round(.65*q.checkboxSize),viewBox:"0 0 10 10",fill:"none",children:t("path",{d:"M8.5 2L4 7.5 1.5 5",stroke:"#fff",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})}),"avatar"===_?t(y,{src:w,size:q.avatarSize}):"dot"===_?t("svg",{width:8,height:8,viewBox:"0 0 8 8",fill:"none",style:{flexShrink:0},children:t("circle",{cx:4,cy:4,r:3.5,fill:S||"currentColor"})}):"icon"===_&&C?t("span",{style:{display:"flex",alignItems:"center",flexShrink:0},children:o.cloneElement(C,{width:q.avatarSize,height:q.avatarSize})}):null,t("span",{style:{whiteSpace:"nowrap"},children:n}),"count"===V&&"number"==typeof E&&t("span",{style:{display:"flex",alignItems:"center",justifyContent:"center",paddingLeft:q.countPx,paddingRight:q.countPx,paddingTop:1,paddingBottom:1,background:"rgba(0,0,0,0.07)",borderRadius:3,fontSize:q.countFontSize,fontWeight:500,lineHeight:"16px",flexShrink:0},children:E})]}),"x-close"===V&&t("button",{"aria-label":"Remove",onClick:function(e){e.stopPropagation(),null==D||D()},style:{display:"flex",alignItems:"center",justifyContent:"center",padding:q.closePad,borderRadius:3,border:"none",background:"transparent",cursor:"pointer",flexShrink:0,color:"inherit",opacity:.55,lineHeight:0},children:t("svg",{width:q.closeSize,height:q.closeSize,viewBox:"0 0 10 10",fill:"none",children:t("path",{d:"M7.5 2.5l-5 5M2.5 2.5l5 5",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round"})})}),"after"===B&&C&&!F&&t("span",{style:{display:"flex",alignItems:"center",flexShrink:0,marginLeft:q.contentGap},children:C})]}))},F="var(--shadow-xs)",C={small:"4px",mediumSmall:"6px",medium:"8px",large:"10px"},w={small:"sm",mediumSmall:"sm",medium:"md",large:"lg"},S=function(r){var o=r.value,n=r.defaultValue,a=void 0===n?[]:n,c=r.onChange,d=r.placeholder,s=void 0===d?"Add tag...":d,u=r.disabled,f=void 0!==u&&u,g=r.error,x=void 0!==g&&g,v=r.size,b=void 0===v?"mediumSmall":v,y=r.className,S=void 0===y?"":y,k=r.style,z=r.label,E=r.required,D=r.hintText,A=i(a),O=A[0],R=A[1],I=i(""),B=I[0],P=I[1],H=i(!1),N=H[0],L=H[1],W=l(null),j=void 0!==o,T=j?o:O,M=function(e){j||R(e),null==c||c(e)},G=function(e){var t=e.trim();t&&!T.includes(t)&&(M(h(h([],T,!0),[t],!1)),P(""))},q=function(e){M(T.filter(function(t,r){return r!==e}))},Z=f?{border:"1px solid var(--color-border-disabled)",boxShadow:F,outline:"none"}:x&&N?{border:"1px solid var(--color-border-error)",boxShadow:F,outline:"2px solid var(--color-border-error)",outlineOffset:"-2px"}:x?{border:"1px solid var(--color-border-error_subtle)",boxShadow:F,outline:"none"}:N?{border:"1px solid var(--color-border-brand)",boxShadow:F,outline:"2px solid var(--color-border-brand)",outlineOffset:"-2px"}:{border:"1px solid var(--color-border-primary)",boxShadow:F,outline:"none"},_=Z.border,V=Z.boxShadow,Y=Z.outline,$=Z.outlineOffset,K=C[b],U=w[b],X=e("div",{className:"aha-input-tags ".concat(S),onClick:function(){var e;return null===(e=W.current)||void 0===e?void 0:e.focus()},style:p({display:"flex",flexWrap:"wrap",alignItems:"center",gap:"6px",padding:K,border:_,boxShadow:V,outline:Y,outlineOffset:$,borderRadius:"var(--radius-md)",backgroundColor:f?"var(--color-bg-disabled_subtle)":"var(--color-bg-primary)",boxSizing:"border-box",width:"100%",transition:"border-color 0.15s ease, box-shadow 0.15s ease",cursor:f?"not-allowed":"text"},k),children:[T.map(function(e,r){return t(m,{size:U,action:f?"none":"x-close",onClose:function(){return q(r)},children:e},r)}),t("input",{ref:W,value:B,onChange:function(e){return P(e.target.value)},onKeyDown:function(e){"Enter"!==e.key&&","!==e.key||!B||(e.preventDefault(),G(B)),"Backspace"===e.key&&!B&&T.length>0&&q(T.length-1)},onFocus:function(){return L(!0)},onBlur:function(){L(!1),B&&G(B)},disabled:f,placeholder:0===T.length?s:"",style:{flex:1,minWidth:"80px",border:"none",outline:"none",padding:0,fontFamily:"var(--font-family-body)",fontSize:"var(--font-size-text-md)",lineHeight:"var(--line-height-text-md)",color:f?"var(--color-text-disabled)":"var(--color-text-primary)",backgroundColor:"transparent"}}),t("style",{children:"\n .aha-input-tags input::placeholder { color: var(--color-text-placeholder); }\n "})]});return z||D?e("div",{style:{display:"flex",flexDirection:"column",gap:"6px",width:"100%"},children:[z&&e("label",{style:{fontFamily:"var(--font-family-body)",fontSize:"var(--font-size-text-sm)",fontWeight:500,lineHeight:"20px",color:"var(--color-text-secondary)"},children:[z,E&&t("span",{style:{color:"var(--color-error-600)",marginLeft:"2px"},children:"*"})]}),X,D&&t("p",{style:{margin:0,fontFamily:"var(--font-family-body)",fontSize:"var(--font-size-text-sm)",fontWeight:400,lineHeight:"20px",color:x?"var(--color-error-600)":"var(--color-text-tertiary)"},children:D})]}):X},k=function(r){var o=r.minHeight,n=void 0===o?120:o,a=r.style,i=r.label,l=r.required,c=r.hintText,d=r.helpIcon,s=r.error,u=f(r,["minHeight","style","label","required","hintText","helpIcon","error"]),h=t(S,p({error:s,style:p({minHeight:"".concat(n,"px"),alignItems:"flex-start",overflow:"auto",resize:"vertical"},a)},u));return i||c?e("div",{style:{display:"flex",flexDirection:"column",gap:"6px",width:"100%"},children:[i&&e("label",{style:{fontFamily:"var(--font-family-body)",fontSize:"var(--font-size-text-sm)",fontWeight:500,lineHeight:"20px",color:"var(--color-text-secondary)",display:"flex",alignItems:"center"},children:[i,l&&t("span",{style:{color:"var(--color-error-600)",marginLeft:"2px"},children:"*"}),d&&t("span",{style:{marginLeft:"4px",display:"inline-flex",alignItems:"center",color:"var(--color-fg-quaternary)"},children:d})]}),h,c&&t("p",{style:{margin:0,fontFamily:"var(--font-family-body)",fontSize:"var(--font-size-text-sm)",fontWeight:400,lineHeight:"20px",color:s?"var(--color-error-600)":"var(--color-text-tertiary)"},children:c})]}):h},z=/^(?:[a-zA-Z0-9-]+\.)+[a-zA-Z]{2,}$/,E=/(https?:\/\/[^\s<]+|www\.[^\s<]+|(?:[a-zA-Z0-9-]+\.)+[a-zA-Z]{2,}(?:\/[^\s<]*)?)/gi,D=new Set(["com","cn","net","org","io","co","edu","gov","ai","app","dev","me","info","biz","tech","cc","tv","xyz","top","vip","pro","store","site","online","cloud"]),A=function(e,t,r,o){if(void 0===t&&(t=!0),void 0===r&&(r=!0),!e||"string"!=typeof e)return!1;var n=e.trim();if(!n)return!1;var a=/^[a-zA-Z][a-zA-Z\d+\-.]*:\/\//.test(n);if(t&&!a)return!1;var i=a?n:"https://".concat(n);try{var l=new URL(i),c=l.protocol.toLowerCase();if("http:"!==c&&"https:"!==c)return!1;if(r){var d=l.hostname.toLowerCase();if(!d)return!1;if("localhost"===d)return!0;if(/^\d{1,3}(\.\d{1,3}){3}$/.test(d))return d.split(".").every(function(e){var t=Number(e);return Number.isInteger(t)&&t>=0&&t<=255});if(!z.test(d))return!1;var s=d.split(".").pop()||"";if(!(o?new Set(o.map(function(e){return e.toLowerCase()})):D).has(s))return!1}return!0}catch(e){return!1}},O=function(e){var t=e.match(/^(.*?)([),.;!?]+)?$/);return{core:(null==t?void 0:t[1])||e,suffix:(null==t?void 0:t[2])||""}},R=function(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")},I=function(e){return e.replace(new RegExp("​","g"),"")},B=function(e,t,r){var o=function(e,t){var r,o;if(!e)return[];for(var n=[],a=0,i=new RegExp(E),l=i.exec(e);l;){var c=l[0],d=l.index,s=d+c.length;d>a&&n.push({type:"text",text:e.slice(a,d)});var u=O(c),p=u.core,f=u.suffix,h=/^[a-zA-Z][a-zA-Z\d+\-.]*:\/\//.test(p)?p:"https://".concat(p),g=A(p,null!==(r=null==t?void 0:t.needProtocol)&&void 0!==r&&r,null===(o=null==t?void 0:t.needHost)||void 0===o||o,null==t?void 0:t.allowedTlds);((null==t?void 0:t.validate)?t.validate(h):g)&&p?(n.push({type:"url",text:p,href:h}),f&&n.push({type:"text",text:f})):n.push({type:"text",text:c}),a=s,l=i.exec(e)}return a<e.length&&n.push({type:"text",text:e.slice(a)}),n}(e,t);if(0===o.length)return"";var n=o.map(function(e){if("text"===e.type)return R(e.text);var o=(null==t?void 0:t.className)?' class="'.concat(t.className,'"'):"",n=r?"pointer-events: none;":"";return'<a href="'.concat(R(e.href),'" target="_blank" rel="noopener noreferrer"').concat(o,' style="color: #2563EB; text-decoration: underline; ').concat(n,'">').concat(R(e.text),"</a>")}).join("");return e.endsWith("\n")?"".concat(n,'<span data-aha-zwsp="true">').concat("​","</span>"):n},P=function(e){var t=window.getSelection();if(!t||0===t.rangeCount)return 0;var r=t.getRangeAt(0);if(!e.contains(r.startContainer))return 0;var o=r.cloneRange();return o.selectNodeContents(e),o.setEnd(r.startContainer,r.startOffset),I(o.toString()).length},H=c(function(n,a){var i=n.disabled,c=void 0!==i&&i,h=n.error,g=void 0!==h&&h,x=n.readOnly,v=void 0!==x&&x,b=n.showCount,y=void 0!==b&&b,m=n.maxLength,F=n.className,C=void 0===F?"":F,w=n.style,S=n.placeholder,k=n.value,z=n.defaultValue,E=n.rows,D=void 0===E?3:E,A=n.autoSize,O=void 0!==A&&A,R=n.onChange,H=n.onFocus,N=n.onBlur,L=n.linkify,W=void 0!==L&&L,j=n.linkifyOptions,T=n.label,M=n.required,G=n.hintText,q=n.helpIcon,Z=f(n,["disabled","error","readOnly","showCount","maxLength","className","style","placeholder","value","defaultValue","rows","autoSize","onChange","onFocus","onBlur","linkify","linkifyOptions","label","required","hintText","helpIcon"]),_=l(null),V=l(null),Y=l(!1),$=l(null),K=o.useState(z||k||""),U=K[0],X=K[1],J=o.useState(!1),Q=J[0],ee=J[1],te=o.useState(void 0),re=te[0],oe=te[1];d(function(){"function"==typeof a?a(W?null:_.current):a&&(a.current=W?null:_.current)},[a,W]);var ne=void 0!==k,ae=ne?k:U,ie=String(ae||"").length,le=function(e){ee(!0),null==H||H(e)},ce=function(e){ee(!1),null==N||N(e)},de=s(function(){return"number"==typeof m?m:void 0},[m]);d(function(){if(!W&&O&&_.current){var e=_.current,t="object"==typeof O&&O.minRows||1,r="object"==typeof O?O.maxRows:void 0;e.style.height="auto";var o=e.scrollHeight,n=parseInt(window.getComputedStyle(e).lineHeight||"22",10),a=t*n,i=r?r*n:void 0,l=Math.max(o,a);i&&(l=Math.min(l,i)),e.style.height="".concat(l,"px"),oe(l)}},[ae,O,W]),d(function(){if(W&&O&&V.current){var e=V.current,t="object"==typeof O&&O.minRows||1,r="object"==typeof O?O.maxRows:void 0,o=parseInt(window.getComputedStyle(e).lineHeight||"24",10),n=t*o+24,a=r?r*o+24:void 0;e.style.height="auto";var i=Math.max(e.scrollHeight,n);a&&(i=Math.min(i,a)),e.style.height="".concat(i,"px"),e.style.overflowY=a&&e.scrollHeight>a?"auto":"hidden",oe(i)}},[O,ae,W]),u(function(){var e;if(W&&V.current&&!Y.current){var t=V.current,r=document.activeElement===t,o=r?P(t):0,n=null!==(e=$.current)&&void 0!==e?e:o,a=B(String(ae||""),j,c);if(t.innerHTML!==a&&(t.innerHTML=a),r){var i=String(ae||"").length;!function(e,t){var r=document.createRange(),o=window.getSelection();if(o){for(var n=Math.max(0,t),a=document.createTreeWalker(e,NodeFilter.SHOW_TEXT),i=a.nextNode();i;){for(var l=i.textContent||"",c=0,d=-1,s=0;s<l.length;s+=1)if("​"!==l[s]&&(c+=1),c===n){d=s+1;break}if(0===n)return r.setStart(i,0),r.collapse(!0),o.removeAllRanges(),void o.addRange(r);if(-1!==d)return r.setStart(i,d),r.collapse(!0),o.removeAllRanges(),void o.addRange(r);n-=c,i=a.nextNode()}r.selectNodeContents(e),r.collapse(!1),o.removeAllRanges(),o.addRange(r)}}(t,Math.min(n,i))}$.current=null}},[ae,c,W,j]);var se=function(e){null==R||R({target:{value:e},currentTarget:{value:e}})},ue=function(){if(V.current&&!Y.current){$.current=P(V.current);var e=I(V.current.textContent||""),t=de?e.slice(0,de):e;ne||X(t),se(t)}},pe="var(--shadow-xs)",fe=p(p(p(p({width:"100%",boxSizing:"border-box",fontFamily:"var(--font-family-body)",borderRadius:"var(--radius-md)"},c?{border:"1px solid var(--color-border-disabled)",boxShadow:pe,outline:"none"}:g&&Q?{border:"1px solid var(--color-border-error)",boxShadow:pe,outline:"2px solid var(--color-border-error)",outlineOffset:"-2px"}:g?{border:"1px solid var(--color-border-error_subtle)",boxShadow:pe,outline:"none"}:Q?{border:"1px solid var(--color-border-brand)",boxShadow:pe,outline:"2px solid var(--color-border-brand)",outlineOffset:"-2px"}:{border:"1px solid var(--color-border-primary)",boxShadow:pe,outline:"none"}),{backgroundColor:c||v?"var(--color-bg-disabled_subtle)":"var(--color-bg-primary)",color:c?"var(--color-text-disabled)":"var(--color-text-primary)",fontSize:"var(--font-size-text-md)",fontWeight:400,lineHeight:"var(--line-height-text-md)",padding:"12px 14px",transition:"border-color 0.15s ease, box-shadow 0.15s ease, outline-color 0.15s ease",resize:O||W?"none":"vertical",cursor:c?"not-allowed":"text",WebkitAppearance:"none",appearance:"none"}),void 0!==re&&O?{height:"".concat(re,"px")}:{}),w),he=e(r,{children:[t("style",{children:"\n .aha-textarea-wrapper textarea::placeholder {\n color: var(--color-text-placeholder);\n font-size: var(--font-size-text-md);\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea::-webkit-input-placeholder { color: var(--color-text-placeholder); }\n .aha-textarea-wrapper textarea::-moz-placeholder { color: var(--color-text-placeholder); }\n .aha-textarea-wrapper textarea:-ms-input-placeholder { color: var(--color-text-placeholder); }\n .aha-textarea-wrapper textarea {\n -webkit-tap-highlight-color: transparent;\n -webkit-touch-callout: none;\n touch-action: manipulation;\n }\n .aha-textarea-wrapper .aha-textarea-editable {\n white-space: pre-wrap;\n word-break: break-word;\n }\n .aha-textarea-wrapper .aha-textarea-editable:empty::before {\n content: attr(data-placeholder);\n color: var(--color-text-placeholder);\n }\n .aha-textarea-wrapper .aha-textarea-editable a {\n color: #2563EB;\n }\n "}),e("div",{className:"aha-textarea-wrapper ".concat(C),style:{position:"relative",display:"inline-flex",flexDirection:"column",width:"100%"},children:[W?t("div",{ref:V,className:"aha-textarea-editable",contentEditable:!c&&!v,suppressContentEditableWarning:!0,role:"textbox","aria-multiline":"true","aria-disabled":c,"data-placeholder":S||"",onInput:ue,onPaste:function(e){var t;if(e.preventDefault(),!v&&!c){var r,o,n=e.clipboardData.getData("text/plain"),a=String(ae||""),i=window.getSelection(),l="".concat(a).concat(n),d=a.length+n.length;if(i&&i.rangeCount>0&&(null===(t=V.current)||void 0===t?void 0:t.contains(i.anchorNode))){var s=P(V.current),u=(r=i.getRangeAt(0),(o=r.cloneRange()).selectNodeContents(V.current),o.setEnd(r.endContainer,r.endOffset),o.toString().length);l=a.slice(0,s)+n+a.slice(u),d=s+n.length}de&&(l=l.slice(0,de),d=Math.min(d,l.length)),$.current=d,ne||X(l),se(l)}},onKeyDown:function(e){var t,r;if("Enter"===e.key&&!e.nativeEvent.isComposing&&!c&&!v&&V.current){e.preventDefault();var o=String(ae||""),n=function(e){var t=window.getSelection();if(!t||0===t.rangeCount)return null;var r=t.getRangeAt(0);if(!e.contains(r.startContainer)||!e.contains(r.endContainer))return null;var o=r.cloneRange();o.selectNodeContents(e),o.setEnd(r.startContainer,r.startOffset);var n=r.cloneRange();return n.selectNodeContents(e),n.setEnd(r.endContainer,r.endOffset),{start:I(o.toString()).length,end:I(n.toString()).length}}(V.current),a=null!==(t=null==n?void 0:n.start)&&void 0!==t?t:o.length,i=null!==(r=null==n?void 0:n.end)&&void 0!==r?r:a,l="".concat(o.slice(0,a),"\n").concat(o.slice(i));de&&(l=l.slice(0,de));var d=Math.min(a+1,l.length);$.current=d,ne||X(l),se(l)}},onFocus:function(e){return le(e)},onBlur:function(e){return ce(e)},onCompositionStart:function(){Y.current=!0},onCompositionEnd:function(){Y.current=!1,ue()},style:p(p({},fe),{minHeight:O?void 0:"".concat(24*D+24,"px"),overflowY:O?"hidden":"auto"}),autoCorrect:Z.autoCorrect||"off",autoCapitalize:Z.autoCapitalize||"off",spellCheck:Z.spellCheck||!1}):t("textarea",p({ref:_,value:ae,placeholder:S,disabled:c,readOnly:v,rows:O?void 0:D,maxLength:m,onChange:function(e){ne||X(e.target.value),null==R||R(e)},onFocus:le,onBlur:ce,style:fe,autoComplete:Z.autoComplete||"off",autoCorrect:Z.autoCorrect||"off",autoCapitalize:Z.autoCapitalize||"off",spellCheck:Z.spellCheck||!1},Z)),(y||m)&&t("div",{style:{display:"flex",justifyContent:"flex-end",marginTop:"4px",fontSize:"var(--font-size-text-xs)",lineHeight:"var(--line-height-text-xs)",color:c?"var(--color-text-disabled)":"var(--color-text-tertiary)",fontFamily:"var(--font-family-body)"},children:m?e("span",{children:[ie," / ",m]}):t("span",{children:ie})})]})]});return T||G?e("div",{style:{display:"flex",flexDirection:"column",gap:"6px",width:"100%"},children:[T&&e("label",{style:{fontFamily:"var(--font-family-body)",fontSize:"var(--font-size-text-sm)",fontWeight:500,lineHeight:"20px",color:"var(--color-text-secondary)",display:"flex",alignItems:"center",gap:"2px"},children:[T,M&&t("span",{style:{color:"var(--color-error-600)",marginLeft:"2px"},children:"*"}),q&&t("span",{style:{marginLeft:"4px",display:"inline-flex",alignItems:"center",color:"var(--color-fg-quaternary)"},children:q})]}),he,G&&t("p",{style:{margin:0,fontFamily:"var(--font-family-body)",fontSize:"var(--font-size-text-sm)",fontWeight:400,lineHeight:"20px",color:g?"var(--color-error-600)":"var(--color-text-tertiary)"},children:G})]}):he});H.displayName="Textarea";export{k as TextareaTags,H as default,A as websiteValidator};
2
2
  //# sourceMappingURL=Textarea.esm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Textarea.esm.js","sources":["../node_modules/tslib/tslib.es6.js","../src/theme/ThemeContext.tsx","../src/components/Textarea/index.tsx"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","import React, { createContext, useContext, useMemo } from 'react';\n\nexport interface ThemeConfig {\n primaryColor?: string;\n}\n\nconst defaultTheme: ThemeConfig = {\n primaryColor: '#FB6011',\n};\n\nconst ThemeContext = createContext<ThemeConfig>(defaultTheme);\n\nexport interface ThemeProviderProps {\n theme?: ThemeConfig;\n children: React.ReactNode;\n}\n\nexport const ThemeProvider: React.FC<ThemeProviderProps> = ({ theme, children }) => {\n const themeValue = useMemo(() => {\n return {\n ...defaultTheme,\n ...theme,\n };\n }, [theme]);\n\n return (\n <ThemeContext.Provider value={themeValue}>\n {children}\n </ThemeContext.Provider>\n );\n};\n\nexport const useTheme = (): ThemeConfig => {\n const context = useContext(ThemeContext);\n if (!context) {\n // 如果没有 Provider,返回默认主题\n return defaultTheme;\n }\n return context;\n};\n\n// 导出默认主题色,供组件内部使用\nexport const getDefaultPrimaryColor = () => defaultTheme.primaryColor!;\n\n","import React, { forwardRef, useRef, useEffect, useMemo, useLayoutEffect } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\ninterface LinkifyOptions {\n validate?: (url: string) => boolean;\n className?: string;\n needProtocol?: boolean;\n needHost?: boolean;\n allowedTlds?: string[];\n}\n\nexport interface TextareaProps\n extends Omit<React.TextareaHTMLAttributes<HTMLTextAreaElement>, 'size'> {\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否显示错误状态 */\n error?: boolean;\n /** 是否只读 */\n readOnly?: boolean;\n /** 是否显示字符计数 */\n showCount?: boolean;\n /** 最大字符数 */\n maxLength?: number;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 占位符 */\n placeholder?: string;\n /** 值 */\n value?: string;\n /** 默认值 */\n defaultValue?: string;\n /** 行数 */\n rows?: number;\n /** 是否自动调整高度 */\n autoSize?: boolean | { minRows?: number; maxRows?: number };\n /** 变化回调 */\n onChange?: (e: React.ChangeEvent<HTMLTextAreaElement>) => void;\n /** 聚焦回调 */\n onFocus?: (e: React.FocusEvent<HTMLTextAreaElement>) => void;\n /** 失焦回调 */\n onBlur?: (e: React.FocusEvent<HTMLTextAreaElement>) => void;\n /** 是否启用实时链接识别 */\n linkify?: boolean;\n /** 链接识别配置 */\n linkifyOptions?: LinkifyOptions;\n}\n\ntype TextToken =\n | { type: 'text'; text: string }\n | { type: 'url'; text: string; href: string };\n\nconst DOMAIN_REGEX = /^(?:[a-zA-Z0-9-]+\\.)+[a-zA-Z]{2,}$/;\nconst URL_CANDIDATE_REGEX =\n /(https?:\\/\\/[^\\s<]+|www\\.[^\\s<]+|(?:[a-zA-Z0-9-]+\\.)+[a-zA-Z]{2,}(?:\\/[^\\s<]*)?)/gi;\nconst DEFAULT_ALLOWED_TLDS = new Set([\n 'com',\n 'cn',\n 'net',\n 'org',\n 'io',\n 'co',\n 'edu',\n 'gov',\n 'ai',\n 'app',\n 'dev',\n 'me',\n 'info',\n 'biz',\n 'tech',\n 'cc',\n 'tv',\n 'xyz',\n 'top',\n 'vip',\n 'pro',\n 'store',\n 'site',\n 'online',\n 'cloud',\n]);\n\nexport const websiteValidator = (\n url: string,\n needProtocol: boolean = true,\n needHost: boolean = true,\n allowedTlds?: string[]\n): boolean => {\n if (!url || typeof url !== 'string') return false;\n const trimmed = url.trim();\n if (!trimmed) return false;\n\n const hasProtocol = /^[a-zA-Z][a-zA-Z\\d+\\-.]*:\\/\\//.test(trimmed);\n if (needProtocol && !hasProtocol) return false;\n\n const normalized = hasProtocol ? trimmed : `https://${trimmed}`;\n\n try {\n const parsed = new URL(normalized);\n const protocol = parsed.protocol.toLowerCase();\n if (protocol !== 'http:' && protocol !== 'https:') return false;\n\n if (needHost) {\n const host = parsed.hostname.toLowerCase();\n if (!host) return false;\n if (host === 'localhost') return true;\n if (/^\\d{1,3}(\\.\\d{1,3}){3}$/.test(host)) {\n return host.split('.').every((segment) => {\n const num = Number(segment);\n return Number.isInteger(num) && num >= 0 && num <= 255;\n });\n }\n if (!DOMAIN_REGEX.test(host)) return false;\n const tld = host.split('.').pop() || '';\n const tldSet = allowedTlds\n ? new Set(allowedTlds.map((item) => item.toLowerCase()))\n : DEFAULT_ALLOWED_TLDS;\n if (!tldSet.has(tld)) return false;\n }\n return true;\n } catch {\n return false;\n }\n};\n\nconst trimTrailingPunctuation = (value: string): { core: string; suffix: string } => {\n const match = value.match(/^(.*?)([),.;!?]+)?$/);\n return {\n core: match?.[1] || value,\n suffix: match?.[2] || '',\n };\n};\n\nconst tokenizeText = (\n text: string,\n options?: LinkifyOptions\n): TextToken[] => {\n if (!text) return [];\n\n const tokens: TextToken[] = [];\n let lastIndex = 0;\n const regex = new RegExp(URL_CANDIDATE_REGEX);\n let match = regex.exec(text);\n\n while (match) {\n const matchedText = match[0];\n const start = match.index;\n const end = start + matchedText.length;\n\n if (start > lastIndex) {\n tokens.push({ type: 'text', text: text.slice(lastIndex, start) });\n }\n\n const { core, suffix } = trimTrailingPunctuation(matchedText);\n const href = /^[a-zA-Z][a-zA-Z\\d+\\-.]*:\\/\\//.test(core)\n ? core\n : `https://${core}`;\n const defaultIsValid = websiteValidator(\n core,\n options?.needProtocol ?? false,\n options?.needHost ?? true,\n options?.allowedTlds\n );\n const isValid = options?.validate ? options.validate(href) : defaultIsValid;\n\n if (isValid && core) {\n tokens.push({ type: 'url', text: core, href });\n if (suffix) {\n tokens.push({ type: 'text', text: suffix });\n }\n } else {\n tokens.push({ type: 'text', text: matchedText });\n }\n\n lastIndex = end;\n match = regex.exec(text);\n }\n\n if (lastIndex < text.length) {\n tokens.push({ type: 'text', text: text.slice(lastIndex) });\n }\n\n return tokens;\n};\n\nconst escapeHtml = (value: string): string =>\n value\n .replace(/&/g, '&amp;')\n .replace(/</g, '&lt;')\n .replace(/>/g, '&gt;')\n .replace(/\"/g, '&quot;')\n .replace(/'/g, '&#39;');\n\nconst ZWSP = '\\u200B';\nconst stripEditorArtifacts = (value: string): string =>\n value.replace(new RegExp(ZWSP, 'g'), '');\n\nconst renderTokensAsHtml = (\n text: string,\n options?: LinkifyOptions,\n disabled?: boolean\n): string => {\n const tokens = tokenizeText(text, options);\n if (tokens.length === 0) return '';\n\n const html = tokens\n .map((token) => {\n if (token.type === 'text') {\n return escapeHtml(token.text);\n }\n\n const classAttr = options?.className ? ` class=\"${options.className}\"` : '';\n const pointerEvents = disabled ? 'pointer-events: none;' : '';\n return `<a href=\"${escapeHtml(token.href)}\" target=\"_blank\" rel=\"noopener noreferrer\"${classAttr} style=\"color: #2563EB; text-decoration: underline; ${pointerEvents}\">${escapeHtml(token.text)}</a>`;\n })\n .join('');\n\n // contentEditable 在末尾是换行时可能吞掉视觉换行,补一个零宽字符占位\n if (text.endsWith('\\n')) {\n return `${html}<span data-aha-zwsp=\"true\">${ZWSP}</span>`;\n }\n return html;\n};\n\nconst getCaretOffset = (container: HTMLElement): number => {\n const selection = window.getSelection();\n if (!selection || selection.rangeCount === 0) return 0;\n\n const range = selection.getRangeAt(0);\n if (!container.contains(range.startContainer)) return 0;\n\n const preRange = range.cloneRange();\n preRange.selectNodeContents(container);\n preRange.setEnd(range.startContainer, range.startOffset);\n return stripEditorArtifacts(preRange.toString()).length;\n};\n\nconst setCaretOffset = (container: HTMLElement, offset: number): void => {\n const range = document.createRange();\n const selection = window.getSelection();\n if (!selection) return;\n\n let remaining = Math.max(0, offset);\n const walker = document.createTreeWalker(container, NodeFilter.SHOW_TEXT);\n let currentNode = walker.nextNode();\n\n while (currentNode) {\n const rawText = currentNode.textContent || '';\n let visibleCount = 0;\n let targetOffsetInNode = -1;\n for (let i = 0; i < rawText.length; i += 1) {\n if (rawText[i] !== ZWSP) {\n visibleCount += 1;\n }\n if (visibleCount === remaining) {\n targetOffsetInNode = i + 1;\n break;\n }\n }\n\n if (remaining === 0) {\n range.setStart(currentNode, 0);\n range.collapse(true);\n selection.removeAllRanges();\n selection.addRange(range);\n return;\n }\n\n if (targetOffsetInNode !== -1) {\n range.setStart(currentNode, targetOffsetInNode);\n range.collapse(true);\n selection.removeAllRanges();\n selection.addRange(range);\n return;\n }\n\n remaining -= visibleCount;\n currentNode = walker.nextNode();\n }\n\n range.selectNodeContents(container);\n range.collapse(false);\n selection.removeAllRanges();\n selection.addRange(range);\n};\n\nconst getSelectionOffsets = (\n container: HTMLElement\n): { start: number; end: number } | null => {\n const selection = window.getSelection();\n if (!selection || selection.rangeCount === 0) return null;\n const range = selection.getRangeAt(0);\n if (!container.contains(range.startContainer) || !container.contains(range.endContainer)) {\n return null;\n }\n\n const startRange = range.cloneRange();\n startRange.selectNodeContents(container);\n startRange.setEnd(range.startContainer, range.startOffset);\n\n const endRange = range.cloneRange();\n endRange.selectNodeContents(container);\n endRange.setEnd(range.endContainer, range.endOffset);\n\n return {\n start: stripEditorArtifacts(startRange.toString()).length,\n end: stripEditorArtifacts(endRange.toString()).length,\n };\n};\n\nconst Textarea = forwardRef<HTMLTextAreaElement, TextareaProps>(\n (\n {\n disabled = false,\n error = false,\n readOnly = false,\n showCount = false,\n maxLength,\n className = '',\n style,\n placeholder,\n value,\n defaultValue,\n rows = 3,\n autoSize = false,\n onChange,\n onFocus,\n onBlur,\n linkify = false,\n linkifyOptions,\n ...restProps\n },\n ref\n ) => {\n const { primaryColor = '#FB6011' } = useTheme();\n const textareaRef = useRef<HTMLTextAreaElement>(null);\n const editableRef = useRef<HTMLDivElement>(null);\n const isComposingRef = useRef(false);\n const caretOffsetRef = useRef<number | null>(null);\n const [internalValue, setInternalValue] = React.useState(\n defaultValue || value || ''\n );\n const [focused, setFocused] = React.useState(false);\n const [height, setHeight] = React.useState<number | undefined>(undefined);\n\n // 合并 ref(仅原生 textarea 模式)\n useEffect(() => {\n if (typeof ref === 'function') {\n ref(linkify ? null : textareaRef.current);\n } else if (ref) {\n (ref as React.MutableRefObject<HTMLTextAreaElement | null>).current =\n linkify ? null : textareaRef.current;\n }\n }, [ref, linkify]);\n\n // 受控/非受控处理\n const isControlled = value !== undefined;\n const currentValue = isControlled ? value : internalValue;\n const currentLength = String(currentValue || '').length;\n\n const handleChange = (e: React.ChangeEvent<HTMLTextAreaElement>) => {\n if (!isControlled) {\n setInternalValue(e.target.value);\n }\n onChange?.(e);\n };\n\n const handleFocus = (e: React.FocusEvent<HTMLTextAreaElement>) => {\n setFocused(true);\n onFocus?.(e);\n };\n\n const handleBlur = (e: React.FocusEvent<HTMLTextAreaElement>) => {\n setFocused(false);\n onBlur?.(e);\n };\n\n const getMaxLengthValue = useMemo(\n () => (typeof maxLength === 'number' ? maxLength : undefined),\n [maxLength]\n );\n\n // 自动调整高度(原生 textarea)\n useEffect(() => {\n if (!linkify && autoSize && textareaRef.current) {\n const textarea = textareaRef.current;\n const minRows =\n typeof autoSize === 'object' ? autoSize.minRows || 1 : 1;\n const maxRows =\n typeof autoSize === 'object' ? autoSize.maxRows : undefined;\n\n // 重置高度以获取正确的 scrollHeight\n textarea.style.height = 'auto';\n const scrollHeight = textarea.scrollHeight;\n\n // 计算行高(假设每行约 22px,根据字体大小调整)\n const lineHeight = parseInt(\n window.getComputedStyle(textarea).lineHeight || '22',\n 10\n );\n const minHeight = minRows * lineHeight;\n const maxHeight = maxRows ? maxRows * lineHeight : undefined;\n\n let newHeight = Math.max(scrollHeight, minHeight);\n if (maxHeight) {\n newHeight = Math.min(newHeight, maxHeight);\n }\n\n textarea.style.height = `${newHeight}px`;\n setHeight(newHeight);\n }\n }, [currentValue, autoSize, linkify]);\n\n // 自动调整高度(linkify + contentEditable)\n useEffect(() => {\n if (!linkify || !autoSize || !editableRef.current) return;\n const editable = editableRef.current;\n const minRows = typeof autoSize === 'object' ? autoSize.minRows || 1 : 1;\n const maxRows = typeof autoSize === 'object' ? autoSize.maxRows : undefined;\n\n const lineHeight = parseInt(\n window.getComputedStyle(editable).lineHeight || '24',\n 10\n );\n const minHeight = minRows * lineHeight + 24;\n const maxHeight = maxRows ? maxRows * lineHeight + 24 : undefined;\n\n editable.style.height = 'auto';\n let newHeight = Math.max(editable.scrollHeight, minHeight);\n if (maxHeight) {\n newHeight = Math.min(newHeight, maxHeight);\n }\n editable.style.height = `${newHeight}px`;\n editable.style.overflowY = maxHeight && editable.scrollHeight > maxHeight ? 'auto' : 'hidden';\n setHeight(newHeight);\n }, [autoSize, currentValue, linkify]);\n\n useLayoutEffect(() => {\n if (!linkify || !editableRef.current || isComposingRef.current) return;\n const editable = editableRef.current;\n const isActive = document.activeElement === editable;\n const fallbackOffset = isActive ? getCaretOffset(editable) : 0;\n const caretOffset = caretOffsetRef.current ?? fallbackOffset;\n const nextHtml = renderTokensAsHtml(\n String(currentValue || ''),\n linkifyOptions,\n disabled\n );\n\n if (editable.innerHTML !== nextHtml) {\n editable.innerHTML = nextHtml;\n }\n\n if (isActive) {\n const maxOffset = String(currentValue || '').length;\n setCaretOffset(editable, Math.min(caretOffset, maxOffset));\n }\n caretOffsetRef.current = null;\n }, [currentValue, disabled, linkify, linkifyOptions]);\n\n const notifyChange = (nextValue: string) => {\n const syntheticEvent = {\n target: { value: nextValue },\n currentTarget: { value: nextValue },\n } as React.ChangeEvent<HTMLTextAreaElement>;\n onChange?.(syntheticEvent);\n };\n\n const handleEditableInput = () => {\n if (!editableRef.current || isComposingRef.current) return;\n caretOffsetRef.current = getCaretOffset(editableRef.current);\n const rawValue = stripEditorArtifacts(editableRef.current.textContent || '');\n const nextValue = getMaxLengthValue ? rawValue.slice(0, getMaxLengthValue) : rawValue;\n\n if (!isControlled) {\n setInternalValue(nextValue);\n }\n notifyChange(nextValue);\n };\n\n const handleEditablePaste = (e: React.ClipboardEvent<HTMLDivElement>) => {\n e.preventDefault();\n if (readOnly || disabled) return;\n\n const pastedText = e.clipboardData.getData('text/plain');\n const currentText = String(currentValue || '');\n const selection = window.getSelection();\n let nextText = `${currentText}${pastedText}`;\n let caretOffset = currentText.length + pastedText.length;\n\n if (\n selection &&\n selection.rangeCount > 0 &&\n editableRef.current?.contains(selection.anchorNode)\n ) {\n const startOffset = getCaretOffset(editableRef.current);\n const endOffset = (() => {\n const range = selection.getRangeAt(0);\n const preRange = range.cloneRange();\n preRange.selectNodeContents(editableRef.current);\n preRange.setEnd(range.endContainer, range.endOffset);\n return preRange.toString().length;\n })();\n nextText =\n currentText.slice(0, startOffset) +\n pastedText +\n currentText.slice(endOffset);\n caretOffset = startOffset + pastedText.length;\n }\n\n if (getMaxLengthValue) {\n nextText = nextText.slice(0, getMaxLengthValue);\n caretOffset = Math.min(caretOffset, nextText.length);\n }\n caretOffsetRef.current = caretOffset;\n\n if (!isControlled) {\n setInternalValue(nextText);\n }\n notifyChange(nextText);\n };\n\n const handleEditableKeyDown = (e: React.KeyboardEvent<HTMLDivElement>) => {\n if (e.key !== 'Enter' || e.nativeEvent.isComposing) return;\n if (disabled || readOnly) return;\n if (!editableRef.current) return;\n\n e.preventDefault();\n const currentText = String(currentValue || '');\n const offsets = getSelectionOffsets(editableRef.current);\n const start = offsets?.start ?? currentText.length;\n const end = offsets?.end ?? start;\n\n let nextText = `${currentText.slice(0, start)}\\n${currentText.slice(end)}`;\n if (getMaxLengthValue) {\n nextText = nextText.slice(0, getMaxLengthValue);\n }\n\n const nextCaret = Math.min(start + 1, nextText.length);\n caretOffsetRef.current = nextCaret;\n\n if (!isControlled) {\n setInternalValue(nextText);\n }\n notifyChange(nextText);\n };\n\n const baseStyles: React.CSSProperties = {\n width: '100%',\n boxSizing: 'border-box',\n fontFamily: \"DM Sans, sans-serif\",\n borderRadius: '8px', // rounded-md\n border: `1px solid ${error ? '#F04438' : focused ? primaryColor : '#D7D3D0'}`,\n backgroundColor: disabled ? '#FAFAF9' : readOnly ? '#FAFAF9' : '#FFFFFF',\n color: disabled ? '#98A2B3' : '#1C1917',\n fontSize: '16px', // text-base - 至少 16px 避免 iOS Safari 自动缩放\n fontWeight: 400,\n lineHeight: '24px',\n padding: '12px 14px', // 上下 12px,左右 14px\n boxShadow: '0 1px 2px rgba(10, 13, 18, 0.05)', // #0A0D120D 5%\n transition: 'all 0.2s',\n outline: 'none',\n resize: autoSize || linkify ? 'none' : 'vertical',\n cursor: disabled ? 'not-allowed' : 'text',\n WebkitAppearance: 'none', // 移除 iOS Safari 默认样式\n appearance: 'none',\n ...(height !== undefined && autoSize ? { height: `${height}px` } : {}),\n ...style,\n };\n\n // 占位符样式通过 CSS 类名处理\n const placeholderStyles = `\n .aha-textarea-wrapper textarea::placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea::-webkit-input-placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea::-moz-placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea:-ms-input-placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n /* 移动端优化 */\n .aha-textarea-wrapper textarea {\n -webkit-tap-highlight-color: transparent;\n -webkit-touch-callout: none;\n touch-action: manipulation;\n }\n .aha-textarea-wrapper .aha-textarea-editable {\n white-space: pre-wrap;\n word-break: break-word;\n }\n .aha-textarea-wrapper .aha-textarea-editable:empty::before {\n content: attr(data-placeholder);\n color: #79716B;\n }\n .aha-textarea-wrapper .aha-textarea-editable a {\n color: #2563EB;\n }\n `;\n\n return (\n <>\n <style>{placeholderStyles}</style>\n <div\n className={`aha-textarea-wrapper ${className}`}\n style={{\n position: 'relative',\n display: 'inline-flex',\n flexDirection: 'column',\n width: '100%',\n }}\n >\n {linkify ? (\n <div\n ref={editableRef}\n className=\"aha-textarea-editable\"\n contentEditable={!disabled && !readOnly}\n suppressContentEditableWarning\n role=\"textbox\"\n aria-multiline=\"true\"\n aria-disabled={disabled}\n data-placeholder={placeholder || ''}\n onInput={handleEditableInput}\n onPaste={handleEditablePaste}\n onKeyDown={handleEditableKeyDown}\n onFocus={(e) => handleFocus(e as unknown as React.FocusEvent<HTMLTextAreaElement>)}\n onBlur={(e) => handleBlur(e as unknown as React.FocusEvent<HTMLTextAreaElement>)}\n onCompositionStart={() => {\n isComposingRef.current = true;\n }}\n onCompositionEnd={() => {\n isComposingRef.current = false;\n handleEditableInput();\n }}\n style={{\n ...baseStyles,\n minHeight: autoSize ? undefined : `${rows * 24 + 24}px`,\n overflowY: autoSize ? 'hidden' : 'auto',\n }}\n autoCorrect={restProps.autoCorrect || 'off'}\n autoCapitalize={restProps.autoCapitalize || 'off'}\n spellCheck={restProps.spellCheck || false}\n />\n ) : (\n <textarea\n ref={textareaRef}\n value={currentValue}\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readOnly}\n rows={autoSize ? undefined : rows}\n maxLength={maxLength}\n onChange={handleChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n style={baseStyles}\n autoComplete={restProps.autoComplete || 'off'}\n autoCorrect={restProps.autoCorrect || 'off'}\n autoCapitalize={restProps.autoCapitalize || 'off'}\n spellCheck={restProps.spellCheck || false}\n {...restProps}\n />\n )}\n {(showCount || maxLength) && (\n <div\n style={{\n display: 'flex',\n justifyContent: 'flex-end',\n marginTop: '4px',\n fontSize: '12px',\n lineHeight: '18px',\n color: disabled ? '#98A2B3' : '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n {maxLength ? (\n <span>\n {currentLength} / {maxLength}\n </span>\n ) : (\n <span>{currentLength}</span>\n )}\n </div>\n )}\n </div>\n </>\n );\n }\n);\n\nTextarea.displayName = 'Textarea';\n\nexport default Textarea;\n\n"],"names":["__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","this","SuppressedError","defaultTheme","primaryColor","ThemeContext","createContext","DOMAIN_REGEX","URL_CANDIDATE_REGEX","DEFAULT_ALLOWED_TLDS","Set","websiteValidator","url","needProtocol","needHost","allowedTlds","trimmed","trim","hasProtocol","test","normalized","concat","parsed","URL","protocol","toLowerCase","host","hostname","split","every","segment","num","Number","isInteger","tld","pop","map","item","has","_a","trimTrailingPunctuation","value","match","core","suffix","escapeHtml","replace","stripEditorArtifacts","RegExp","renderTokensAsHtml","text","options","disabled","tokens","lastIndex","regex","exec","matchedText","start","index","end","push","type","slice","_c","href","defaultIsValid","_b","validate","tokenizeText","html","token","classAttr","className","pointerEvents","join","endsWith","getCaretOffset","container","selection","window","getSelection","rangeCount","range","getRangeAt","contains","startContainer","preRange","cloneRange","selectNodeContents","setEnd","startOffset","toString","Textarea","forwardRef","ref","error","_d","readOnly","_e","showCount","maxLength","_f","style","placeholder","defaultValue","_g","rows","_h","autoSize","onChange","onFocus","onBlur","_j","linkify","linkifyOptions","restProps","e","indexOf","getOwnPropertySymbols","propertyIsEnumerable","__rest","_k","useContext","textareaRef","useRef","editableRef","isComposingRef","caretOffsetRef","_l","React","useState","internalValue","setInternalValue","_m","focused","setFocused","_o","undefined","height","setHeight","useEffect","current","isControlled","currentValue","currentLength","String","handleFocus","handleBlur","getMaxLengthValue","useMemo","textarea","minRows","maxRows","scrollHeight","lineHeight","parseInt","getComputedStyle","minHeight","maxHeight","newHeight","Math","max","min","editable","overflowY","useLayoutEffect","isActive","document","activeElement","fallbackOffset","caretOffset","nextHtml","innerHTML","maxOffset","offset","createRange","remaining","walker","createTreeWalker","NodeFilter","SHOW_TEXT","currentNode","nextNode","rawText","textContent","visibleCount","targetOffsetInNode","setStart","collapse","removeAllRanges","addRange","setCaretOffset","notifyChange","nextValue","target","currentTarget","handleEditableInput","rawValue","baseStyles","width","boxSizing","fontFamily","borderRadius","border","backgroundColor","color","fontSize","fontWeight","padding","boxShadow","transition","outline","resize","cursor","WebkitAppearance","appearance","_jsxs","_Fragment","children","_jsx","position","display","flexDirection","contentEditable","suppressContentEditableWarning","role","onInput","onPaste","preventDefault","pastedText","clipboardData","getData","currentText","nextText","anchorNode","endOffset","endContainer","onKeyDown","key","nativeEvent","isComposing","offsets","startRange","endRange","getSelectionOffsets","nextCaret","onCompositionStart","onCompositionEnd","autoCorrect","autoCapitalize","spellCheck","autoComplete","justifyContent","marginTop","displayName"],"mappings":"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","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"Textarea.esm.js","sources":["../node_modules/tslib/tslib.es6.js","../src/theme/ThemeContext.tsx","../src/components/Tag/index.tsx","../src/components/Input/InputTags.tsx","../src/components/Textarea/TextareaTags.tsx","../src/components/Textarea/index.tsx"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","import React, { createContext, useContext, useMemo } from 'react';\n\nexport interface ThemeConfig {\n primaryColor?: string;\n}\n\nconst defaultTheme: ThemeConfig = {\n primaryColor: '#FB6011',\n};\n\nconst ThemeContext = createContext<ThemeConfig>(defaultTheme);\n\nexport interface ThemeProviderProps {\n theme?: ThemeConfig;\n children: React.ReactNode;\n}\n\nexport const ThemeProvider: React.FC<ThemeProviderProps> = ({ theme, children }) => {\n const themeValue = useMemo(() => {\n return {\n ...defaultTheme,\n ...theme,\n };\n }, [theme]);\n\n return (\n <ThemeContext.Provider value={themeValue}>\n {children}\n </ThemeContext.Provider>\n );\n};\n\nexport const useTheme = (): ThemeConfig => {\n const context = useContext(ThemeContext);\n if (!context) {\n // 如果没有 Provider,返回默认主题\n return defaultTheme;\n }\n return context;\n};\n\n// 导出默认主题色,供组件内部使用\nexport const getDefaultPrimaryColor = () => defaultTheme.primaryColor!;\n\n","import React, { SVGProps, useState } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\n// ─── Types ────────────────────────────────────────────────────────────────────\n\nexport type TagColor =\n | 'Green' | 'Red' | 'Orange' | 'Cyan' | 'Violet'\n | 'Pink' | 'Gray' | 'Yellow' | 'Blue' | string;\n\nexport type TagVariant = 'light' | 'fill';\n\n/** sm/md/lg are the canonical sizes; large/small are legacy aliases */\nexport type TagSize = 'sm' | 'md' | 'lg' | 'large' | 'small';\n\n/** Leading icon variant */\nexport type TagIconType = 'none' | 'dot' | 'avatar' | 'icon';\n\n/** Right-side action */\nexport type TagAction = 'none' | 'x-close' | 'count';\n\n/** @deprecated Use iconType instead */\nexport type IconPosition = 'leading' | 'after' | 'none';\n\nexport interface TagProps {\n children: React.ReactNode;\n color?: TagColor;\n variant?: TagVariant;\n size?: TagSize;\n stroke?: boolean;\n // Icon variants (mutually exclusive; avatar takes precedence over icon)\n iconType?: TagIconType;\n icon?: React.ReactElement;\n avatarSrc?: string;\n dotColor?: string;\n // Action variants\n action?: TagAction;\n count?: number;\n onClose?: () => void;\n // Checkbox variant\n checkbox?: boolean;\n checked?: boolean;\n onCheckedChange?: (checked: boolean) => void;\n /** @deprecated use iconType='icon' */\n iconPosition?: IconPosition;\n className?: string;\n onClick?: () => void;\n [key: string]: any;\n}\n\n// ─── Color Configs ────────────────────────────────────────────────────────────\n\nconst COLOR_CONFIG = {\n Green: { light: { bg: '#ECFDF5', text: '#006045', border: '#A4F4CF' }, fill: { bg: '#00BC7D', text: '#FFFFFF' } },\n Red: { light: { bg: '#FEF2F2', text: '#9F0712', border: '#FFC9C9' }, fill: { bg: '#FB2C36', text: '#FFFFFF' } },\n Orange: { light: { bg: '#FFF6ED', text: '#9B2911', border: '#FFD1A9' }, fill: { bg: '#FB6011', text: '#FFFFFF' } },\n Cyan: { light: { bg: '#ECFEFF', text: '#005F78', border: '#A2F4FD' }, fill: { bg: '#00B8DB', text: '#FFFFFF' } },\n Violet: { light: { bg: '#F5F3FF', text: '#5D0EC0', border: '#DDD6FF' }, fill: { bg: '#8E51FF', text: '#FFFFFF' } },\n Pink: { light: { bg: '#FDF2F8', text: '#A3004C', border: '#FCCEE8' }, fill: { bg: '#F6339A', text: '#FFFFFF' } },\n Gray: { light: { bg: '#F5F5F4', text: '#292524', border: '#E7E5E4' }, fill: { bg: '#292524', text: '#FFFFFF' } },\n Yellow: { light: { bg: '#FFFBEB', text: '#973C00', border: '#FEE685' }, fill: { bg: '#FE9A00', text: '#FFFFFF' } },\n Blue: { light: { bg: '#EFF6FF', text: '#193CB8', border: '#BEDBFF' }, fill: { bg: '#2B7FFF', text: '#FFFFFF' } },\n};\n\nconst getColorConfig = (color: TagColor, primaryColor?: string) => {\n if (color in COLOR_CONFIG) {\n const config = COLOR_CONFIG[color as keyof typeof COLOR_CONFIG];\n if (color === 'Orange' && primaryColor) {\n return { ...config, fill: { ...config.fill, bg: primaryColor } };\n }\n return config;\n }\n if (color.startsWith('#')) {\n const r = parseInt(color.slice(1, 3), 16);\n const g = parseInt(color.slice(3, 5), 16);\n const b = parseInt(color.slice(5, 7), 16);\n return {\n light: { bg: `rgba(${r},${g},${b},0.1)`, text: color, border: `rgba(${r},${g},${b},0.3)` },\n fill: { bg: color, text: '#FFFFFF' },\n };\n }\n return COLOR_CONFIG.Gray;\n};\n\nconst getIconColor = (color: TagColor, primaryColor?: string): string => {\n const map: Record<string, string> = {\n Green: '#009966', Red: '#E7000B', Orange: primaryColor || '#E17100',\n Blue: '#155DFC', Yellow: '#EC470A', Cyan: '#0092B8',\n Violet: '#7F22FE', Pink: '#E60076', Gray: '#57534D',\n };\n return map[color] ?? (color.startsWith('#') ? color : '#57534D');\n};\n\nconst getOutlineColor = (color: TagColor): string => {\n const map: Record<string, string> = {\n Green: '#A4F4CF', Red: '#FFC9C9', Orange: '#FFD1A9',\n Blue: '#BEDBFF', Yellow: '#FFD1A9', Cyan: '#A2F4FD',\n Violet: '#DDD6FF', Pink: '#FCCEE8', Gray: '#E7E5E4',\n };\n if (color in map) return map[color];\n if (color.startsWith('#')) {\n const r = parseInt(color.slice(1, 3), 16);\n const g = parseInt(color.slice(3, 5), 16);\n const b = parseInt(color.slice(5, 7), 16);\n return `rgba(${r},${g},${b},0.3)`;\n }\n return '#E7E5E4';\n};\n\n// ─── Size Config ──────────────────────────────────────────────────────────────\n// Values derived from Figma design (node 3307:417515)\n\ntype NSize = 'sm' | 'md' | 'lg';\n\nconst normalizeSize = (size: TagSize): NSize => {\n if (size === 'large') return 'lg';\n if (size === 'small') return 'sm';\n return size as NSize;\n};\n\nconst SIZE = {\n sm: {\n // Base padding: px-8px py-3px (h=24px with lh-18px)\n basePx: 8, basePy: 3,\n // Left padding adjustments per leading element (checkbox wins over icon)\n plCheckbox: 5, plAvatar: 4, plDot: 6, plIcon: 4,\n // Right padding adjustments per action\n prClose: 4, prCount: 4,\n fontSize: 12, lineHeight: '18px', height: 24,\n avatarSize: 16, checkboxSize: 14,\n contentGap: 4, rootGap: 3,\n countPx: 4, countFontSize: 12,\n closeSize: 10, closePad: 2,\n },\n md: {\n // Base padding: px-9px py-2px (h=24px with lh-20px)\n basePx: 9, basePy: 2,\n plCheckbox: 4, plAvatar: 5, plDot: 7, plIcon: 5,\n prClose: 4, prCount: 3,\n fontSize: 14, lineHeight: '20px', height: 24,\n avatarSize: 16, checkboxSize: 16,\n contentGap: 5, rootGap: 4,\n countPx: 5, countFontSize: 12,\n closeSize: 12, closePad: 2,\n },\n lg: {\n // Base padding: px-10px py-4px (h=28px with lh-20px)\n basePx: 10, basePy: 4,\n plCheckbox: 5, plAvatar: 7, plDot: 9, plIcon: 7,\n prClose: 4, prCount: 4,\n fontSize: 14, lineHeight: '20px', height: 28,\n avatarSize: 18, checkboxSize: 18,\n contentGap: 6, rootGap: 4,\n countPx: 6, countFontSize: 14,\n closeSize: 14, closePad: 3,\n },\n} as const;\n\n// ─── TagAvatar ────────────────────────────────────────────────────────────────\n\nexport interface TagAvatarProps {\n src?: string;\n alt?: string;\n size?: number;\n}\n\nexport const TagAvatar: React.FC<TagAvatarProps> = ({ src, alt = 'Avatar', size = 16 }) => {\n const [failed, setFailed] = useState(false);\n return (\n <div\n style={{\n width: size, height: size, borderRadius: '50%',\n overflow: 'hidden', flexShrink: 0,\n border: '0.667px solid rgba(0,0,0,0.08)',\n background: '#e5e5e4',\n display: 'flex', alignItems: 'center', justifyContent: 'center',\n }}\n >\n {src && !failed ? (\n <img\n src={src} alt={alt}\n onError={() => setFailed(true)}\n style={{ width: '100%', height: '100%', objectFit: 'cover', display: 'block' }}\n />\n ) : (\n <svg\n width={size * 0.625} height={size * 0.625}\n viewBox=\"0 0 10 10\" fill=\"none\"\n >\n <circle cx=\"5\" cy=\"3.5\" r=\"2\" stroke=\"#999\" strokeWidth=\"1.2\" />\n <path d=\"M1 9.5c0-2.2 1.8-4 4-4s4 1.8 4 4\" stroke=\"#999\" strokeWidth=\"1.2\" strokeLinecap=\"round\" />\n </svg>\n )}\n </div>\n );\n};\n\n// ─── Tag ──────────────────────────────────────────────────────────────────────\n\nconst Tag: React.FC<TagProps> = ({\n children,\n color,\n variant = 'light',\n size = 'md',\n stroke = false,\n iconType: iconTypeProp,\n icon,\n avatarSrc,\n dotColor,\n action = 'none',\n count,\n onClose,\n checkbox = false,\n checked: checkedProp,\n onCheckedChange,\n iconPosition,\n className = '',\n onClick,\n ...rest\n}) => {\n const { primaryColor } = useTheme();\n const [internalChecked, setInternalChecked] = useState(false);\n\n const nSize = normalizeSize(size);\n const s = SIZE[nSize];\n\n // Controlled/uncontrolled checkbox\n const isChecked = checkedProp !== undefined ? checkedProp : internalChecked;\n const handleCheckboxToggle = (e: React.MouseEvent) => {\n e.stopPropagation();\n const next = !isChecked;\n if (checkedProp === undefined) setInternalChecked(next);\n onCheckedChange?.(next);\n };\n\n // Resolve icon type; backward-compat: legacy iconPosition='leading' → iconType='icon'\n const iconType: TagIconType =\n iconTypeProp ??\n (icon && iconPosition === 'leading' ? 'icon' : 'none');\n\n const hasLeading = iconType !== 'none';\n const effectiveAction = action !== 'none' ? action : undefined;\n\n // Compute left padding (checkbox wins > dot > avatar/icon > base)\n const pl = checkbox ? s.plCheckbox\n : iconType === 'dot' ? s.plDot\n : iconType === 'avatar' || iconType === 'icon' ? s.plAvatar\n : s.basePx;\n\n // Compute right padding\n const pr = effectiveAction === 'x-close' ? s.prClose\n : effectiveAction === 'count' ? s.prCount\n : s.basePx;\n\n // Base neutral style matching Figma (white bg + gray border)\n const containerStyle: React.CSSProperties = {\n display: 'inline-flex',\n alignItems: 'center',\n gap: effectiveAction === 'x-close' ? s.rootGap : 0,\n paddingLeft: pl,\n paddingRight: pr,\n paddingTop: s.basePy,\n paddingBottom: s.basePy,\n height: s.height,\n borderRadius: 6,\n fontFamily: 'DM Sans, sans-serif',\n fontWeight: 500,\n fontSize: s.fontSize,\n lineHeight: s.lineHeight,\n transition: 'all 0.2s',\n cursor: onClick ? 'pointer' : 'default',\n boxSizing: 'border-box',\n backgroundColor: '#ffffff',\n color: '#44403c',\n // Inset outline matches Figma: outline-1 outline-offset-[-1px]\n outline: '1px solid #d7d3d0',\n outlineOffset: '-1px',\n };\n\n // Optional color override (keeps backward compat with color prop)\n if (color) {\n const colorConfig = getColorConfig(color, primaryColor);\n if (variant === 'light') {\n containerStyle.backgroundColor = colorConfig.light.bg;\n containerStyle.color = colorConfig.light.text;\n containerStyle.outline = stroke ? `1px solid ${getOutlineColor(color)}` : 'none';\n containerStyle.outlineOffset = stroke ? '-1px' : undefined;\n } else {\n containerStyle.backgroundColor = colorConfig.fill.bg;\n containerStyle.color = colorConfig.fill.text;\n containerStyle.outline = 'none';\n }\n }\n\n if (onClick) {\n containerStyle.cursor = 'pointer';\n }\n\n // Leading icon element\n const renderLeadingIcon = () => {\n if (iconType === 'avatar') {\n return <TagAvatar src={avatarSrc} size={s.avatarSize} />;\n }\n if (iconType === 'dot') {\n return (\n <svg width={8} height={8} viewBox=\"0 0 8 8\" fill=\"none\" style={{ flexShrink: 0 }}>\n <circle cx={4} cy={4} r={3.5} fill={dotColor || 'currentColor'} />\n </svg>\n );\n }\n if (iconType === 'icon' && icon) {\n return (\n <span style={{ display: 'flex', alignItems: 'center', flexShrink: 0 }}>\n {React.cloneElement(icon as React.ReactElement<SVGProps<SVGSVGElement>>, {\n width: s.avatarSize,\n height: s.avatarSize,\n })}\n </span>\n );\n }\n return null;\n };\n\n return (\n <div\n className={className}\n style={containerStyle}\n onClick={onClick}\n {...rest}\n >\n {/* Content row: checkbox + icon + text + count */}\n <div style={{ display: 'flex', alignItems: 'center', gap: s.contentGap, flexShrink: 0 }}>\n {/* Checkbox */}\n {checkbox && (\n <div\n role=\"checkbox\"\n aria-checked={isChecked}\n onClick={handleCheckboxToggle}\n style={{\n width: s.checkboxSize, height: s.checkboxSize,\n borderRadius: 4, flexShrink: 0,\n border: isChecked ? 'none' : '1px solid #d7d3d0',\n background: isChecked ? (primaryColor || '#7F56D9') : '#ffffff',\n display: 'flex', alignItems: 'center', justifyContent: 'center',\n cursor: 'pointer',\n }}\n >\n {isChecked && (\n <svg\n width={Math.round(s.checkboxSize * 0.65)}\n height={Math.round(s.checkboxSize * 0.65)}\n viewBox=\"0 0 10 10\" fill=\"none\"\n >\n <path d=\"M8.5 2L4 7.5 1.5 5\" stroke=\"#fff\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" />\n </svg>\n )}\n </div>\n )}\n\n {/* Leading icon (avatar / dot / generic icon) */}\n {renderLeadingIcon()}\n\n {/* Text label */}\n <span style={{ whiteSpace: 'nowrap' }}>{children}</span>\n\n {/* Count badge */}\n {effectiveAction === 'count' && typeof count === 'number' && (\n <span style={{\n display: 'flex', alignItems: 'center', justifyContent: 'center',\n paddingLeft: s.countPx, paddingRight: s.countPx,\n paddingTop: 1, paddingBottom: 1,\n background: 'rgba(0,0,0,0.07)',\n borderRadius: 3,\n fontSize: s.countFontSize,\n fontWeight: 500,\n lineHeight: '16px',\n flexShrink: 0,\n }}>\n {count}\n </span>\n )}\n </div>\n\n {/* Close X (outside content row, right side) */}\n {effectiveAction === 'x-close' && (\n <button\n aria-label=\"Remove\"\n onClick={(e) => { e.stopPropagation(); onClose?.(); }}\n style={{\n display: 'flex', alignItems: 'center', justifyContent: 'center',\n padding: s.closePad, borderRadius: 3,\n border: 'none', background: 'transparent',\n cursor: 'pointer', flexShrink: 0,\n color: 'inherit', opacity: 0.55,\n lineHeight: 0,\n }}\n >\n <svg width={s.closeSize} height={s.closeSize} viewBox=\"0 0 10 10\" fill=\"none\">\n <path d=\"M7.5 2.5l-5 5M2.5 2.5l5 5\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" />\n </svg>\n </button>\n )}\n\n {/* Legacy: icon rendered after text when iconPosition='after' */}\n {iconPosition === 'after' && icon && !iconTypeProp && (\n <span style={{ display: 'flex', alignItems: 'center', flexShrink: 0, marginLeft: s.contentGap }}>\n {icon}\n </span>\n )}\n </div>\n );\n};\n\nexport default Tag;\n","import React, { useState, useRef, KeyboardEvent } from 'react';\nimport Tag from '../Tag';\n\nexport interface InputTagsProps {\n value?: string[];\n defaultValue?: string[];\n onChange?: (tags: string[]) => void;\n placeholder?: string;\n disabled?: boolean;\n error?: boolean;\n size?: 'small' | 'mediumSmall' | 'medium' | 'large';\n className?: string;\n style?: React.CSSProperties;\n label?: string;\n required?: boolean;\n hintText?: string;\n}\n\nconst SHADOW_XS = 'var(--shadow-xs)';\n\nconst containerPadding = {\n small: '4px',\n mediumSmall: '6px',\n medium: '8px',\n large: '10px',\n};\n\nconst tagSizeMap = {\n small: 'sm',\n mediumSmall: 'sm',\n medium: 'md',\n large: 'lg',\n} as const;\n\nconst InputTags: React.FC<InputTagsProps> = ({\n value,\n defaultValue = [],\n onChange,\n placeholder = 'Add tag...',\n disabled = false,\n error = false,\n size = 'mediumSmall',\n className = '',\n style,\n label,\n required,\n hintText,\n}) => {\n const [internalTags, setInternalTags] = useState<string[]>(defaultValue);\n const [inputValue, setInputValue] = useState('');\n const [focused, setFocused] = useState(false);\n const inputRef = useRef<HTMLInputElement>(null);\n\n const isControlled = value !== undefined;\n const tags = isControlled ? value! : internalTags;\n\n const updateTags = (next: string[]) => {\n if (!isControlled) setInternalTags(next);\n onChange?.(next);\n };\n\n const addTag = (tag: string) => {\n const trimmed = tag.trim();\n if (!trimmed || tags.includes(trimmed)) return;\n updateTags([...tags, trimmed]);\n setInputValue('');\n };\n\n const removeTag = (index: number) => {\n updateTags(tags.filter((_, i) => i !== index));\n };\n\n const handleKeyDown = (e: KeyboardEvent<HTMLInputElement>) => {\n if ((e.key === 'Enter' || e.key === ',') && inputValue) {\n e.preventDefault();\n addTag(inputValue);\n }\n if (e.key === 'Backspace' && !inputValue && tags.length > 0) {\n removeTag(tags.length - 1);\n }\n };\n\n const getFocusStyles = (): React.CSSProperties => {\n if (disabled) return { border: '1px solid var(--color-border-disabled)', boxShadow: SHADOW_XS, outline: 'none' };\n if (error && focused) return { border: '1px solid var(--color-border-error)', boxShadow: SHADOW_XS, outline: '2px solid var(--color-border-error)', outlineOffset: '-2px' };\n if (error) return { border: '1px solid var(--color-border-error_subtle)', boxShadow: SHADOW_XS, outline: 'none' };\n if (focused) return { border: '1px solid var(--color-border-brand)', boxShadow: SHADOW_XS, outline: '2px solid var(--color-border-brand)', outlineOffset: '-2px' };\n return { border: '1px solid var(--color-border-primary)', boxShadow: SHADOW_XS, outline: 'none' };\n };\n\n const { border, boxShadow, outline, outlineOffset } = getFocusStyles();\n const p = containerPadding[size];\n const tagSize = tagSizeMap[size];\n\n const labelStyle: React.CSSProperties = {\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 500,\n lineHeight: '20px',\n color: 'var(--color-text-secondary)',\n };\n\n const tagsEl = (\n <div\n className={`aha-input-tags ${className}`}\n onClick={() => inputRef.current?.focus()}\n style={{\n display: 'flex',\n flexWrap: 'wrap',\n alignItems: 'center',\n gap: '6px',\n padding: p,\n border,\n boxShadow,\n outline,\n outlineOffset,\n borderRadius: 'var(--radius-md)',\n backgroundColor: disabled ? 'var(--color-bg-disabled_subtle)' : 'var(--color-bg-primary)',\n boxSizing: 'border-box',\n width: '100%',\n transition: 'border-color 0.15s ease, box-shadow 0.15s ease',\n cursor: disabled ? 'not-allowed' : 'text',\n ...style,\n }}\n >\n {tags.map((tag, i) => (\n <Tag\n key={i}\n size={tagSize}\n action={disabled ? 'none' : 'x-close'}\n onClose={() => removeTag(i)}\n >\n {tag}\n </Tag>\n ))}\n <input\n ref={inputRef}\n value={inputValue}\n onChange={(e) => setInputValue(e.target.value)}\n onKeyDown={handleKeyDown}\n onFocus={() => setFocused(true)}\n onBlur={() => { setFocused(false); if (inputValue) addTag(inputValue); }}\n disabled={disabled}\n placeholder={tags.length === 0 ? placeholder : ''}\n style={{\n flex: 1,\n minWidth: '80px',\n border: 'none',\n outline: 'none',\n padding: 0,\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-md)',\n lineHeight: 'var(--line-height-text-md)',\n color: disabled ? 'var(--color-text-disabled)' : 'var(--color-text-primary)',\n backgroundColor: 'transparent',\n }}\n />\n <style>{`\n .aha-input-tags input::placeholder { color: var(--color-text-placeholder); }\n `}</style>\n </div>\n );\n\n if (!label && !hintText) return tagsEl;\n\n return (\n <div style={{ display: 'flex', flexDirection: 'column', gap: '6px', width: '100%' }}>\n {label && (\n <label style={labelStyle}>\n {label}\n {required && <span style={{ color: 'var(--color-error-600)', marginLeft: '2px' }}>*</span>}\n </label>\n )}\n {tagsEl}\n {hintText && (\n <p style={{\n margin: 0,\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 400,\n lineHeight: '20px',\n color: error ? 'var(--color-error-600)' : 'var(--color-text-tertiary)',\n }}>\n {hintText}\n </p>\n )}\n </div>\n );\n};\n\nexport default InputTags;\n","import React from 'react';\nimport InputTags, { InputTagsProps } from '../Input/InputTags';\n\nexport interface TextareaTagsProps extends Omit<InputTagsProps, 'size'> {\n minHeight?: number;\n helpIcon?: React.ReactNode;\n}\n\nconst TextareaTags: React.FC<TextareaTagsProps> = ({\n minHeight = 120,\n style,\n label,\n required,\n hintText,\n helpIcon,\n error,\n ...props\n}) => {\n const tagsEl = (\n <InputTags\n error={error}\n style={{\n minHeight: `${minHeight}px`,\n alignItems: 'flex-start',\n overflow: 'auto',\n resize: 'vertical',\n ...style,\n }}\n {...props}\n />\n );\n\n if (!label && !hintText) return tagsEl;\n\n return (\n <div style={{ display: 'flex', flexDirection: 'column', gap: '6px', width: '100%' }}>\n {label && (\n <label style={{\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 500,\n lineHeight: '20px',\n color: 'var(--color-text-secondary)',\n display: 'flex',\n alignItems: 'center',\n }}>\n {label}\n {required && <span style={{ color: 'var(--color-error-600)', marginLeft: '2px' }}>*</span>}\n {helpIcon && (\n <span style={{ marginLeft: '4px', display: 'inline-flex', alignItems: 'center', color: 'var(--color-fg-quaternary)' }}>\n {helpIcon}\n </span>\n )}\n </label>\n )}\n {tagsEl}\n {hintText && (\n <p style={{\n margin: 0,\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 400,\n lineHeight: '20px',\n color: error ? 'var(--color-error-600)' : 'var(--color-text-tertiary)',\n }}>\n {hintText}\n </p>\n )}\n </div>\n );\n};\n\nexport default TextareaTags;\n","import React, { forwardRef, useRef, useEffect, useMemo, useLayoutEffect } from 'react';\n\ninterface LinkifyOptions {\n validate?: (url: string) => boolean;\n className?: string;\n needProtocol?: boolean;\n needHost?: boolean;\n allowedTlds?: string[];\n}\n\nexport interface TextareaProps\n extends Omit<React.TextareaHTMLAttributes<HTMLTextAreaElement>, 'size'> {\n disabled?: boolean;\n error?: boolean;\n readOnly?: boolean;\n showCount?: boolean;\n maxLength?: number;\n className?: string;\n style?: React.CSSProperties;\n placeholder?: string;\n value?: string;\n defaultValue?: string;\n rows?: number;\n autoSize?: boolean | { minRows?: number; maxRows?: number };\n onChange?: (e: React.ChangeEvent<HTMLTextAreaElement>) => void;\n onFocus?: (e: React.FocusEvent<HTMLTextAreaElement>) => void;\n onBlur?: (e: React.FocusEvent<HTMLTextAreaElement>) => void;\n linkify?: boolean;\n linkifyOptions?: LinkifyOptions;\n label?: string;\n required?: boolean;\n hintText?: string;\n helpIcon?: React.ReactNode;\n}\n\ntype TextToken =\n | { type: 'text'; text: string }\n | { type: 'url'; text: string; href: string };\n\nconst DOMAIN_REGEX = /^(?:[a-zA-Z0-9-]+\\.)+[a-zA-Z]{2,}$/;\nconst URL_CANDIDATE_REGEX =\n /(https?:\\/\\/[^\\s<]+|www\\.[^\\s<]+|(?:[a-zA-Z0-9-]+\\.)+[a-zA-Z]{2,}(?:\\/[^\\s<]*)?)/gi;\nconst DEFAULT_ALLOWED_TLDS = new Set([\n 'com',\n 'cn',\n 'net',\n 'org',\n 'io',\n 'co',\n 'edu',\n 'gov',\n 'ai',\n 'app',\n 'dev',\n 'me',\n 'info',\n 'biz',\n 'tech',\n 'cc',\n 'tv',\n 'xyz',\n 'top',\n 'vip',\n 'pro',\n 'store',\n 'site',\n 'online',\n 'cloud',\n]);\n\nexport const websiteValidator = (\n url: string,\n needProtocol: boolean = true,\n needHost: boolean = true,\n allowedTlds?: string[]\n): boolean => {\n if (!url || typeof url !== 'string') return false;\n const trimmed = url.trim();\n if (!trimmed) return false;\n\n const hasProtocol = /^[a-zA-Z][a-zA-Z\\d+\\-.]*:\\/\\//.test(trimmed);\n if (needProtocol && !hasProtocol) return false;\n\n const normalized = hasProtocol ? trimmed : `https://${trimmed}`;\n\n try {\n const parsed = new URL(normalized);\n const protocol = parsed.protocol.toLowerCase();\n if (protocol !== 'http:' && protocol !== 'https:') return false;\n\n if (needHost) {\n const host = parsed.hostname.toLowerCase();\n if (!host) return false;\n if (host === 'localhost') return true;\n if (/^\\d{1,3}(\\.\\d{1,3}){3}$/.test(host)) {\n return host.split('.').every((segment) => {\n const num = Number(segment);\n return Number.isInteger(num) && num >= 0 && num <= 255;\n });\n }\n if (!DOMAIN_REGEX.test(host)) return false;\n const tld = host.split('.').pop() || '';\n const tldSet = allowedTlds\n ? new Set(allowedTlds.map((item) => item.toLowerCase()))\n : DEFAULT_ALLOWED_TLDS;\n if (!tldSet.has(tld)) return false;\n }\n return true;\n } catch {\n return false;\n }\n};\n\nconst trimTrailingPunctuation = (value: string): { core: string; suffix: string } => {\n const match = value.match(/^(.*?)([),.;!?]+)?$/);\n return {\n core: match?.[1] || value,\n suffix: match?.[2] || '',\n };\n};\n\nconst tokenizeText = (\n text: string,\n options?: LinkifyOptions\n): TextToken[] => {\n if (!text) return [];\n\n const tokens: TextToken[] = [];\n let lastIndex = 0;\n const regex = new RegExp(URL_CANDIDATE_REGEX);\n let match = regex.exec(text);\n\n while (match) {\n const matchedText = match[0];\n const start = match.index;\n const end = start + matchedText.length;\n\n if (start > lastIndex) {\n tokens.push({ type: 'text', text: text.slice(lastIndex, start) });\n }\n\n const { core, suffix } = trimTrailingPunctuation(matchedText);\n const href = /^[a-zA-Z][a-zA-Z\\d+\\-.]*:\\/\\//.test(core)\n ? core\n : `https://${core}`;\n const defaultIsValid = websiteValidator(\n core,\n options?.needProtocol ?? false,\n options?.needHost ?? true,\n options?.allowedTlds\n );\n const isValid = options?.validate ? options.validate(href) : defaultIsValid;\n\n if (isValid && core) {\n tokens.push({ type: 'url', text: core, href });\n if (suffix) {\n tokens.push({ type: 'text', text: suffix });\n }\n } else {\n tokens.push({ type: 'text', text: matchedText });\n }\n\n lastIndex = end;\n match = regex.exec(text);\n }\n\n if (lastIndex < text.length) {\n tokens.push({ type: 'text', text: text.slice(lastIndex) });\n }\n\n return tokens;\n};\n\nconst escapeHtml = (value: string): string =>\n value\n .replace(/&/g, '&amp;')\n .replace(/</g, '&lt;')\n .replace(/>/g, '&gt;')\n .replace(/\"/g, '&quot;')\n .replace(/'/g, '&#39;');\n\nconst ZWSP = '\\u200B';\nconst stripEditorArtifacts = (value: string): string =>\n value.replace(new RegExp(ZWSP, 'g'), '');\n\nconst renderTokensAsHtml = (\n text: string,\n options?: LinkifyOptions,\n disabled?: boolean\n): string => {\n const tokens = tokenizeText(text, options);\n if (tokens.length === 0) return '';\n\n const html = tokens\n .map((token) => {\n if (token.type === 'text') {\n return escapeHtml(token.text);\n }\n\n const classAttr = options?.className ? ` class=\"${options.className}\"` : '';\n const pointerEvents = disabled ? 'pointer-events: none;' : '';\n return `<a href=\"${escapeHtml(token.href)}\" target=\"_blank\" rel=\"noopener noreferrer\"${classAttr} style=\"color: #2563EB; text-decoration: underline; ${pointerEvents}\">${escapeHtml(token.text)}</a>`;\n })\n .join('');\n\n // contentEditable 在末尾是换行时可能吞掉视觉换行,补一个零宽字符占位\n if (text.endsWith('\\n')) {\n return `${html}<span data-aha-zwsp=\"true\">${ZWSP}</span>`;\n }\n return html;\n};\n\nconst getCaretOffset = (container: HTMLElement): number => {\n const selection = window.getSelection();\n if (!selection || selection.rangeCount === 0) return 0;\n\n const range = selection.getRangeAt(0);\n if (!container.contains(range.startContainer)) return 0;\n\n const preRange = range.cloneRange();\n preRange.selectNodeContents(container);\n preRange.setEnd(range.startContainer, range.startOffset);\n return stripEditorArtifacts(preRange.toString()).length;\n};\n\nconst setCaretOffset = (container: HTMLElement, offset: number): void => {\n const range = document.createRange();\n const selection = window.getSelection();\n if (!selection) return;\n\n let remaining = Math.max(0, offset);\n const walker = document.createTreeWalker(container, NodeFilter.SHOW_TEXT);\n let currentNode = walker.nextNode();\n\n while (currentNode) {\n const rawText = currentNode.textContent || '';\n let visibleCount = 0;\n let targetOffsetInNode = -1;\n for (let i = 0; i < rawText.length; i += 1) {\n if (rawText[i] !== ZWSP) {\n visibleCount += 1;\n }\n if (visibleCount === remaining) {\n targetOffsetInNode = i + 1;\n break;\n }\n }\n\n if (remaining === 0) {\n range.setStart(currentNode, 0);\n range.collapse(true);\n selection.removeAllRanges();\n selection.addRange(range);\n return;\n }\n\n if (targetOffsetInNode !== -1) {\n range.setStart(currentNode, targetOffsetInNode);\n range.collapse(true);\n selection.removeAllRanges();\n selection.addRange(range);\n return;\n }\n\n remaining -= visibleCount;\n currentNode = walker.nextNode();\n }\n\n range.selectNodeContents(container);\n range.collapse(false);\n selection.removeAllRanges();\n selection.addRange(range);\n};\n\nconst getSelectionOffsets = (\n container: HTMLElement\n): { start: number; end: number } | null => {\n const selection = window.getSelection();\n if (!selection || selection.rangeCount === 0) return null;\n const range = selection.getRangeAt(0);\n if (!container.contains(range.startContainer) || !container.contains(range.endContainer)) {\n return null;\n }\n\n const startRange = range.cloneRange();\n startRange.selectNodeContents(container);\n startRange.setEnd(range.startContainer, range.startOffset);\n\n const endRange = range.cloneRange();\n endRange.selectNodeContents(container);\n endRange.setEnd(range.endContainer, range.endOffset);\n\n return {\n start: stripEditorArtifacts(startRange.toString()).length,\n end: stripEditorArtifacts(endRange.toString()).length,\n };\n};\n\nconst Textarea = forwardRef<HTMLTextAreaElement, TextareaProps>(\n (\n {\n disabled = false,\n error = false,\n readOnly = false,\n showCount = false,\n maxLength,\n className = '',\n style,\n placeholder,\n value,\n defaultValue,\n rows = 3,\n autoSize = false,\n onChange,\n onFocus,\n onBlur,\n linkify = false,\n linkifyOptions,\n label,\n required,\n hintText,\n helpIcon,\n ...restProps\n },\n ref\n ) => {\n const textareaRef = useRef<HTMLTextAreaElement>(null);\n const editableRef = useRef<HTMLDivElement>(null);\n const isComposingRef = useRef(false);\n const caretOffsetRef = useRef<number | null>(null);\n const [internalValue, setInternalValue] = React.useState(\n defaultValue || value || ''\n );\n const [focused, setFocused] = React.useState(false);\n const [height, setHeight] = React.useState<number | undefined>(undefined);\n\n // 合并 ref(仅原生 textarea 模式)\n useEffect(() => {\n if (typeof ref === 'function') {\n ref(linkify ? null : textareaRef.current);\n } else if (ref) {\n (ref as React.MutableRefObject<HTMLTextAreaElement | null>).current =\n linkify ? null : textareaRef.current;\n }\n }, [ref, linkify]);\n\n // 受控/非受控处理\n const isControlled = value !== undefined;\n const currentValue = isControlled ? value : internalValue;\n const currentLength = String(currentValue || '').length;\n\n const handleChange = (e: React.ChangeEvent<HTMLTextAreaElement>) => {\n if (!isControlled) {\n setInternalValue(e.target.value);\n }\n onChange?.(e);\n };\n\n const handleFocus = (e: React.FocusEvent<HTMLTextAreaElement>) => {\n setFocused(true);\n onFocus?.(e);\n };\n\n const handleBlur = (e: React.FocusEvent<HTMLTextAreaElement>) => {\n setFocused(false);\n onBlur?.(e);\n };\n\n const getMaxLengthValue = useMemo(\n () => (typeof maxLength === 'number' ? maxLength : undefined),\n [maxLength]\n );\n\n // 自动调整高度(原生 textarea)\n useEffect(() => {\n if (!linkify && autoSize && textareaRef.current) {\n const textarea = textareaRef.current;\n const minRows =\n typeof autoSize === 'object' ? autoSize.minRows || 1 : 1;\n const maxRows =\n typeof autoSize === 'object' ? autoSize.maxRows : undefined;\n\n // 重置高度以获取正确的 scrollHeight\n textarea.style.height = 'auto';\n const scrollHeight = textarea.scrollHeight;\n\n // 计算行高(假设每行约 22px,根据字体大小调整)\n const lineHeight = parseInt(\n window.getComputedStyle(textarea).lineHeight || '22',\n 10\n );\n const minHeight = minRows * lineHeight;\n const maxHeight = maxRows ? maxRows * lineHeight : undefined;\n\n let newHeight = Math.max(scrollHeight, minHeight);\n if (maxHeight) {\n newHeight = Math.min(newHeight, maxHeight);\n }\n\n textarea.style.height = `${newHeight}px`;\n setHeight(newHeight);\n }\n }, [currentValue, autoSize, linkify]);\n\n // 自动调整高度(linkify + contentEditable)\n useEffect(() => {\n if (!linkify || !autoSize || !editableRef.current) return;\n const editable = editableRef.current;\n const minRows = typeof autoSize === 'object' ? autoSize.minRows || 1 : 1;\n const maxRows = typeof autoSize === 'object' ? autoSize.maxRows : undefined;\n\n const lineHeight = parseInt(\n window.getComputedStyle(editable).lineHeight || '24',\n 10\n );\n const minHeight = minRows * lineHeight + 24;\n const maxHeight = maxRows ? maxRows * lineHeight + 24 : undefined;\n\n editable.style.height = 'auto';\n let newHeight = Math.max(editable.scrollHeight, minHeight);\n if (maxHeight) {\n newHeight = Math.min(newHeight, maxHeight);\n }\n editable.style.height = `${newHeight}px`;\n editable.style.overflowY = maxHeight && editable.scrollHeight > maxHeight ? 'auto' : 'hidden';\n setHeight(newHeight);\n }, [autoSize, currentValue, linkify]);\n\n useLayoutEffect(() => {\n if (!linkify || !editableRef.current || isComposingRef.current) return;\n const editable = editableRef.current;\n const isActive = document.activeElement === editable;\n const fallbackOffset = isActive ? getCaretOffset(editable) : 0;\n const caretOffset = caretOffsetRef.current ?? fallbackOffset;\n const nextHtml = renderTokensAsHtml(\n String(currentValue || ''),\n linkifyOptions,\n disabled\n );\n\n if (editable.innerHTML !== nextHtml) {\n editable.innerHTML = nextHtml;\n }\n\n if (isActive) {\n const maxOffset = String(currentValue || '').length;\n setCaretOffset(editable, Math.min(caretOffset, maxOffset));\n }\n caretOffsetRef.current = null;\n }, [currentValue, disabled, linkify, linkifyOptions]);\n\n const notifyChange = (nextValue: string) => {\n const syntheticEvent = {\n target: { value: nextValue },\n currentTarget: { value: nextValue },\n } as React.ChangeEvent<HTMLTextAreaElement>;\n onChange?.(syntheticEvent);\n };\n\n const handleEditableInput = () => {\n if (!editableRef.current || isComposingRef.current) return;\n caretOffsetRef.current = getCaretOffset(editableRef.current);\n const rawValue = stripEditorArtifacts(editableRef.current.textContent || '');\n const nextValue = getMaxLengthValue ? rawValue.slice(0, getMaxLengthValue) : rawValue;\n\n if (!isControlled) {\n setInternalValue(nextValue);\n }\n notifyChange(nextValue);\n };\n\n const handleEditablePaste = (e: React.ClipboardEvent<HTMLDivElement>) => {\n e.preventDefault();\n if (readOnly || disabled) return;\n\n const pastedText = e.clipboardData.getData('text/plain');\n const currentText = String(currentValue || '');\n const selection = window.getSelection();\n let nextText = `${currentText}${pastedText}`;\n let caretOffset = currentText.length + pastedText.length;\n\n if (\n selection &&\n selection.rangeCount > 0 &&\n editableRef.current?.contains(selection.anchorNode)\n ) {\n const startOffset = getCaretOffset(editableRef.current);\n const endOffset = (() => {\n const range = selection.getRangeAt(0);\n const preRange = range.cloneRange();\n preRange.selectNodeContents(editableRef.current);\n preRange.setEnd(range.endContainer, range.endOffset);\n return preRange.toString().length;\n })();\n nextText =\n currentText.slice(0, startOffset) +\n pastedText +\n currentText.slice(endOffset);\n caretOffset = startOffset + pastedText.length;\n }\n\n if (getMaxLengthValue) {\n nextText = nextText.slice(0, getMaxLengthValue);\n caretOffset = Math.min(caretOffset, nextText.length);\n }\n caretOffsetRef.current = caretOffset;\n\n if (!isControlled) {\n setInternalValue(nextText);\n }\n notifyChange(nextText);\n };\n\n const handleEditableKeyDown = (e: React.KeyboardEvent<HTMLDivElement>) => {\n if (e.key !== 'Enter' || e.nativeEvent.isComposing) return;\n if (disabled || readOnly) return;\n if (!editableRef.current) return;\n\n e.preventDefault();\n const currentText = String(currentValue || '');\n const offsets = getSelectionOffsets(editableRef.current);\n const start = offsets?.start ?? currentText.length;\n const end = offsets?.end ?? start;\n\n let nextText = `${currentText.slice(0, start)}\\n${currentText.slice(end)}`;\n if (getMaxLengthValue) {\n nextText = nextText.slice(0, getMaxLengthValue);\n }\n\n const nextCaret = Math.min(start + 1, nextText.length);\n caretOffsetRef.current = nextCaret;\n\n if (!isControlled) {\n setInternalValue(nextText);\n }\n notifyChange(nextText);\n };\n\n const SHADOW_XS = 'var(--shadow-xs)';\n\n const getFocusStyles = (): React.CSSProperties => {\n if (disabled) return { border: '1px solid var(--color-border-disabled)', boxShadow: SHADOW_XS, outline: 'none' };\n if (error && focused) return { border: '1px solid var(--color-border-error)', boxShadow: SHADOW_XS, outline: '2px solid var(--color-border-error)', outlineOffset: '-2px' };\n if (error) return { border: '1px solid var(--color-border-error_subtle)', boxShadow: SHADOW_XS, outline: 'none' };\n if (focused) return { border: '1px solid var(--color-border-brand)', boxShadow: SHADOW_XS, outline: '2px solid var(--color-border-brand)', outlineOffset: '-2px' };\n return { border: '1px solid var(--color-border-primary)', boxShadow: SHADOW_XS, outline: 'none' };\n };\n\n const baseStyles: React.CSSProperties = {\n width: '100%',\n boxSizing: 'border-box',\n fontFamily: 'var(--font-family-body)',\n borderRadius: 'var(--radius-md)',\n ...getFocusStyles(),\n backgroundColor:\n disabled || readOnly\n ? 'var(--color-bg-disabled_subtle)'\n : 'var(--color-bg-primary)',\n color: disabled ? 'var(--color-text-disabled)' : 'var(--color-text-primary)',\n fontSize: 'var(--font-size-text-md)',\n fontWeight: 400,\n lineHeight: 'var(--line-height-text-md)',\n padding: '12px 14px',\n transition: 'border-color 0.15s ease, box-shadow 0.15s ease, outline-color 0.15s ease',\n resize: autoSize || linkify ? 'none' : 'vertical',\n cursor: disabled ? 'not-allowed' : 'text',\n WebkitAppearance: 'none',\n appearance: 'none',\n ...(height !== undefined && autoSize ? { height: `${height}px` } : {}),\n ...style,\n };\n\n const placeholderStyles = `\n .aha-textarea-wrapper textarea::placeholder {\n color: var(--color-text-placeholder);\n font-size: var(--font-size-text-md);\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea::-webkit-input-placeholder { color: var(--color-text-placeholder); }\n .aha-textarea-wrapper textarea::-moz-placeholder { color: var(--color-text-placeholder); }\n .aha-textarea-wrapper textarea:-ms-input-placeholder { color: var(--color-text-placeholder); }\n .aha-textarea-wrapper textarea {\n -webkit-tap-highlight-color: transparent;\n -webkit-touch-callout: none;\n touch-action: manipulation;\n }\n .aha-textarea-wrapper .aha-textarea-editable {\n white-space: pre-wrap;\n word-break: break-word;\n }\n .aha-textarea-wrapper .aha-textarea-editable:empty::before {\n content: attr(data-placeholder);\n color: var(--color-text-placeholder);\n }\n .aha-textarea-wrapper .aha-textarea-editable a {\n color: #2563EB;\n }\n `;\n\n const textareaEl = (\n <>\n <style>{placeholderStyles}</style>\n <div\n className={`aha-textarea-wrapper ${className}`}\n style={{\n position: 'relative',\n display: 'inline-flex',\n flexDirection: 'column',\n width: '100%',\n }}\n >\n {linkify ? (\n <div\n ref={editableRef}\n className=\"aha-textarea-editable\"\n contentEditable={!disabled && !readOnly}\n suppressContentEditableWarning\n role=\"textbox\"\n aria-multiline=\"true\"\n aria-disabled={disabled}\n data-placeholder={placeholder || ''}\n onInput={handleEditableInput}\n onPaste={handleEditablePaste}\n onKeyDown={handleEditableKeyDown}\n onFocus={(e) => handleFocus(e as unknown as React.FocusEvent<HTMLTextAreaElement>)}\n onBlur={(e) => handleBlur(e as unknown as React.FocusEvent<HTMLTextAreaElement>)}\n onCompositionStart={() => {\n isComposingRef.current = true;\n }}\n onCompositionEnd={() => {\n isComposingRef.current = false;\n handleEditableInput();\n }}\n style={{\n ...baseStyles,\n minHeight: autoSize ? undefined : `${rows * 24 + 24}px`,\n overflowY: autoSize ? 'hidden' : 'auto',\n }}\n autoCorrect={restProps.autoCorrect || 'off'}\n autoCapitalize={restProps.autoCapitalize || 'off'}\n spellCheck={restProps.spellCheck || false}\n />\n ) : (\n <textarea\n ref={textareaRef}\n value={currentValue}\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readOnly}\n rows={autoSize ? undefined : rows}\n maxLength={maxLength}\n onChange={handleChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n style={baseStyles}\n autoComplete={restProps.autoComplete || 'off'}\n autoCorrect={restProps.autoCorrect || 'off'}\n autoCapitalize={restProps.autoCapitalize || 'off'}\n spellCheck={restProps.spellCheck || false}\n {...restProps}\n />\n )}\n {(showCount || maxLength) && (\n <div\n style={{\n display: 'flex',\n justifyContent: 'flex-end',\n marginTop: '4px',\n fontSize: 'var(--font-size-text-xs)',\n lineHeight: 'var(--line-height-text-xs)',\n color: disabled ? 'var(--color-text-disabled)' : 'var(--color-text-tertiary)',\n fontFamily: 'var(--font-family-body)',\n }}\n >\n {maxLength ? (\n <span>\n {currentLength} / {maxLength}\n </span>\n ) : (\n <span>{currentLength}</span>\n )}\n </div>\n )}\n </div>\n </>\n );\n\n if (!label && !hintText) return textareaEl;\n\n return (\n <div style={{ display: 'flex', flexDirection: 'column', gap: '6px', width: '100%' }}>\n {label && (\n <label style={{\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 500,\n lineHeight: '20px',\n color: 'var(--color-text-secondary)',\n display: 'flex',\n alignItems: 'center',\n gap: '2px',\n }}>\n {label}\n {required && <span style={{ color: 'var(--color-error-600)', marginLeft: '2px' }}>*</span>}\n {helpIcon && (\n <span style={{ marginLeft: '4px', display: 'inline-flex', alignItems: 'center', color: 'var(--color-fg-quaternary)' }}>\n {helpIcon}\n </span>\n )}\n </label>\n )}\n {textareaEl}\n {hintText && (\n <p style={{\n margin: 0,\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 400,\n lineHeight: '20px',\n color: error ? 'var(--color-error-600)' : 'var(--color-text-tertiary)',\n }}>\n {hintText}\n </p>\n )}\n </div>\n );\n }\n);\n\nTextarea.displayName = 'Textarea';\n\nexport default Textarea;\nexport { default as TextareaTags } from './TextareaTags';\nexport type { TextareaTagsProps } from './TextareaTags';\n\n"],"names":["__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","this","__rest","e","indexOf","getOwnPropertySymbols","propertyIsEnumerable","__spreadArray","to","from","pack","ar","l","Array","slice","concat","SuppressedError","defaultTheme","primaryColor","ThemeContext","createContext","COLOR_CONFIG","Green","light","bg","text","border","fill","Red","Orange","Cyan","Violet","Pink","Gray","Yellow","Blue","SIZE","sm","basePx","basePy","plCheckbox","plAvatar","plDot","plIcon","prClose","prCount","fontSize","lineHeight","height","avatarSize","checkboxSize","contentGap","rootGap","countPx","countFontSize","closeSize","closePad","md","lg","TagAvatar","_a","src","_b","alt","_c","size","_d","useState","failed","setFailed","_jsx","style","width","borderRadius","overflow","flexShrink","background","display","alignItems","justifyContent","children","onError","objectFit","_jsxs","viewBox","cx","cy","r","stroke","strokeWidth","d","strokeLinecap","Tag","color","variant","iconTypeProp","iconType","icon","avatarSrc","dotColor","_e","action","count","onClose","_f","checkbox","checkedProp","checked","onCheckedChange","iconPosition","_g","className","onClick","rest","useContext","_h","internalChecked","setInternalChecked","nSize","normalizeSize","isChecked","undefined","effectiveAction","pl","pr","containerStyle","gap","paddingLeft","paddingRight","paddingTop","paddingBottom","fontFamily","fontWeight","transition","cursor","boxSizing","backgroundColor","outline","outlineOffset","colorConfig","config","startsWith","parseInt","g","b","getColorConfig","map","getOutlineColor","role","stopPropagation","next","Math","round","strokeLinejoin","React","cloneElement","whiteSpace","padding","opacity","marginLeft","SHADOW_XS","containerPadding","small","mediumSmall","medium","large","tagSizeMap","InputTags","value","defaultValue","onChange","placeholder","disabled","error","label","required","hintText","internalTags","setInternalTags","_j","inputValue","setInputValue","_k","focused","setFocused","inputRef","useRef","isControlled","tags","updateTags","addTag","tag","trimmed","trim","includes","removeTag","index","filter","_","_l","boxShadow","tagSize","tagsEl","current","focus","flexWrap","ref","target","onKeyDown","key","preventDefault","onFocus","onBlur","flex","minWidth","flexDirection","margin","TextareaTags","minHeight","helpIcon","props","resize","DOMAIN_REGEX","URL_CANDIDATE_REGEX","DEFAULT_ALLOWED_TLDS","Set","websiteValidator","url","needProtocol","needHost","allowedTlds","hasProtocol","test","normalized","parsed","URL","protocol","toLowerCase","host","hostname","split","every","segment","num","Number","isInteger","tld","pop","item","has","trimTrailingPunctuation","match","core","suffix","escapeHtml","replace","stripEditorArtifacts","RegExp","renderTokensAsHtml","options","tokens","lastIndex","regex","exec","matchedText","start","end","push","type","href","defaultIsValid","validate","tokenizeText","html","token","classAttr","pointerEvents","join","endsWith","getCaretOffset","container","selection","window","getSelection","rangeCount","range","getRangeAt","contains","startContainer","preRange","cloneRange","selectNodeContents","setEnd","startOffset","toString","Textarea","forwardRef","readOnly","showCount","maxLength","rows","autoSize","linkify","linkifyOptions","restProps","textareaRef","editableRef","isComposingRef","caretOffsetRef","internalValue","setInternalValue","_m","setHeight","useEffect","currentValue","currentLength","String","handleFocus","handleBlur","getMaxLengthValue","useMemo","textarea","minRows","maxRows","scrollHeight","getComputedStyle","maxHeight","newHeight","max","min","editable","overflowY","useLayoutEffect","isActive","document","activeElement","fallbackOffset","caretOffset","nextHtml","innerHTML","maxOffset","offset","createRange","remaining","walker","createTreeWalker","NodeFilter","SHOW_TEXT","currentNode","nextNode","rawText","textContent","visibleCount","targetOffsetInNode","setStart","collapse","removeAllRanges","addRange","setCaretOffset","notifyChange","nextValue","currentTarget","handleEditableInput","rawValue","baseStyles","WebkitAppearance","appearance","textareaEl","_Fragment","position","contentEditable","suppressContentEditableWarning","onInput","onPaste","pastedText","clipboardData","getData","currentText","nextText","anchorNode","endOffset","endContainer","nativeEvent","isComposing","offsets","startRange","endRange","getSelectionOffsets","nextCaret","onCompositionStart","onCompositionEnd","autoCorrect","autoCapitalize","spellCheck","autoComplete","marginTop","displayName"],"mappings":"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","x_google_ignoreList":[0]}