@jacshuo/onyx 2.2.0 → 2.3.0

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/dist/Chart/BarChart.cjs +1 -1
  2. package/dist/Chart/BarChart.js +1 -1
  3. package/dist/Chart/PieChart.cjs +1 -1
  4. package/dist/Chart/PieChart.js +1 -1
  5. package/dist/Chart/ScatterChart.cjs +1 -1
  6. package/dist/Chart/ScatterChart.js +1 -1
  7. package/dist/Chart/index.cjs +1 -1
  8. package/dist/Chart/index.js +1 -1
  9. package/dist/DataDisplay/VirtualList.cjs +2 -0
  10. package/dist/DataDisplay/VirtualList.css +1 -0
  11. package/dist/DataDisplay/VirtualList.d.cts +5 -0
  12. package/dist/DataDisplay/VirtualList.d.ts +5 -0
  13. package/dist/DataDisplay/VirtualList.js +2 -0
  14. package/dist/DataDisplay/index.cjs +3 -2
  15. package/dist/DataDisplay/index.css +1 -0
  16. package/dist/DataDisplay/index.d.cts +5 -0
  17. package/dist/DataDisplay/index.d.ts +5 -0
  18. package/dist/DataDisplay/index.js +3 -2
  19. package/dist/Extras/FileExplorer.cjs +2 -2
  20. package/dist/Extras/FileExplorer.js +2 -2
  21. package/dist/Extras/LoginPanel.cjs +1 -0
  22. package/dist/Extras/LoginPanel.css +1 -0
  23. package/dist/Extras/LoginPanel.d.cts +3 -0
  24. package/dist/Extras/LoginPanel.d.ts +3 -0
  25. package/dist/Extras/LoginPanel.js +1 -0
  26. package/dist/Extras/RichTextEditor.cjs +45 -0
  27. package/dist/Extras/RichTextEditor.css +1 -0
  28. package/dist/Extras/RichTextEditor.d.cts +10 -0
  29. package/dist/Extras/RichTextEditor.d.ts +10 -0
  30. package/dist/Extras/RichTextEditor.js +45 -0
  31. package/dist/Extras/index.cjs +48 -4
  32. package/dist/Extras/index.css +1 -1
  33. package/dist/Extras/index.d.cts +7 -0
  34. package/dist/Extras/index.d.ts +7 -0
  35. package/dist/Extras/index.js +48 -4
  36. package/dist/Forms/Form.cjs +1 -1
  37. package/dist/Forms/Form.js +1 -1
  38. package/dist/Forms/OTPInput.cjs +1 -0
  39. package/dist/Forms/OTPInput.css +1 -0
  40. package/dist/Forms/OTPInput.d.cts +4 -0
  41. package/dist/Forms/OTPInput.d.ts +4 -0
  42. package/dist/Forms/OTPInput.js +1 -0
  43. package/dist/Forms/Select.cjs +1 -1
  44. package/dist/Forms/Select.js +1 -1
  45. package/dist/Forms/index.cjs +1 -1
  46. package/dist/Forms/index.css +1 -0
  47. package/dist/Forms/index.d.cts +4 -0
  48. package/dist/Forms/index.d.ts +4 -0
  49. package/dist/Forms/index.js +1 -1
  50. package/dist/Layout/SplitPanel.cjs +1 -0
  51. package/dist/Layout/SplitPanel.d.cts +3 -0
  52. package/dist/Layout/SplitPanel.d.ts +3 -0
  53. package/dist/Layout/SplitPanel.js +1 -0
  54. package/dist/Layout/index.cjs +1 -1
  55. package/dist/Layout/index.d.cts +3 -0
  56. package/dist/Layout/index.d.ts +3 -0
  57. package/dist/Layout/index.js +1 -1
  58. package/dist/Navigation/Header.cjs +1 -1
  59. package/dist/Navigation/Header.js +1 -1
  60. package/dist/Navigation/RibbonBar.d.cts +3 -3
  61. package/dist/Navigation/RibbonBar.d.ts +3 -3
  62. package/dist/Navigation/index.cjs +2 -2
  63. package/dist/Navigation/index.d.cts +3 -3
  64. package/dist/Navigation/index.d.ts +3 -3
  65. package/dist/Navigation/index.js +2 -2
  66. package/dist/Primitives/Avatar.cjs +1 -1
  67. package/dist/Primitives/Avatar.js +1 -1
  68. package/dist/Primitives/Badge.cjs +1 -1
  69. package/dist/Primitives/Badge.js +1 -1
  70. package/dist/Primitives/Button.cjs +1 -1
  71. package/dist/Primitives/Button.js +1 -1
  72. package/dist/Primitives/Checkbox.cjs +1 -1
  73. package/dist/Primitives/Checkbox.js +1 -1
  74. package/dist/Primitives/Dropdown.cjs +1 -1
  75. package/dist/Primitives/Dropdown.js +1 -1
  76. package/dist/Primitives/DropdownButton.cjs +1 -1
  77. package/dist/Primitives/DropdownButton.js +1 -1
  78. package/dist/Primitives/Indicator.cjs +1 -1
  79. package/dist/Primitives/Indicator.js +1 -1
  80. package/dist/Primitives/Input.cjs +1 -1
  81. package/dist/Primitives/Input.js +1 -1
  82. package/dist/Primitives/Kbd.cjs +1 -0
  83. package/dist/Primitives/Kbd.css +0 -0
  84. package/dist/Primitives/Kbd.d.cts +6 -0
  85. package/dist/Primitives/Kbd.d.ts +6 -0
  86. package/dist/Primitives/Kbd.js +1 -0
  87. package/dist/Primitives/Label.cjs +1 -1
  88. package/dist/Primitives/Label.js +1 -1
  89. package/dist/Primitives/Radio.cjs +1 -1
  90. package/dist/Primitives/Radio.js +1 -1
  91. package/dist/Primitives/Rating.cjs +2 -0
  92. package/dist/Primitives/Rating.css +0 -0
  93. package/dist/Primitives/Rating.d.cts +4 -0
  94. package/dist/Primitives/Rating.d.ts +4 -0
  95. package/dist/Primitives/Rating.js +2 -0
  96. package/dist/Primitives/Slider.cjs +1 -1
  97. package/dist/Primitives/Slider.js +1 -1
  98. package/dist/Primitives/Switch.cjs +1 -1
  99. package/dist/Primitives/Switch.js +1 -1
  100. package/dist/Primitives/Tag.cjs +1 -1
  101. package/dist/Primitives/Tag.js +1 -1
  102. package/dist/Primitives/index.cjs +2 -1
  103. package/dist/Primitives/index.d.cts +10 -0
  104. package/dist/Primitives/index.d.ts +10 -0
  105. package/dist/Primitives/index.js +2 -1
  106. package/dist/_tsup-dts-rollup.d.cts +825 -0
  107. package/dist/_tsup-dts-rollup.d.ts +825 -0
  108. package/dist/index.cjs +49 -5
  109. package/dist/index.css +1 -1
  110. package/dist/index.d.cts +35 -0
  111. package/dist/index.d.ts +35 -0
  112. package/dist/index.js +49 -5
  113. package/dist/styles/DataDisplay/VirtualList.css +35 -0
  114. package/dist/styles/Extras/LoginPanel.css +16 -0
  115. package/dist/styles/Extras/RichTextEditor.css +908 -0
  116. package/dist/styles/Forms/OTPInput.css +11 -0
  117. package/dist/styles/Layout/SplitPanel.css +15 -0
  118. package/dist/styles/Primitives/Kbd.css +1 -0
  119. package/dist/styles/Primitives/Rating.css +1 -0
  120. package/dist/styles/base.css +278 -0
  121. package/dist/styles.css +278 -0
  122. package/dist/theme.cjs +1 -1
  123. package/dist/theme.d.cts +3 -0
  124. package/dist/theme.d.ts +3 -0
  125. package/dist/theme.js +1 -1
  126. package/package.json +21 -1
@@ -1,2 +1,3 @@
1
- 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var L=require('react'),lucideReact=require('lucide-react'),clsx=require('clsx'),tailwindMerge=require('tailwind-merge'),classVarianceAuthority=require('class-variance-authority'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var L__default=/*#__PURE__*/_interopDefault(L);function i(...e){return tailwindMerge.twMerge(clsx.clsx(e))}var q=classVarianceAuthority.cva("w-full text-left text-sm",{variants:{intent:{default:"",striped:"[&_tbody_tr:nth-child(even)]:bg-primary-50 dark:[&_tbody_tr:nth-child(even)]:bg-primary-800/30",bordered:"[&_th]:border [&_td]:border [&_th]:border-primary-200 [&_td]:border-primary-200 dark:[&_th]:border-primary-700 dark:[&_td]:border-primary-700"},density:{compact:"[&_th]:px-2 [&_th]:py-1 [&_td]:px-2 [&_td]:py-1",default:"",relaxed:"[&_th]:px-6 [&_th]:py-5 [&_td]:px-6 [&_td]:py-5"}},defaultVariants:{intent:"default",density:"default"}}),O=classVarianceAuthority.cva("text-sm text-primary-700 dark:text-primary-300",{variants:{intent:{default:"space-y-1",bordered:"divide-y divide-primary-200 rounded-lg border border-primary-200 dark:divide-primary-700 dark:border-primary-700 [&>li]:px-4 [&>li]:py-2",hover:"[&>li]:rounded-md [&>li]:px-3 [&>li]:py-2 [&>li]:transition-colors [&>li:hover]:bg-primary-50 dark:[&>li:hover]:bg-primary-800/50"}},defaultVariants:{intent:"default"}});classVarianceAuthority.cva("group flex w-full items-center gap-1.5 text-left [&_svg]:shrink-0",{variants:{size:{sm:"py-0.5 text-xs [&_svg]:h-3 [&_svg]:w-3",md:"py-1.5 text-sm [&_svg]:h-3.5 [&_svg]:w-3.5",lg:"py-2 text-base [&_svg]:h-4 [&_svg]:w-4"}},defaultVariants:{size:"md"}});classVarianceAuthority.cva("flex cursor-pointer items-center gap-1 rounded transition-colors [&_svg]:shrink-0",{variants:{size:{sm:"py-0.5 text-xs [&_svg]:h-3.5 [&_svg]:w-3.5",md:"py-1 text-sm [&_svg]:h-4 [&_svg]:w-4",lg:"py-1.5 text-base [&_svg]:h-5 [&_svg]:w-5"}},defaultVariants:{size:"md"}});var $=classVarianceAuthority.cva("relative rounded-xl border bg-white p-5 shadow-sm transition-shadow hover:shadow-md dark:bg-primary-900",{variants:{intent:{primary:"border-primary-200 dark:border-primary-700",success:"border-success-200 dark:border-success-800",danger:"border-danger-200 dark:border-danger-800",warning:"border-warning-200 dark:border-warning-800"},size:{sm:"p-4",md:"p-5",lg:"p-6"}},defaultVariants:{intent:"primary",size:"md"}}),G=classVarianceAuthority.cva("relative overflow-hidden rounded-xl border bg-white p-5 shadow-sm transition-all duration-300 hover:shadow-lg dark:bg-primary-900",{variants:{intent:{primary:"border-primary-200 dark:border-primary-700",success:"border-success-200 dark:border-success-800",danger:"border-danger-200 dark:border-danger-800",warning:"border-warning-200 dark:border-warning-800"},size:{sm:"p-4",md:"p-5",lg:"p-6"}},defaultVariants:{intent:"primary",size:"md"}}),V=classVarianceAuthority.cva("overflow-x-auto rounded-lg font-mono [background:var(--color-syntax-bg)] [&_pre]:m-0 [&_pre]:p-4 [&_code]:bg-transparent",{variants:{size:{sm:"text-xs",md:"text-sm",lg:"text-base"}},defaultVariants:{size:"md"}});function P({intent:e,density:t,className:r,...s}){return jsxRuntime.jsx("div",{className:"w-full overflow-auto",children:jsxRuntime.jsx("table",{className:i(q({intent:e,density:t}),r),...s})})}var le=L.createContext({size:"md"});function M({intent:e,size:t="md",className:r,...s}){return jsxRuntime.jsx(le.Provider,{value:{size:t},children:jsxRuntime.jsx("ul",{className:i(O({intent:e}),r),...s})})}var me=L.createContext({showLines:true,expandedKeys:null,onToggleKey:()=>{},size:"md"});function H({showLines:e=true,showRoot:t=true,expandedKeys:r,defaultExpandedKeys:s="all",onExpandedKeysChange:a,size:n="md",className:l,children:c,...o}){let [y,g]=L.useState(()=>s),d=L.useCallback(u=>{if(r){let f=new Set(r);f.has(u)?f.delete(u):f.add(u),a?.(f);}else g(f=>{if(f==="all")return new Set(["__ALL_MINUS__",u]);let h=new Set(f);return h.has(u)?h.delete(u):h.add(u),h});},[r,a]),T=r??(y==="all"?null:y);return jsxRuntime.jsx(me.Provider,{value:{showLines:e,expandedKeys:T,onToggleKey:d,size:n},children:t?jsxRuntime.jsx("ul",{className:i("text-sm",l),role:"tree",...o,children:c}):jsxRuntime.jsx("ul",{className:i("text-sm",l),role:"tree",...o,children:jsxRuntime.jsx(ue,{children:c})})})}function ue({children:e}){let t=J(e);return jsxRuntime.jsx(jsxRuntime.Fragment,{children:t.map(r=>L__default.default.isValidElement(r)&&r.props.children?r.props.children:null)})}function J(e){let t=[];return L__default.default.Children.forEach(e,r=>{L__default.default.isValidElement(r)&&r.type===L__default.default.Fragment?t.push(...J(r.props.children)):t.push(r);}),t}function be({avatar:e,sender:t}){return e?typeof e=="string"?/^(?:https?|data|blob):/.test(e)?jsxRuntime.jsx("img",{src:e,alt:t,className:"h-8 w-8 shrink-0 rounded-full object-cover",draggable:false}):jsxRuntime.jsx("div",{className:"bg-primary-200 text-primary-600 dark:bg-primary-700 dark:text-primary-300 flex h-8 w-8 shrink-0 items-center justify-center rounded-full text-lg select-none",children:e}):jsxRuntime.jsx("div",{className:"flex h-8 w-8 shrink-0 items-center justify-center rounded-full",children:e}):jsxRuntime.jsx("div",{className:"bg-primary-200 text-primary-600 dark:bg-primary-700 dark:text-primary-300 flex h-8 w-8 shrink-0 items-center justify-center rounded-full text-sm font-semibold select-none",children:t.charAt(0).toUpperCase()})}function xe({msg:e,alignRight:t}){return jsxRuntime.jsxs("div",{className:i("flex gap-2.5",t?"flex-row-reverse":"flex-row"),children:[jsxRuntime.jsx(be,{avatar:e.avatar,sender:e.sender}),jsxRuntime.jsxs("div",{className:i("flex max-w-[75%] flex-col gap-0.5",t?"items-end":"items-start"),children:[jsxRuntime.jsx("span",{className:"text-primary-500 dark:text-primary-400 text-xs",children:e.sender}),jsxRuntime.jsx("div",{className:i("rounded-xl px-3 py-2 text-sm leading-relaxed",t?"rounded-tr-sm bg-primary-500 text-white dark:bg-primary-600":"bg-primary-100 text-primary-800 dark:bg-primary-800 dark:text-primary-200 rounded-tl-sm"),children:e.content}),e.time&&jsxRuntime.jsx("span",{className:"text-primary-400 dark:text-primary-500 text-[10px]",children:e.time})]})]})}function D({messages:e,mode:t="split",autoScroll:r=true,className:s,...a}){let n=L.useRef(null);return L.useEffect(()=>{r&&n.current?.scrollIntoView({behavior:"smooth"});},[e,r]),jsxRuntime.jsxs("div",{className:i("flex flex-col gap-4 overflow-y-auto rounded-lg border p-4","border-primary-200 dark:border-primary-700 dark:bg-primary-900 bg-white",s),...a,children:[e.map(l=>{let c=t==="split"&&!!l.self;return jsxRuntime.jsx(xe,{msg:l,alignRight:c},l.id)}),jsxRuntime.jsx("div",{ref:n})]})}var ke={name:"onyx-css-vars",type:"dark",settings:[{settings:{foreground:"var(--color-syntax-plain)",background:"var(--color-syntax-bg)"}},{scope:["comment","punctuation.definition.comment"],settings:{foreground:"var(--color-syntax-comment)",fontStyle:"italic"}},{scope:["keyword","keyword.control","keyword.operator.new","keyword.operator.expression","storage.type","storage.modifier"],settings:{foreground:"var(--color-syntax-keyword)"}},{scope:["string","string.quoted","string.template"],settings:{foreground:"var(--color-syntax-string)"}},{scope:["entity.name.function","support.function","meta.function-call"],settings:{foreground:"var(--color-syntax-function)"}},{scope:["variable","variable.other","variable.parameter","meta.definition.variable"],settings:{foreground:"var(--color-syntax-variable)"}},{scope:["constant.numeric","constant.language"],settings:{foreground:"var(--color-syntax-number)"}},{scope:["keyword.operator","keyword.operator.assignment","keyword.operator.comparison","keyword.operator.arithmetic"],settings:{foreground:"var(--color-syntax-operator)"}},{scope:["entity.name.tag","punctuation.definition.tag","support.class.component"],settings:{foreground:"var(--color-syntax-tag)"}},{scope:["entity.other.attribute-name","meta.tag.attributes"],settings:{foreground:"var(--color-syntax-attr)"}},{scope:["punctuation","meta.brace","punctuation.definition.block","punctuation.separator","punctuation.terminator"],settings:{foreground:"var(--color-syntax-punctuation)"}},{scope:["entity.name.type","support.type","support.class","entity.other.inherited-class"],settings:{foreground:"var(--color-syntax-type)"}}]},we={typescript:()=>import('@shikijs/langs/typescript'),javascript:()=>import('@shikijs/langs/javascript'),tsx:()=>import('@shikijs/langs/tsx'),jsx:()=>import('@shikijs/langs/jsx'),html:()=>import('@shikijs/langs/html'),css:()=>import('@shikijs/langs/css'),json:()=>import('@shikijs/langs/json'),markdown:()=>import('@shikijs/langs/markdown'),python:()=>import('@shikijs/langs/python'),rust:()=>import('@shikijs/langs/rust'),go:()=>import('@shikijs/langs/go'),java:()=>import('@shikijs/langs/java'),c:()=>import('@shikijs/langs/c'),cpp:()=>import('@shikijs/langs/cpp'),csharp:()=>import('@shikijs/langs/csharp'),vue:()=>import('@shikijs/langs/vue'),xml:()=>import('@shikijs/langs/xml'),yaml:()=>import('@shikijs/langs/yaml'),sql:()=>import('@shikijs/langs/sql'),bash:()=>import('@shikijs/langs/bash'),shell:()=>import('@shikijs/langs/shell')},z=null,W=new Set;function Te(){return z||(z=Promise.all([import('shiki/core'),import('shiki/engine/javascript')]).then(([{createHighlighterCore:e},{createJavaScriptRegexEngine:t}])=>e({themes:[ke],langs:[],engine:t()}))),z}async function Ne(e,t,r){let s=await Te();if(t&&!W.has(t)){let n=we[t];if(n)try{let l=await n();await s.loadLanguage(l.default??l),W.add(t);}catch{t="text";}else t="text";}let a=s.codeToHtml(e,{lang:t||"text",theme:"onyx-css-vars"});if(a=a.replace(/(<pre [^>]*style=")/,"$1line-height:1.7;tab-size:2;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;"),r){let n=0;a=a.replace(/<span class="line">/g,()=>(n++,`<span class="line"><span class="line-number" data-line="${n}"></span>`));}return a}function B({code:e,language:t="text",lineNumbers:r=false,editable:s=false,onCodeChange:a,size:n,className:l,...c}){let[o,y]=L.useState(""),g=L.useRef(null),b=L.useRef(null),d=L.useRef(null);L.useEffect(()=>{let p=false;return Ne(e,t,s?false:r).then(m=>{p||y(m);}),()=>{p=true;}},[e,t,r,s]);let T=L.useCallback(()=>{let p=b.current,m=d.current?.querySelector("pre"),R=g.current?.querySelector("[data-gutter]");p&&m&&(m.scrollTop=p.scrollTop,m.scrollLeft=p.scrollLeft),p&&R&&(R.scrollTop=p.scrollTop);},[]),u=L.useCallback(p=>{a?.(p.target.value);},[a]),f=L.useCallback(p=>{if(p.key==="Tab"){p.preventDefault();let m=p.currentTarget,R=m.selectionStart,re=m.selectionEnd,ae=m.value.substring(0,R)+" "+m.value.substring(re);a?.(ae),requestAnimationFrame(()=>{m.selectionStart=m.selectionEnd=R+2;});}},[a]),h=r&&"[&_.line-number]:inline-block [&_.line-number]:w-8 [&_.line-number]:mr-4 [&_.line-number]:text-right [&_.line-number]:text-secondary-400 [&_.line-number]:select-none [&_.line-number]:before:content-[attr(data-line)]",K="ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace",U=1.7,te=e.split(`
2
- `).length;return s?jsxRuntime.jsxs("div",{ref:g,className:i(V({size:n}),"flex border border-primary-200 dark:border-primary-700",l),style:{background:"var(--color-syntax-bg)"},...c,children:[r&&jsxRuntime.jsx("div",{"data-gutter":true,"aria-hidden":true,className:"shrink-0 select-none overflow-hidden py-4 pl-3 pr-1 text-right text-secondary-400",style:{fontFamily:K,lineHeight:U,width:"3rem"},children:Array.from({length:te},(p,m)=>jsxRuntime.jsx("div",{children:m+1},m))}),jsxRuntime.jsxs("div",{className:"relative min-w-0 flex-1",children:[jsxRuntime.jsx("textarea",{ref:b,value:e,onChange:u,onScroll:T,onKeyDown:f,spellCheck:false,autoCapitalize:"off",autoComplete:"off",autoCorrect:"off",className:"relative z-2 m-0 block h-full w-full resize-none overflow-auto whitespace-pre border-none bg-transparent p-4 text-transparent caret-primary-600 outline-none dark:caret-primary-400",style:{fontFamily:K,lineHeight:U,tabSize:2,minHeight:"6rem"}}),jsxRuntime.jsx("div",{ref:d,"aria-hidden":true,className:"pointer-events-none absolute inset-0 z-1 overflow-hidden [&_pre]:m-0 [&_pre]:h-full [&_pre]:overflow-hidden [&_pre]:p-4 [&_code]:bg-transparent",dangerouslySetInnerHTML:o?{__html:o}:void 0})]})]}):jsxRuntime.jsx("div",{ref:g,className:i(V({size:n}),"border border-primary-200 dark:border-primary-700",h,l),style:{background:"var(--color-syntax-bg)"},...c,children:jsxRuntime.jsx("div",{ref:d,className:"[&_pre]:m-0 [&_pre]:p-4",dangerouslySetInnerHTML:o?{__html:o}:void 0,children:o?void 0:jsxRuntime.jsx("pre",{className:"m-0 p-4",style:{background:"var(--color-syntax-bg)"},children:jsxRuntime.jsx("code",{children:e})})})})}var _e={up:lucideReact.TrendingUp,down:lucideReact.TrendingDown,neutral:lucideReact.Minus},Ke={up:"text-success-600 dark:text-success-400",down:"text-danger-600 dark:text-danger-400",neutral:"text-secondary-500 dark:text-secondary-400"};function F({title:e,value:t,prefix:r,suffix:s,icon:a,trend:n,trendValue:l,description:c,intent:o,size:y,className:g}){let b=n?_e[n]:null,d=n?Ke[n]:"";return jsxRuntime.jsx("div",{className:i($({intent:o,size:y}),g),children:jsxRuntime.jsxs("div",{className:"flex items-start justify-between gap-3",children:[jsxRuntime.jsxs("div",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("p",{className:"truncate text-xs font-medium tracking-wider uppercase text-secondary-500 dark:text-secondary-400",children:e}),jsxRuntime.jsxs("p",{className:"mt-1 flex items-baseline gap-1 text-2xl font-bold text-primary-900 dark:text-primary-50",children:[r&&jsxRuntime.jsx("span",{className:"text-base font-semibold text-secondary-500 dark:text-secondary-400",children:r}),jsxRuntime.jsx("span",{children:t}),s&&jsxRuntime.jsx("span",{className:"text-base font-semibold text-secondary-500 dark:text-secondary-400",children:s})]}),(n||c)&&jsxRuntime.jsxs("div",{className:"mt-2 flex items-center gap-2",children:[n&&b&&jsxRuntime.jsxs("span",{className:i("flex items-center gap-0.5 text-xs font-semibold",d),children:[jsxRuntime.jsx(b,{className:"h-3.5 w-3.5"}),l]}),c&&jsxRuntime.jsx("span",{className:"text-xs text-secondary-500 dark:text-secondary-400",children:c})]})]}),a&&jsxRuntime.jsx("div",{className:i("flex h-10 w-10 shrink-0 items-center justify-center rounded-xl [&_svg]:h-5 [&_svg]:w-5",o==="success"&&"bg-success-100 text-success-600 dark:bg-success-900/30 dark:text-success-400",o==="danger"&&"bg-danger-100 text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",o==="warning"&&"bg-warning-100 text-warning-600 dark:bg-warning-900/30 dark:text-warning-400",(!o||o==="primary")&&"bg-primary-100 text-primary-600 dark:bg-primary-800 dark:text-primary-400"),children:a})]})})}function Ee(e){return 1-Math.pow(1-e,4)}function De(e,t,r,s,a){let[n,l]=L.useState(()=>a?a(t):t.toFixed(s)),c=L.useRef(null),o=L.useRef(null);return L.useEffect(()=>{c.current!==null&&cancelAnimationFrame(c.current),o.current=null;let y=g=>{o.current===null&&(o.current=g);let b=g-o.current,d=Math.min(b/r,1),T=Ee(d),u=t+(e-t)*T;l(a?a(u):u.toFixed(s)),d<1&&(c.current=requestAnimationFrame(y));};return c.current=requestAnimationFrame(y),()=>{c.current!==null&&cancelAnimationFrame(c.current);}},[e,t,r,s,a]),n}var Ae={up:lucideReact.TrendingUp,down:lucideReact.TrendingDown,neutral:lucideReact.Minus},Ie={up:"text-success-600 dark:text-success-400",down:"text-danger-600 dark:text-danger-400",neutral:"text-secondary-500 dark:text-secondary-400"},ee={primary:"bg-primary-100 text-primary-600 dark:bg-primary-800/60 dark:text-primary-300",success:"bg-success-100 text-success-600 dark:bg-success-900/30 dark:text-success-400",danger:"bg-danger-100 text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",warning:"bg-warning-100 text-warning-600 dark:bg-warning-900/30 dark:text-warning-400"};function j({title:e,value:t,decimals:r=0,prefix:s,suffix:a,icon:n,trend:l,trendValue:c,description:o,animateDuration:y=1200,formatter:g,from:b=0,intent:d,size:T,className:u}){let f=De(t,b,y,r,g),h=l?Ae[l]:null,K=l?Ie[l]:"";return jsxRuntime.jsxs("div",{className:i(G({intent:d,size:T}),u),children:[jsxRuntime.jsx("div",{className:i("pointer-events-none absolute inset-x-0 top-0 h-0.5 rounded-t-xl",d==="success"&&"bg-gradient-to-r from-success-400 to-success-600",d==="danger"&&"bg-gradient-to-r from-danger-400 to-danger-600",d==="warning"&&"bg-gradient-to-r from-warning-400 to-warning-600",(!d||d==="primary")&&"bg-gradient-to-r from-primary-400 to-primary-600")}),jsxRuntime.jsxs("div",{className:"flex items-start justify-between gap-4",children:[jsxRuntime.jsxs("div",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("p",{className:"text-xs font-semibold tracking-widest uppercase text-secondary-500 dark:text-secondary-400",children:e}),jsxRuntime.jsxs("p",{className:"mt-2 flex items-baseline gap-1",children:[s&&jsxRuntime.jsx("span",{className:"text-lg font-semibold text-secondary-400 dark:text-secondary-500",children:s}),jsxRuntime.jsx("span",{className:"font-mono text-3xl font-bold tabular-nums text-primary-900 dark:text-primary-50",children:f}),a&&jsxRuntime.jsx("span",{className:"text-lg font-semibold text-secondary-400 dark:text-secondary-500",children:a})]})]}),n&&jsxRuntime.jsx("div",{className:i("flex h-12 w-12 shrink-0 items-center justify-center rounded-2xl [&_svg]:h-6 [&_svg]:w-6",ee[d??"primary"]??ee.primary),children:n})]}),(l||o)&&jsxRuntime.jsxs("div",{className:"mt-3 flex items-center gap-2 border-t border-primary-100 pt-3 dark:border-primary-700/50",children:[l&&h&&jsxRuntime.jsxs("span",{className:i("flex items-center gap-0.5 text-xs font-bold",K),children:[jsxRuntime.jsx(h,{className:"h-3.5 w-3.5"}),c]}),o&&jsxRuntime.jsx("span",{className:"text-xs text-secondary-500 dark:text-secondary-400",children:o})]})]})}var ze={Table:P,List:M,Tree:H,Chat:D,CodeBlock:B,Stat:F,MetricCard:j},or=ze;exports.Chat=D;exports.CodeBlock=B;exports.DataDisplay=ze;exports.List=M;exports.MetricCard=j;exports.Stat=F;exports.Table=P;exports.Tree=H;exports.default=or;
1
+ 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var re=require('react'),lucideReact=require('lucide-react'),clsx=require('clsx'),tailwindMerge=require('tailwind-merge'),classVarianceAuthority=require('class-variance-authority'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var re__default=/*#__PURE__*/_interopDefault(re);function f(...r){return tailwindMerge.twMerge(clsx.clsx(r))}var ke=classVarianceAuthority.cva("w-full text-left text-sm",{variants:{intent:{default:"",striped:"[&_tbody_tr:nth-child(even)]:bg-primary-50 dark:[&_tbody_tr:nth-child(even)]:bg-primary-800/30",bordered:"[&_th]:border [&_td]:border [&_th]:border-primary-200 [&_td]:border-primary-200 dark:[&_th]:border-primary-700 dark:[&_td]:border-primary-700"},density:{compact:"[&_th]:px-2 [&_th]:py-1 [&_td]:px-2 [&_td]:py-1",default:"",relaxed:"[&_th]:px-6 [&_th]:py-5 [&_td]:px-6 [&_td]:py-5"}},defaultVariants:{intent:"default",density:"default"}}),Te=classVarianceAuthority.cva("text-sm text-primary-700 dark:text-primary-300",{variants:{intent:{default:"space-y-1",bordered:"divide-y divide-primary-200 rounded-lg border border-primary-200 dark:divide-primary-700 dark:border-primary-700 [&>li]:px-4 [&>li]:py-2",hover:"[&>li]:rounded-md [&>li]:px-3 [&>li]:py-2 [&>li]:transition-colors [&>li:hover]:bg-primary-50 dark:[&>li:hover]:bg-primary-800/50"}},defaultVariants:{intent:"default"}});classVarianceAuthority.cva("group flex w-full items-center gap-1.5 text-left [&_svg]:shrink-0",{variants:{size:{sm:"py-0.5 text-xs [&_svg]:h-3 [&_svg]:w-3",md:"py-1.5 text-sm [&_svg]:h-3.5 [&_svg]:w-3.5",lg:"py-2 text-base [&_svg]:h-4 [&_svg]:w-4"}},defaultVariants:{size:"md"}});classVarianceAuthority.cva("flex cursor-pointer items-center gap-1 rounded transition-colors [&_svg]:shrink-0",{variants:{size:{sm:"py-0.5 text-xs [&_svg]:h-3.5 [&_svg]:w-3.5",md:"py-1 text-sm [&_svg]:h-4 [&_svg]:w-4",lg:"py-1.5 text-base [&_svg]:h-5 [&_svg]:w-5"}},defaultVariants:{size:"md"}});var Ne=classVarianceAuthority.cva("relative rounded-xl border bg-white p-5 shadow-sm transition-shadow hover:shadow-md dark:bg-primary-900",{variants:{intent:{primary:"border-primary-200 dark:border-primary-700",success:"border-success-200 dark:border-success-800",danger:"border-danger-200 dark:border-danger-800",warning:"border-warning-200 dark:border-warning-800"},size:{sm:"p-4",md:"p-5",lg:"p-6"}},defaultVariants:{intent:"primary",size:"md"}}),Re=classVarianceAuthority.cva("relative overflow-hidden rounded-xl border bg-white p-5 shadow-sm transition-all duration-300 hover:shadow-lg dark:bg-primary-900",{variants:{intent:{primary:"border-primary-200 dark:border-primary-700",success:"border-success-200 dark:border-success-800",danger:"border-danger-200 dark:border-danger-800",warning:"border-warning-200 dark:border-warning-800"},size:{sm:"p-4",md:"p-5",lg:"p-6"}},defaultVariants:{intent:"primary",size:"md"}}),le=classVarianceAuthority.cva("overflow-x-auto rounded-lg font-mono [background:var(--color-syntax-bg)] [&_pre]:m-0 [&_pre]:p-4 [&_code]:bg-transparent",{variants:{size:{sm:"text-xs",md:"text-sm",lg:"text-base"}},defaultVariants:{size:"md"}});function ce({intent:r,density:a,className:t,...o}){return jsxRuntime.jsx("div",{className:"w-full overflow-auto",children:jsxRuntime.jsx("table",{className:f(ke({intent:r,density:a}),t),...o})})}var Be=re.createContext({size:"md"});function de({intent:r,size:a="md",className:t,...o}){return jsxRuntime.jsx(Be.Provider,{value:{size:a},children:jsxRuntime.jsx("ul",{className:f(Te({intent:r}),t),...o})})}var Ue=re.createContext({showLines:true,expandedKeys:null,onToggleKey:()=>{},size:"md"});function me({showLines:r=true,showRoot:a=true,expandedKeys:t,defaultExpandedKeys:o="all",onExpandedKeysChange:s,size:c="md",className:i,children:g,...d}){let [T,w]=re.useState(()=>o),u=re.useCallback(p=>{if(t){let b=new Set(t);b.has(p)?b.delete(p):b.add(p),s?.(b);}else w(b=>{if(b==="all")return new Set(["__ALL_MINUS__",p]);let y=new Set(b);return y.has(p)?y.delete(p):y.add(p),y});},[t,s]),m=t??(T==="all"?null:T);return jsxRuntime.jsx(Ue.Provider,{value:{showLines:r,expandedKeys:m,onToggleKey:u,size:c},children:a?jsxRuntime.jsx("ul",{className:f("text-sm",i),role:"tree",...d,children:g}):jsxRuntime.jsx("ul",{className:f("text-sm",i),role:"tree",...d,children:jsxRuntime.jsx(qe,{children:g})})})}function qe({children:r}){let a=Ce(r);return jsxRuntime.jsx(jsxRuntime.Fragment,{children:a.map(t=>re__default.default.isValidElement(t)&&t.props.children?t.props.children:null)})}function Ce(r){let a=[];return re__default.default.Children.forEach(r,t=>{re__default.default.isValidElement(t)&&t.type===re__default.default.Fragment?a.push(...Ce(t.props.children)):a.push(t);}),a}function $e({avatar:r,sender:a}){return r?typeof r=="string"?/^(?:https?|data|blob):/.test(r)?jsxRuntime.jsx("img",{src:r,alt:a,className:"h-8 w-8 shrink-0 rounded-full object-cover",draggable:false}):jsxRuntime.jsx("div",{className:"bg-primary-200 text-primary-600 dark:bg-primary-700 dark:text-primary-300 flex h-8 w-8 shrink-0 items-center justify-center rounded-full text-lg select-none",children:r}):jsxRuntime.jsx("div",{className:"flex h-8 w-8 shrink-0 items-center justify-center rounded-full",children:r}):jsxRuntime.jsx("div",{className:"bg-primary-200 text-primary-600 dark:bg-primary-700 dark:text-primary-300 flex h-8 w-8 shrink-0 items-center justify-center rounded-full text-sm font-semibold select-none",children:a.charAt(0).toUpperCase()})}function Ge({msg:r,alignRight:a}){return jsxRuntime.jsxs("div",{className:f("flex gap-2.5",a?"flex-row-reverse":"flex-row"),children:[jsxRuntime.jsx($e,{avatar:r.avatar,sender:r.sender}),jsxRuntime.jsxs("div",{className:f("flex max-w-[75%] flex-col gap-0.5",a?"items-end":"items-start"),children:[jsxRuntime.jsx("span",{className:"text-primary-500 dark:text-primary-400 text-xs",children:r.sender}),jsxRuntime.jsx("div",{className:f("rounded-xl px-3 py-2 text-sm leading-relaxed",a?"rounded-tr-sm bg-primary-500 text-white dark:bg-primary-600":"bg-primary-100 text-primary-800 dark:bg-primary-800 dark:text-primary-200 rounded-tl-sm"),children:r.content}),r.time&&jsxRuntime.jsx("span",{className:"text-primary-400 dark:text-primary-500 text-[10px]",children:r.time})]})]})}function ue({messages:r,mode:a="split",autoScroll:t=true,className:o,...s}){let c=re.useRef(null);return re.useEffect(()=>{t&&c.current?.scrollIntoView({behavior:"smooth"});},[r,t]),jsxRuntime.jsxs("div",{className:f("flex flex-col gap-4 overflow-y-auto rounded-lg border p-4","border-primary-200 dark:border-primary-700 dark:bg-primary-900 bg-white",o),...s,children:[r.map(i=>{let g=a==="split"&&!!i.self;return jsxRuntime.jsx(Ge,{msg:i,alignRight:g},i.id)}),jsxRuntime.jsx("div",{ref:c})]})}var Ze={name:"onyx-css-vars",type:"dark",settings:[{settings:{foreground:"var(--color-syntax-plain)",background:"var(--color-syntax-bg)"}},{scope:["comment","punctuation.definition.comment"],settings:{foreground:"var(--color-syntax-comment)",fontStyle:"italic"}},{scope:["keyword","keyword.control","keyword.operator.new","keyword.operator.expression","storage.type","storage.modifier"],settings:{foreground:"var(--color-syntax-keyword)"}},{scope:["string","string.quoted","string.template"],settings:{foreground:"var(--color-syntax-string)"}},{scope:["entity.name.function","support.function","meta.function-call"],settings:{foreground:"var(--color-syntax-function)"}},{scope:["variable","variable.other","variable.parameter","meta.definition.variable"],settings:{foreground:"var(--color-syntax-variable)"}},{scope:["constant.numeric","constant.language"],settings:{foreground:"var(--color-syntax-number)"}},{scope:["keyword.operator","keyword.operator.assignment","keyword.operator.comparison","keyword.operator.arithmetic"],settings:{foreground:"var(--color-syntax-operator)"}},{scope:["entity.name.tag","punctuation.definition.tag","support.class.component"],settings:{foreground:"var(--color-syntax-tag)"}},{scope:["entity.other.attribute-name","meta.tag.attributes"],settings:{foreground:"var(--color-syntax-attr)"}},{scope:["punctuation","meta.brace","punctuation.definition.block","punctuation.separator","punctuation.terminator"],settings:{foreground:"var(--color-syntax-punctuation)"}},{scope:["entity.name.type","support.type","support.class","entity.other.inherited-class"],settings:{foreground:"var(--color-syntax-type)"}}]},et={typescript:()=>import('@shikijs/langs/typescript'),javascript:()=>import('@shikijs/langs/javascript'),tsx:()=>import('@shikijs/langs/tsx'),jsx:()=>import('@shikijs/langs/jsx'),html:()=>import('@shikijs/langs/html'),css:()=>import('@shikijs/langs/css'),json:()=>import('@shikijs/langs/json'),markdown:()=>import('@shikijs/langs/markdown'),python:()=>import('@shikijs/langs/python'),rust:()=>import('@shikijs/langs/rust'),go:()=>import('@shikijs/langs/go'),java:()=>import('@shikijs/langs/java'),c:()=>import('@shikijs/langs/c'),cpp:()=>import('@shikijs/langs/cpp'),csharp:()=>import('@shikijs/langs/csharp'),vue:()=>import('@shikijs/langs/vue'),xml:()=>import('@shikijs/langs/xml'),yaml:()=>import('@shikijs/langs/yaml'),sql:()=>import('@shikijs/langs/sql'),bash:()=>import('@shikijs/langs/bash'),shell:()=>import('@shikijs/langs/shell')},be=null,Ve=new Set;function tt(){return be||(be=Promise.all([import('shiki/core'),import('shiki/engine/javascript')]).then(([{createHighlighterCore:r},{createJavaScriptRegexEngine:a}])=>r({themes:[Ze],langs:[],engine:a()}))),be}async function rt(r,a,t){let o=await tt();if(a&&!Ve.has(a)){let c=et[a];if(c)try{let i=await c();await o.loadLanguage(i.default??i),Ve.add(a);}catch{a="text";}else a="text";}let s=o.codeToHtml(r,{lang:a||"text",theme:"onyx-css-vars"});if(s=s.replace(/(<pre [^>]*style=")/,"$1line-height:1.7;tab-size:2;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;"),t){let c=0;s=s.replace(/<span class="line">/g,()=>(c++,`<span class="line"><span class="line-number" data-line="${c}"></span>`));}return s}function ye({code:r,language:a="text",lineNumbers:t=false,editable:o=false,onCodeChange:s,size:c,className:i,...g}){let[d,T]=re.useState(""),w=re.useRef(null),N=re.useRef(null),u=re.useRef(null);re.useEffect(()=>{let v=false;return rt(r,a,o?false:t).then(x=>{v||T(x);}),()=>{v=true;}},[r,a,t,o]);let m=re.useCallback(()=>{let v=N.current,x=u.current?.querySelector("pre"),L=w.current?.querySelector("[data-gutter]");v&&x&&(x.scrollTop=v.scrollTop,x.scrollLeft=v.scrollLeft),v&&L&&(L.scrollTop=v.scrollTop);},[]),p=re.useCallback(v=>{s?.(v.target.value);},[s]),b=re.useCallback(v=>{if(v.key==="Tab"){v.preventDefault();let x=v.currentTarget,L=x.selectionStart,O=x.selectionEnd,P=x.value.substring(0,L)+" "+x.value.substring(O);s?.(P),requestAnimationFrame(()=>{x.selectionStart=x.selectionEnd=L+2;});}},[s]),y=t&&"[&_.line-number]:inline-block [&_.line-number]:w-8 [&_.line-number]:mr-4 [&_.line-number]:text-right [&_.line-number]:text-secondary-400 [&_.line-number]:select-none [&_.line-number]:before:content-[attr(data-line)]",k="ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace",I=1.7,S=r.split(`
2
+ `).length;return o?jsxRuntime.jsxs("div",{ref:w,className:f(le({size:c}),"flex border border-primary-200 dark:border-primary-700",i),style:{background:"var(--color-syntax-bg)"},...g,children:[t&&jsxRuntime.jsx("div",{"data-gutter":true,"aria-hidden":true,className:"shrink-0 select-none overflow-hidden py-4 pl-3 pr-1 text-right text-secondary-400",style:{fontFamily:k,lineHeight:I,width:"3rem"},children:Array.from({length:S},(v,x)=>jsxRuntime.jsx("div",{children:x+1},x))}),jsxRuntime.jsxs("div",{className:"relative min-w-0 flex-1",children:[jsxRuntime.jsx("textarea",{ref:N,value:r,onChange:p,onScroll:m,onKeyDown:b,spellCheck:false,autoCapitalize:"off",autoComplete:"off",autoCorrect:"off",className:"relative z-2 m-0 block h-full w-full resize-none overflow-auto whitespace-pre border-none bg-transparent p-4 text-transparent caret-primary-600 outline-none dark:caret-primary-400",style:{fontFamily:k,lineHeight:I,tabSize:2,minHeight:"6rem"}}),jsxRuntime.jsx("div",{ref:u,"aria-hidden":true,className:"pointer-events-none absolute inset-0 z-1 overflow-hidden [&_pre]:m-0 [&_pre]:h-full [&_pre]:overflow-hidden [&_pre]:p-4 [&_code]:bg-transparent",dangerouslySetInnerHTML:d?{__html:d}:void 0})]})]}):jsxRuntime.jsx("div",{ref:w,className:f(le({size:c}),"border border-primary-200 dark:border-primary-700",y,i),style:{background:"var(--color-syntax-bg)"},...g,children:jsxRuntime.jsx("div",{ref:u,className:"[&_pre]:m-0 [&_pre]:p-4",dangerouslySetInnerHTML:d?{__html:d}:void 0,children:d?void 0:jsxRuntime.jsx("pre",{className:"m-0 p-4",style:{background:"var(--color-syntax-bg)"},children:jsxRuntime.jsx("code",{children:r})})})})}var ot={up:lucideReact.TrendingUp,down:lucideReact.TrendingDown,neutral:lucideReact.Minus},it={up:"text-success-600 dark:text-success-400",down:"text-danger-600 dark:text-danger-400",neutral:"text-secondary-500 dark:text-secondary-400"};function xe({title:r,value:a,prefix:t,suffix:o,icon:s,trend:c,trendValue:i,description:g,intent:d,size:T,className:w}){let N=c?ot[c]:null,u=c?it[c]:"";return jsxRuntime.jsx("div",{className:f(Ne({intent:d,size:T}),w),children:jsxRuntime.jsxs("div",{className:"flex items-start justify-between gap-3",children:[jsxRuntime.jsxs("div",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("p",{className:"truncate text-xs font-medium tracking-wider uppercase text-secondary-500 dark:text-secondary-400",children:r}),jsxRuntime.jsxs("p",{className:"mt-1 flex items-baseline gap-1 text-2xl font-bold text-primary-900 dark:text-primary-50",children:[t&&jsxRuntime.jsx("span",{className:"text-base font-semibold text-secondary-500 dark:text-secondary-400",children:t}),jsxRuntime.jsx("span",{children:a}),o&&jsxRuntime.jsx("span",{className:"text-base font-semibold text-secondary-500 dark:text-secondary-400",children:o})]}),(c||g)&&jsxRuntime.jsxs("div",{className:"mt-2 flex items-center gap-2",children:[c&&N&&jsxRuntime.jsxs("span",{className:f("flex items-center gap-0.5 text-xs font-semibold",u),children:[jsxRuntime.jsx(N,{className:"h-3.5 w-3.5"}),i]}),g&&jsxRuntime.jsx("span",{className:"text-xs text-secondary-500 dark:text-secondary-400",children:g})]})]}),s&&jsxRuntime.jsx("div",{className:f("flex h-10 w-10 shrink-0 items-center justify-center rounded-xl [&_svg]:h-5 [&_svg]:w-5",d==="success"&&"bg-success-100 text-success-600 dark:bg-success-900/30 dark:text-success-400",d==="danger"&&"bg-danger-100 text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",d==="warning"&&"bg-warning-100 text-warning-600 dark:bg-warning-900/30 dark:text-warning-400",(!d||d==="primary")&&"bg-primary-100 text-primary-600 dark:bg-primary-800 dark:text-primary-400"),children:s})]})})}function ut(r){return 1-Math.pow(1-r,4)}function ft(r,a,t,o,s){let[c,i]=re.useState(()=>s?s(a):a.toFixed(o)),g=re.useRef(null),d=re.useRef(null);return re.useEffect(()=>{g.current!==null&&cancelAnimationFrame(g.current),d.current=null;let T=w=>{d.current===null&&(d.current=w);let N=w-d.current,u=Math.min(N/t,1),m=ut(u),p=a+(r-a)*m;i(s?s(p):p.toFixed(o)),u<1&&(g.current=requestAnimationFrame(T));};return g.current=requestAnimationFrame(T),()=>{g.current!==null&&cancelAnimationFrame(g.current);}},[r,a,t,o,s]),c}var gt={up:lucideReact.TrendingUp,down:lucideReact.TrendingDown,neutral:lucideReact.Minus},bt={up:"text-success-600 dark:text-success-400",down:"text-danger-600 dark:text-danger-400",neutral:"text-secondary-500 dark:text-secondary-400"},Pe={primary:"bg-primary-100 text-primary-600 dark:bg-primary-800/60 dark:text-primary-300",success:"bg-success-100 text-success-600 dark:bg-success-900/30 dark:text-success-400",danger:"bg-danger-100 text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",warning:"bg-warning-100 text-warning-600 dark:bg-warning-900/30 dark:text-warning-400"};function he({title:r,value:a,decimals:t=0,prefix:o,suffix:s,icon:c,trend:i,trendValue:g,description:d,animateDuration:T=1200,formatter:w,from:N=0,intent:u,size:m,className:p}){let b=ft(a,N,T,t,w),y=i?gt[i]:null,k=i?bt[i]:"";return jsxRuntime.jsxs("div",{className:f(Re({intent:u,size:m}),p),children:[jsxRuntime.jsx("div",{className:f("pointer-events-none absolute inset-x-0 top-0 h-0.5 rounded-t-xl",u==="success"&&"bg-gradient-to-r from-success-400 to-success-600",u==="danger"&&"bg-gradient-to-r from-danger-400 to-danger-600",u==="warning"&&"bg-gradient-to-r from-warning-400 to-warning-600",(!u||u==="primary")&&"bg-gradient-to-r from-primary-400 to-primary-600")}),jsxRuntime.jsxs("div",{className:"flex items-start justify-between gap-4",children:[jsxRuntime.jsxs("div",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("p",{className:"text-xs font-semibold tracking-widest uppercase text-secondary-500 dark:text-secondary-400",children:r}),jsxRuntime.jsxs("p",{className:"mt-2 flex items-baseline gap-1",children:[o&&jsxRuntime.jsx("span",{className:"text-lg font-semibold text-secondary-400 dark:text-secondary-500",children:o}),jsxRuntime.jsx("span",{className:"font-mono text-3xl font-bold tabular-nums text-primary-900 dark:text-primary-50",children:b}),s&&jsxRuntime.jsx("span",{className:"text-lg font-semibold text-secondary-400 dark:text-secondary-500",children:s})]})]}),c&&jsxRuntime.jsx("div",{className:f("flex h-12 w-12 shrink-0 items-center justify-center rounded-2xl [&_svg]:h-6 [&_svg]:w-6",Pe[u??"primary"]??Pe.primary),children:c})]}),(i||d)&&jsxRuntime.jsxs("div",{className:"mt-3 flex items-center gap-2 border-t border-primary-100 pt-3 dark:border-primary-700/50",children:[i&&y&&jsxRuntime.jsxs("span",{className:f("flex items-center gap-0.5 text-xs font-bold",k),children:[jsxRuntime.jsx(y,{className:"h-3.5 w-3.5"}),g]}),d&&jsxRuntime.jsx("span",{className:"text-xs text-secondary-500 dark:text-secondary-400",children:d})]})]})}var He="onyx-vlist:";function _e(r,a){let t=0,o=r.length-2;for(;t<=o;){let s=t+o>>1;if(r[s+1]<=a)t=s+1;else if(r[s]>a)o=s-1;else return s}return Math.max(0,t)}function Ke(r,a){let{items:t,itemHeight:o,estimatedItemHeight:s=48,direction:c="vertical",overscan:i=3,onReachEnd:g,reachEndThreshold:d=120,isLoading:T,onScroll:w,onVisibleRangeChange:N,scrollRestorationId:u}=r,m=c==="vertical",p=typeof o=="number",b=p?o:0,y=re.useRef(null),[k,I]=re.useState(300);re.useEffect(()=>{let e=y.current;if(!e)return;let n=new ResizeObserver(([V])=>{let E=m?V.contentRect.height:V.contentRect.width;E>0&&I(E);});n.observe(e);let l=e.getBoundingClientRect(),h=m?l.height:l.width;return h>0&&I(h),()=>n.disconnect()},[m]);let[S,v]=re.useState(0);re.useEffect(()=>{if(!u)return;let e=y.current;if(e)try{let n=localStorage.getItem(He+u);if(n!==null){let l=parseFloat(n);!Number.isNaN(l)&&l>0&&requestAnimationFrame(()=>{m?e.scrollTop=l:e.scrollLeft=l;});}}catch{}},[]);let x=re.useRef(false),L=re.useRef(t.length);t.length!==L.current&&(L.current=t.length,x.current=false);let O=re.useCallback(()=>{let e=y.current;if(!e)return;let n=m?e.scrollTop:e.scrollLeft;if(v(n),w?.(n),u)try{localStorage.setItem(He+u,String(n));}catch{}g&&!T&&(m?e.scrollHeight-e.clientHeight:e.scrollWidth-e.clientWidth)-n<=d&&(x.current||(x.current=true,g()));},[m,w,u,g,T,d]);re.useEffect(()=>{let e=y.current;if(e)return e.addEventListener("scroll",O,{passive:true}),()=>e.removeEventListener("scroll",O)},[O]),re.useEffect(()=>{if(m)return;let e=y.current;if(!e)return;let n=l=>{Math.abs(l.deltaX)>=Math.abs(l.deltaY)||(l.preventDefault(),e.scrollLeft+=l.deltaY);};return e.addEventListener("wheel",n,{passive:false}),()=>e.removeEventListener("wheel",n)},[m]),re.useEffect(()=>{if(m)return;let e=y.current;if(!e)return;let n=5,l=false,h=false,V=0,E=0,Q=z=>{z.target.closest("button,a,input,select,textarea,[role=button],[role=checkbox],[role=radio],[role=option]")||z.button===0&&(l=true,h=false,V=z.clientX,E=e.scrollLeft,e.setPointerCapture(z.pointerId));},_=z=>{if(!l)return;let ie=V-z.clientX;if(!h){if(Math.abs(ie)<n)return;h=true,e.style.cursor="grabbing",e.style.userSelect="none";}e.scrollLeft=E+ie;},te=z=>{if(l){l=false,e.style.cursor="",e.style.userSelect="";try{e.releasePointerCapture(z.pointerId);}catch{}}};return e.addEventListener("pointerdown",Q),e.addEventListener("pointermove",_),e.addEventListener("pointerup",te),e.addEventListener("pointercancel",te),()=>{e.removeEventListener("pointerdown",Q),e.removeEventListener("pointermove",_),e.removeEventListener("pointerup",te),e.removeEventListener("pointercancel",te);}},[m]);let P=re.useRef(new Map),[ee,se]=re.useState(0),oe=re.useCallback((e,n)=>{if(p||!n)return;let l=m?n.offsetHeight:n.offsetWidth;l>0&&P.current.get(e)!==l&&(P.current.set(e,l),se(h=>h+1));},[p,m]),Y=re.useRef(t);Y.current!==t&&(Y.current=t,p||(P.current=new Map));let C=re.useMemo(()=>{if(p)return [];let e=new Array(t.length+1);e[0]=0;for(let n=0;n<t.length;n++){let l=P.current.get(n),h;l!==void 0?h=l:typeof o=="function"?h=t[n]!==void 0?o(t[n],n):s:h=s,e[n+1]=e[n]+h;}return e},[p,t,o,s,ee]),R=re.useCallback(e=>p?e*b:C[e]??0,[p,b,C]),j=re.useCallback(e=>{if(p)return b;let n=P.current.get(e);return n!==void 0?n:typeof o=="function"&&t[e]!==void 0?o(t[e],e):s},[p,b,o,t,s,ee]),$,H,D;if(p){$=b*t.length;let e=Math.floor(S/b),n=Math.ceil((S+k)/b);H=Math.max(0,e-i),D=Math.min(t.length-1,n+i-1);}else if($=C[t.length]??0,C.length>1){let e=_e(C,S);H=Math.max(0,e-i);let n=e;for(;n<t.length&&C[n]<S+k;)n++;D=Math.min(t.length-1,n+i-1);}else H=0,D=Math.min(t.length-1,i*2);H=Math.max(0,H),D=Math.max(H,Math.min(t.length-1,D));let G=re.useRef({start:-1,end:-1});return re.useEffect(()=>{let e,n;if(p&&b>0)e=Math.max(0,Math.floor(S/b)),n=Math.min(t.length-1,Math.ceil((S+k)/b)-1);else {for(e=_e(C,S),n=e;n<t.length&&C[n]<S+k;)n++;n=Math.max(0,n-1);}(G.current.start!==e||G.current.end!==n)&&(G.current={start:e,end:n},N?.(e,n));}),re.useImperativeHandle(a,()=>({scrollToIndex(e,n="auto"){let l=y.current;if(!l)return;let h=R(e),V=j(e),E=m?l.clientHeight:l.clientWidth,Q=m?l.scrollTop:l.scrollLeft,_;if(n==="start")_=h;else if(n==="end")_=h-E+V;else if(n==="center")_=h-(E-V)/2;else if(h<Q)_=h;else if(h+V>Q+E)_=h-E+V;else return;l.scrollTo({[m?"top":"left"]:Math.max(0,_),behavior:"smooth"});},scrollToOffset(e){let n=y.current;n&&n.scrollTo({[m?"top":"left"]:e,behavior:"smooth"});},getScrollOffset(){let e=y.current;return e?m?e.scrollTop:e.scrollLeft:0}}),[R,j,m]),{scrollerRef:y,startIndex:H,endIndex:D,totalSize:$,getItemOffset:R,getItemSize:j,measureItem:oe}}function vt({text:r="Loading\u2026"}){return jsxRuntime.jsxs("div",{className:"flex items-center justify-center gap-2 py-4 text-sm text-primary-400",children:[jsxRuntime.jsx("span",{"aria-hidden":true,className:"h-4 w-4 animate-spin rounded-full border-2 border-primary-200 border-t-primary-500"}),jsxRuntime.jsx("span",{children:r})]})}function wt({text:r="No items"}){return jsxRuntime.jsxs("div",{className:"flex h-full min-h-[120px] flex-col items-center justify-center gap-2 text-sm text-primary-400",children:[jsxRuntime.jsx("svg",{"aria-hidden":true,xmlns:"http://www.w3.org/2000/svg",className:"h-8 w-8 opacity-40",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",strokeWidth:1.5,children:jsxRuntime.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M20 13V6a2 2 0 00-2-2H6a2 2 0 00-2 2v7m16 0v5a2 2 0 01-2 2H6a2 2 0 01-2-2v-5m16 0h-2.586a1 1 0 00-.707.293l-2.414 2.414a1 1 0 01-.707.293h-3.172a1 1 0 01-.707-.293l-2.414-2.414A1 1 0 006.586 13H4"})}),jsxRuntime.jsx("span",{children:r})]})}function kt(r,a){let{items:t,renderItem:o,getItemKey:s,itemHeight:c,direction:i="vertical",height:g="100%",width:d="100%",isLoading:T=false,loadingRenderer:w,loadingText:N,emptyRenderer:u,emptyText:m,itemClassName:p,className:b,style:y}=r,k=i==="vertical",I=typeof c!="number",{scrollerRef:S,startIndex:v,endIndex:x,totalSize:L,getItemOffset:O,getItemSize:P,measureItem:ee}=Ke(r,a),se={position:"relative",overflowX:k?"hidden":"auto",overflowY:k?"auto":"hidden",height:g,width:d,cursor:k?void 0:"grab"},oe={position:"relative",[k?"height":"width"]:L,[k?"width":"height"]:"100%",overflow:"hidden"},Y=[];for(let R=v;R<=x;R++){let j=t[R];if(j===void 0)continue;let $=O(R),H=P(R),D=s?s(j,R):R,G={position:"absolute",[k?"top":"left"]:$,[k?"height":"width"]:I?void 0:H,[k?"width":"height"]:"100%",boxSizing:"border-box"};Y.push(jsxRuntime.jsx("div",{role:"row","aria-rowindex":R+1,style:G,className:f("onyx-vlist-item",p),ref:I?e=>ee(R,e):void 0,children:o(j,R)},D));}let C=t.length===0;return jsxRuntime.jsxs("div",{ref:S,role:"grid","aria-rowcount":t.length,"data-virtual-list":true,"data-direction":i,className:f("onyx-virtual-list",b),style:{...se,...y},children:[C?u?u():jsxRuntime.jsx(wt,{text:m}):jsxRuntime.jsx("div",{style:oe,children:Y}),T&&(w?w():jsxRuntime.jsx(vt,{text:N}))]})}var ae=re.forwardRef(kt);var Tt={Table:ce,List:de,Tree:me,Chat:ue,CodeBlock:ye,Stat:xe,MetricCard:he,VirtualList:ae},an=Tt;
3
+ exports.Chat=ue;exports.CodeBlock=ye;exports.DataDisplay=Tt;exports.List=de;exports.MetricCard=he;exports.Stat=xe;exports.Table=ce;exports.Tree=me;exports.VirtualList=ae;exports.default=an;
@@ -0,0 +1 @@
1
+ [data-virtual-list]{-webkit-overflow-scrolling:touch;scroll-behavior:auto;outline:none}.onyx-vlist-item{will-change:transform;contain:layout style}[data-virtual-list][data-direction=horizontal]{cursor:grab}[data-virtual-list]::-webkit-scrollbar{width:6px;height:6px}[data-virtual-list]::-webkit-scrollbar-track{background:transparent}[data-virtual-list]::-webkit-scrollbar-thumb{border-radius:9999px;background-color:color-mix(in srgb,currentColor 25%,transparent)}[data-virtual-list]::-webkit-scrollbar-thumb:hover{background-color:color-mix(in srgb,currentColor 40%,transparent)}
@@ -9,5 +9,10 @@ export { StatTrend_alias_1 as StatTrend } from '../_tsup-dts-rollup.cjs';
9
9
  export { MetricCard_alias_1 as MetricCard } from '../_tsup-dts-rollup.cjs';
10
10
  export { MetricCardProps_alias_1 as MetricCardProps } from '../_tsup-dts-rollup.cjs';
11
11
  export { MetricCardTrend_alias_1 as MetricCardTrend } from '../_tsup-dts-rollup.cjs';
12
+ export { VirtualList_alias_1 as VirtualList } from '../_tsup-dts-rollup.cjs';
13
+ export { VirtualListHandle_alias_1 as VirtualListHandle } from '../_tsup-dts-rollup.cjs';
14
+ export { VirtualListProps_alias_1 as VirtualListProps } from '../_tsup-dts-rollup.cjs';
15
+ export { VirtualListAlign_alias_1 as VirtualListAlign } from '../_tsup-dts-rollup.cjs';
16
+ export { VirtualListDirection_alias_1 as VirtualListDirection } from '../_tsup-dts-rollup.cjs';
12
17
  export { DataDisplay_alias_1 as DataDisplay } from '../_tsup-dts-rollup.cjs';
13
18
  export { default_alias_2 as default } from '../_tsup-dts-rollup.cjs';
@@ -9,5 +9,10 @@ export { StatTrend_alias_1 as StatTrend } from '../_tsup-dts-rollup.js';
9
9
  export { MetricCard_alias_1 as MetricCard } from '../_tsup-dts-rollup.js';
10
10
  export { MetricCardProps_alias_1 as MetricCardProps } from '../_tsup-dts-rollup.js';
11
11
  export { MetricCardTrend_alias_1 as MetricCardTrend } from '../_tsup-dts-rollup.js';
12
+ export { VirtualList_alias_1 as VirtualList } from '../_tsup-dts-rollup.js';
13
+ export { VirtualListHandle_alias_1 as VirtualListHandle } from '../_tsup-dts-rollup.js';
14
+ export { VirtualListProps_alias_1 as VirtualListProps } from '../_tsup-dts-rollup.js';
15
+ export { VirtualListAlign_alias_1 as VirtualListAlign } from '../_tsup-dts-rollup.js';
16
+ export { VirtualListDirection_alias_1 as VirtualListDirection } from '../_tsup-dts-rollup.js';
12
17
  export { DataDisplay_alias_1 as DataDisplay } from '../_tsup-dts-rollup.js';
13
18
  export { default_alias_2 as default } from '../_tsup-dts-rollup.js';
@@ -1,2 +1,3 @@
1
- import L,{createContext,useState,useCallback,useRef,useEffect}from'react';import {Minus,TrendingDown,TrendingUp}from'lucide-react';import {clsx}from'clsx';import {twMerge}from'tailwind-merge';import {cva}from'class-variance-authority';import {jsx,Fragment,jsxs}from'react/jsx-runtime';function i(...e){return twMerge(clsx(e))}var q=cva("w-full text-left text-sm",{variants:{intent:{default:"",striped:"[&_tbody_tr:nth-child(even)]:bg-primary-50 dark:[&_tbody_tr:nth-child(even)]:bg-primary-800/30",bordered:"[&_th]:border [&_td]:border [&_th]:border-primary-200 [&_td]:border-primary-200 dark:[&_th]:border-primary-700 dark:[&_td]:border-primary-700"},density:{compact:"[&_th]:px-2 [&_th]:py-1 [&_td]:px-2 [&_td]:py-1",default:"",relaxed:"[&_th]:px-6 [&_th]:py-5 [&_td]:px-6 [&_td]:py-5"}},defaultVariants:{intent:"default",density:"default"}}),O=cva("text-sm text-primary-700 dark:text-primary-300",{variants:{intent:{default:"space-y-1",bordered:"divide-y divide-primary-200 rounded-lg border border-primary-200 dark:divide-primary-700 dark:border-primary-700 [&>li]:px-4 [&>li]:py-2",hover:"[&>li]:rounded-md [&>li]:px-3 [&>li]:py-2 [&>li]:transition-colors [&>li:hover]:bg-primary-50 dark:[&>li:hover]:bg-primary-800/50"}},defaultVariants:{intent:"default"}});cva("group flex w-full items-center gap-1.5 text-left [&_svg]:shrink-0",{variants:{size:{sm:"py-0.5 text-xs [&_svg]:h-3 [&_svg]:w-3",md:"py-1.5 text-sm [&_svg]:h-3.5 [&_svg]:w-3.5",lg:"py-2 text-base [&_svg]:h-4 [&_svg]:w-4"}},defaultVariants:{size:"md"}});cva("flex cursor-pointer items-center gap-1 rounded transition-colors [&_svg]:shrink-0",{variants:{size:{sm:"py-0.5 text-xs [&_svg]:h-3.5 [&_svg]:w-3.5",md:"py-1 text-sm [&_svg]:h-4 [&_svg]:w-4",lg:"py-1.5 text-base [&_svg]:h-5 [&_svg]:w-5"}},defaultVariants:{size:"md"}});var $=cva("relative rounded-xl border bg-white p-5 shadow-sm transition-shadow hover:shadow-md dark:bg-primary-900",{variants:{intent:{primary:"border-primary-200 dark:border-primary-700",success:"border-success-200 dark:border-success-800",danger:"border-danger-200 dark:border-danger-800",warning:"border-warning-200 dark:border-warning-800"},size:{sm:"p-4",md:"p-5",lg:"p-6"}},defaultVariants:{intent:"primary",size:"md"}}),G=cva("relative overflow-hidden rounded-xl border bg-white p-5 shadow-sm transition-all duration-300 hover:shadow-lg dark:bg-primary-900",{variants:{intent:{primary:"border-primary-200 dark:border-primary-700",success:"border-success-200 dark:border-success-800",danger:"border-danger-200 dark:border-danger-800",warning:"border-warning-200 dark:border-warning-800"},size:{sm:"p-4",md:"p-5",lg:"p-6"}},defaultVariants:{intent:"primary",size:"md"}}),V=cva("overflow-x-auto rounded-lg font-mono [background:var(--color-syntax-bg)] [&_pre]:m-0 [&_pre]:p-4 [&_code]:bg-transparent",{variants:{size:{sm:"text-xs",md:"text-sm",lg:"text-base"}},defaultVariants:{size:"md"}});function P({intent:e,density:t,className:r,...s}){return jsx("div",{className:"w-full overflow-auto",children:jsx("table",{className:i(q({intent:e,density:t}),r),...s})})}var le=createContext({size:"md"});function M({intent:e,size:t="md",className:r,...s}){return jsx(le.Provider,{value:{size:t},children:jsx("ul",{className:i(O({intent:e}),r),...s})})}var me=createContext({showLines:true,expandedKeys:null,onToggleKey:()=>{},size:"md"});function H({showLines:e=true,showRoot:t=true,expandedKeys:r,defaultExpandedKeys:s="all",onExpandedKeysChange:a,size:n="md",className:l,children:c,...o}){let [y,g]=useState(()=>s),d=useCallback(u=>{if(r){let f=new Set(r);f.has(u)?f.delete(u):f.add(u),a?.(f);}else g(f=>{if(f==="all")return new Set(["__ALL_MINUS__",u]);let h=new Set(f);return h.has(u)?h.delete(u):h.add(u),h});},[r,a]),T=r??(y==="all"?null:y);return jsx(me.Provider,{value:{showLines:e,expandedKeys:T,onToggleKey:d,size:n},children:t?jsx("ul",{className:i("text-sm",l),role:"tree",...o,children:c}):jsx("ul",{className:i("text-sm",l),role:"tree",...o,children:jsx(ue,{children:c})})})}function ue({children:e}){let t=J(e);return jsx(Fragment,{children:t.map(r=>L.isValidElement(r)&&r.props.children?r.props.children:null)})}function J(e){let t=[];return L.Children.forEach(e,r=>{L.isValidElement(r)&&r.type===L.Fragment?t.push(...J(r.props.children)):t.push(r);}),t}function be({avatar:e,sender:t}){return e?typeof e=="string"?/^(?:https?|data|blob):/.test(e)?jsx("img",{src:e,alt:t,className:"h-8 w-8 shrink-0 rounded-full object-cover",draggable:false}):jsx("div",{className:"bg-primary-200 text-primary-600 dark:bg-primary-700 dark:text-primary-300 flex h-8 w-8 shrink-0 items-center justify-center rounded-full text-lg select-none",children:e}):jsx("div",{className:"flex h-8 w-8 shrink-0 items-center justify-center rounded-full",children:e}):jsx("div",{className:"bg-primary-200 text-primary-600 dark:bg-primary-700 dark:text-primary-300 flex h-8 w-8 shrink-0 items-center justify-center rounded-full text-sm font-semibold select-none",children:t.charAt(0).toUpperCase()})}function xe({msg:e,alignRight:t}){return jsxs("div",{className:i("flex gap-2.5",t?"flex-row-reverse":"flex-row"),children:[jsx(be,{avatar:e.avatar,sender:e.sender}),jsxs("div",{className:i("flex max-w-[75%] flex-col gap-0.5",t?"items-end":"items-start"),children:[jsx("span",{className:"text-primary-500 dark:text-primary-400 text-xs",children:e.sender}),jsx("div",{className:i("rounded-xl px-3 py-2 text-sm leading-relaxed",t?"rounded-tr-sm bg-primary-500 text-white dark:bg-primary-600":"bg-primary-100 text-primary-800 dark:bg-primary-800 dark:text-primary-200 rounded-tl-sm"),children:e.content}),e.time&&jsx("span",{className:"text-primary-400 dark:text-primary-500 text-[10px]",children:e.time})]})]})}function D({messages:e,mode:t="split",autoScroll:r=true,className:s,...a}){let n=useRef(null);return useEffect(()=>{r&&n.current?.scrollIntoView({behavior:"smooth"});},[e,r]),jsxs("div",{className:i("flex flex-col gap-4 overflow-y-auto rounded-lg border p-4","border-primary-200 dark:border-primary-700 dark:bg-primary-900 bg-white",s),...a,children:[e.map(l=>{let c=t==="split"&&!!l.self;return jsx(xe,{msg:l,alignRight:c},l.id)}),jsx("div",{ref:n})]})}var ke={name:"onyx-css-vars",type:"dark",settings:[{settings:{foreground:"var(--color-syntax-plain)",background:"var(--color-syntax-bg)"}},{scope:["comment","punctuation.definition.comment"],settings:{foreground:"var(--color-syntax-comment)",fontStyle:"italic"}},{scope:["keyword","keyword.control","keyword.operator.new","keyword.operator.expression","storage.type","storage.modifier"],settings:{foreground:"var(--color-syntax-keyword)"}},{scope:["string","string.quoted","string.template"],settings:{foreground:"var(--color-syntax-string)"}},{scope:["entity.name.function","support.function","meta.function-call"],settings:{foreground:"var(--color-syntax-function)"}},{scope:["variable","variable.other","variable.parameter","meta.definition.variable"],settings:{foreground:"var(--color-syntax-variable)"}},{scope:["constant.numeric","constant.language"],settings:{foreground:"var(--color-syntax-number)"}},{scope:["keyword.operator","keyword.operator.assignment","keyword.operator.comparison","keyword.operator.arithmetic"],settings:{foreground:"var(--color-syntax-operator)"}},{scope:["entity.name.tag","punctuation.definition.tag","support.class.component"],settings:{foreground:"var(--color-syntax-tag)"}},{scope:["entity.other.attribute-name","meta.tag.attributes"],settings:{foreground:"var(--color-syntax-attr)"}},{scope:["punctuation","meta.brace","punctuation.definition.block","punctuation.separator","punctuation.terminator"],settings:{foreground:"var(--color-syntax-punctuation)"}},{scope:["entity.name.type","support.type","support.class","entity.other.inherited-class"],settings:{foreground:"var(--color-syntax-type)"}}]},we={typescript:()=>import('@shikijs/langs/typescript'),javascript:()=>import('@shikijs/langs/javascript'),tsx:()=>import('@shikijs/langs/tsx'),jsx:()=>import('@shikijs/langs/jsx'),html:()=>import('@shikijs/langs/html'),css:()=>import('@shikijs/langs/css'),json:()=>import('@shikijs/langs/json'),markdown:()=>import('@shikijs/langs/markdown'),python:()=>import('@shikijs/langs/python'),rust:()=>import('@shikijs/langs/rust'),go:()=>import('@shikijs/langs/go'),java:()=>import('@shikijs/langs/java'),c:()=>import('@shikijs/langs/c'),cpp:()=>import('@shikijs/langs/cpp'),csharp:()=>import('@shikijs/langs/csharp'),vue:()=>import('@shikijs/langs/vue'),xml:()=>import('@shikijs/langs/xml'),yaml:()=>import('@shikijs/langs/yaml'),sql:()=>import('@shikijs/langs/sql'),bash:()=>import('@shikijs/langs/bash'),shell:()=>import('@shikijs/langs/shell')},z=null,W=new Set;function Te(){return z||(z=Promise.all([import('shiki/core'),import('shiki/engine/javascript')]).then(([{createHighlighterCore:e},{createJavaScriptRegexEngine:t}])=>e({themes:[ke],langs:[],engine:t()}))),z}async function Ne(e,t,r){let s=await Te();if(t&&!W.has(t)){let n=we[t];if(n)try{let l=await n();await s.loadLanguage(l.default??l),W.add(t);}catch{t="text";}else t="text";}let a=s.codeToHtml(e,{lang:t||"text",theme:"onyx-css-vars"});if(a=a.replace(/(<pre [^>]*style=")/,"$1line-height:1.7;tab-size:2;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;"),r){let n=0;a=a.replace(/<span class="line">/g,()=>(n++,`<span class="line"><span class="line-number" data-line="${n}"></span>`));}return a}function B({code:e,language:t="text",lineNumbers:r=false,editable:s=false,onCodeChange:a,size:n,className:l,...c}){let[o,y]=useState(""),g=useRef(null),b=useRef(null),d=useRef(null);useEffect(()=>{let p=false;return Ne(e,t,s?false:r).then(m=>{p||y(m);}),()=>{p=true;}},[e,t,r,s]);let T=useCallback(()=>{let p=b.current,m=d.current?.querySelector("pre"),R=g.current?.querySelector("[data-gutter]");p&&m&&(m.scrollTop=p.scrollTop,m.scrollLeft=p.scrollLeft),p&&R&&(R.scrollTop=p.scrollTop);},[]),u=useCallback(p=>{a?.(p.target.value);},[a]),f=useCallback(p=>{if(p.key==="Tab"){p.preventDefault();let m=p.currentTarget,R=m.selectionStart,re=m.selectionEnd,ae=m.value.substring(0,R)+" "+m.value.substring(re);a?.(ae),requestAnimationFrame(()=>{m.selectionStart=m.selectionEnd=R+2;});}},[a]),h=r&&"[&_.line-number]:inline-block [&_.line-number]:w-8 [&_.line-number]:mr-4 [&_.line-number]:text-right [&_.line-number]:text-secondary-400 [&_.line-number]:select-none [&_.line-number]:before:content-[attr(data-line)]",K="ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace",U=1.7,te=e.split(`
2
- `).length;return s?jsxs("div",{ref:g,className:i(V({size:n}),"flex border border-primary-200 dark:border-primary-700",l),style:{background:"var(--color-syntax-bg)"},...c,children:[r&&jsx("div",{"data-gutter":true,"aria-hidden":true,className:"shrink-0 select-none overflow-hidden py-4 pl-3 pr-1 text-right text-secondary-400",style:{fontFamily:K,lineHeight:U,width:"3rem"},children:Array.from({length:te},(p,m)=>jsx("div",{children:m+1},m))}),jsxs("div",{className:"relative min-w-0 flex-1",children:[jsx("textarea",{ref:b,value:e,onChange:u,onScroll:T,onKeyDown:f,spellCheck:false,autoCapitalize:"off",autoComplete:"off",autoCorrect:"off",className:"relative z-2 m-0 block h-full w-full resize-none overflow-auto whitespace-pre border-none bg-transparent p-4 text-transparent caret-primary-600 outline-none dark:caret-primary-400",style:{fontFamily:K,lineHeight:U,tabSize:2,minHeight:"6rem"}}),jsx("div",{ref:d,"aria-hidden":true,className:"pointer-events-none absolute inset-0 z-1 overflow-hidden [&_pre]:m-0 [&_pre]:h-full [&_pre]:overflow-hidden [&_pre]:p-4 [&_code]:bg-transparent",dangerouslySetInnerHTML:o?{__html:o}:void 0})]})]}):jsx("div",{ref:g,className:i(V({size:n}),"border border-primary-200 dark:border-primary-700",h,l),style:{background:"var(--color-syntax-bg)"},...c,children:jsx("div",{ref:d,className:"[&_pre]:m-0 [&_pre]:p-4",dangerouslySetInnerHTML:o?{__html:o}:void 0,children:o?void 0:jsx("pre",{className:"m-0 p-4",style:{background:"var(--color-syntax-bg)"},children:jsx("code",{children:e})})})})}var _e={up:TrendingUp,down:TrendingDown,neutral:Minus},Ke={up:"text-success-600 dark:text-success-400",down:"text-danger-600 dark:text-danger-400",neutral:"text-secondary-500 dark:text-secondary-400"};function F({title:e,value:t,prefix:r,suffix:s,icon:a,trend:n,trendValue:l,description:c,intent:o,size:y,className:g}){let b=n?_e[n]:null,d=n?Ke[n]:"";return jsx("div",{className:i($({intent:o,size:y}),g),children:jsxs("div",{className:"flex items-start justify-between gap-3",children:[jsxs("div",{className:"min-w-0 flex-1",children:[jsx("p",{className:"truncate text-xs font-medium tracking-wider uppercase text-secondary-500 dark:text-secondary-400",children:e}),jsxs("p",{className:"mt-1 flex items-baseline gap-1 text-2xl font-bold text-primary-900 dark:text-primary-50",children:[r&&jsx("span",{className:"text-base font-semibold text-secondary-500 dark:text-secondary-400",children:r}),jsx("span",{children:t}),s&&jsx("span",{className:"text-base font-semibold text-secondary-500 dark:text-secondary-400",children:s})]}),(n||c)&&jsxs("div",{className:"mt-2 flex items-center gap-2",children:[n&&b&&jsxs("span",{className:i("flex items-center gap-0.5 text-xs font-semibold",d),children:[jsx(b,{className:"h-3.5 w-3.5"}),l]}),c&&jsx("span",{className:"text-xs text-secondary-500 dark:text-secondary-400",children:c})]})]}),a&&jsx("div",{className:i("flex h-10 w-10 shrink-0 items-center justify-center rounded-xl [&_svg]:h-5 [&_svg]:w-5",o==="success"&&"bg-success-100 text-success-600 dark:bg-success-900/30 dark:text-success-400",o==="danger"&&"bg-danger-100 text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",o==="warning"&&"bg-warning-100 text-warning-600 dark:bg-warning-900/30 dark:text-warning-400",(!o||o==="primary")&&"bg-primary-100 text-primary-600 dark:bg-primary-800 dark:text-primary-400"),children:a})]})})}function Ee(e){return 1-Math.pow(1-e,4)}function De(e,t,r,s,a){let[n,l]=useState(()=>a?a(t):t.toFixed(s)),c=useRef(null),o=useRef(null);return useEffect(()=>{c.current!==null&&cancelAnimationFrame(c.current),o.current=null;let y=g=>{o.current===null&&(o.current=g);let b=g-o.current,d=Math.min(b/r,1),T=Ee(d),u=t+(e-t)*T;l(a?a(u):u.toFixed(s)),d<1&&(c.current=requestAnimationFrame(y));};return c.current=requestAnimationFrame(y),()=>{c.current!==null&&cancelAnimationFrame(c.current);}},[e,t,r,s,a]),n}var Ae={up:TrendingUp,down:TrendingDown,neutral:Minus},Ie={up:"text-success-600 dark:text-success-400",down:"text-danger-600 dark:text-danger-400",neutral:"text-secondary-500 dark:text-secondary-400"},ee={primary:"bg-primary-100 text-primary-600 dark:bg-primary-800/60 dark:text-primary-300",success:"bg-success-100 text-success-600 dark:bg-success-900/30 dark:text-success-400",danger:"bg-danger-100 text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",warning:"bg-warning-100 text-warning-600 dark:bg-warning-900/30 dark:text-warning-400"};function j({title:e,value:t,decimals:r=0,prefix:s,suffix:a,icon:n,trend:l,trendValue:c,description:o,animateDuration:y=1200,formatter:g,from:b=0,intent:d,size:T,className:u}){let f=De(t,b,y,r,g),h=l?Ae[l]:null,K=l?Ie[l]:"";return jsxs("div",{className:i(G({intent:d,size:T}),u),children:[jsx("div",{className:i("pointer-events-none absolute inset-x-0 top-0 h-0.5 rounded-t-xl",d==="success"&&"bg-gradient-to-r from-success-400 to-success-600",d==="danger"&&"bg-gradient-to-r from-danger-400 to-danger-600",d==="warning"&&"bg-gradient-to-r from-warning-400 to-warning-600",(!d||d==="primary")&&"bg-gradient-to-r from-primary-400 to-primary-600")}),jsxs("div",{className:"flex items-start justify-between gap-4",children:[jsxs("div",{className:"min-w-0 flex-1",children:[jsx("p",{className:"text-xs font-semibold tracking-widest uppercase text-secondary-500 dark:text-secondary-400",children:e}),jsxs("p",{className:"mt-2 flex items-baseline gap-1",children:[s&&jsx("span",{className:"text-lg font-semibold text-secondary-400 dark:text-secondary-500",children:s}),jsx("span",{className:"font-mono text-3xl font-bold tabular-nums text-primary-900 dark:text-primary-50",children:f}),a&&jsx("span",{className:"text-lg font-semibold text-secondary-400 dark:text-secondary-500",children:a})]})]}),n&&jsx("div",{className:i("flex h-12 w-12 shrink-0 items-center justify-center rounded-2xl [&_svg]:h-6 [&_svg]:w-6",ee[d??"primary"]??ee.primary),children:n})]}),(l||o)&&jsxs("div",{className:"mt-3 flex items-center gap-2 border-t border-primary-100 pt-3 dark:border-primary-700/50",children:[l&&h&&jsxs("span",{className:i("flex items-center gap-0.5 text-xs font-bold",K),children:[jsx(h,{className:"h-3.5 w-3.5"}),c]}),o&&jsx("span",{className:"text-xs text-secondary-500 dark:text-secondary-400",children:o})]})]})}var ze={Table:P,List:M,Tree:H,Chat:D,CodeBlock:B,Stat:F,MetricCard:j},or=ze;export{D as Chat,B as CodeBlock,ze as DataDisplay,M as List,j as MetricCard,F as Stat,P as Table,H as Tree,or as default};
1
+ import re,{createContext,forwardRef,useRef,useState,useEffect,useCallback,useMemo,useImperativeHandle}from'react';import {Minus,TrendingDown,TrendingUp}from'lucide-react';import {clsx}from'clsx';import {twMerge}from'tailwind-merge';import {cva}from'class-variance-authority';import {jsx,jsxs,Fragment}from'react/jsx-runtime';function f(...r){return twMerge(clsx(r))}var ke=cva("w-full text-left text-sm",{variants:{intent:{default:"",striped:"[&_tbody_tr:nth-child(even)]:bg-primary-50 dark:[&_tbody_tr:nth-child(even)]:bg-primary-800/30",bordered:"[&_th]:border [&_td]:border [&_th]:border-primary-200 [&_td]:border-primary-200 dark:[&_th]:border-primary-700 dark:[&_td]:border-primary-700"},density:{compact:"[&_th]:px-2 [&_th]:py-1 [&_td]:px-2 [&_td]:py-1",default:"",relaxed:"[&_th]:px-6 [&_th]:py-5 [&_td]:px-6 [&_td]:py-5"}},defaultVariants:{intent:"default",density:"default"}}),Te=cva("text-sm text-primary-700 dark:text-primary-300",{variants:{intent:{default:"space-y-1",bordered:"divide-y divide-primary-200 rounded-lg border border-primary-200 dark:divide-primary-700 dark:border-primary-700 [&>li]:px-4 [&>li]:py-2",hover:"[&>li]:rounded-md [&>li]:px-3 [&>li]:py-2 [&>li]:transition-colors [&>li:hover]:bg-primary-50 dark:[&>li:hover]:bg-primary-800/50"}},defaultVariants:{intent:"default"}});cva("group flex w-full items-center gap-1.5 text-left [&_svg]:shrink-0",{variants:{size:{sm:"py-0.5 text-xs [&_svg]:h-3 [&_svg]:w-3",md:"py-1.5 text-sm [&_svg]:h-3.5 [&_svg]:w-3.5",lg:"py-2 text-base [&_svg]:h-4 [&_svg]:w-4"}},defaultVariants:{size:"md"}});cva("flex cursor-pointer items-center gap-1 rounded transition-colors [&_svg]:shrink-0",{variants:{size:{sm:"py-0.5 text-xs [&_svg]:h-3.5 [&_svg]:w-3.5",md:"py-1 text-sm [&_svg]:h-4 [&_svg]:w-4",lg:"py-1.5 text-base [&_svg]:h-5 [&_svg]:w-5"}},defaultVariants:{size:"md"}});var Ne=cva("relative rounded-xl border bg-white p-5 shadow-sm transition-shadow hover:shadow-md dark:bg-primary-900",{variants:{intent:{primary:"border-primary-200 dark:border-primary-700",success:"border-success-200 dark:border-success-800",danger:"border-danger-200 dark:border-danger-800",warning:"border-warning-200 dark:border-warning-800"},size:{sm:"p-4",md:"p-5",lg:"p-6"}},defaultVariants:{intent:"primary",size:"md"}}),Re=cva("relative overflow-hidden rounded-xl border bg-white p-5 shadow-sm transition-all duration-300 hover:shadow-lg dark:bg-primary-900",{variants:{intent:{primary:"border-primary-200 dark:border-primary-700",success:"border-success-200 dark:border-success-800",danger:"border-danger-200 dark:border-danger-800",warning:"border-warning-200 dark:border-warning-800"},size:{sm:"p-4",md:"p-5",lg:"p-6"}},defaultVariants:{intent:"primary",size:"md"}}),le=cva("overflow-x-auto rounded-lg font-mono [background:var(--color-syntax-bg)] [&_pre]:m-0 [&_pre]:p-4 [&_code]:bg-transparent",{variants:{size:{sm:"text-xs",md:"text-sm",lg:"text-base"}},defaultVariants:{size:"md"}});function ce({intent:r,density:a,className:t,...o}){return jsx("div",{className:"w-full overflow-auto",children:jsx("table",{className:f(ke({intent:r,density:a}),t),...o})})}var Be=createContext({size:"md"});function de({intent:r,size:a="md",className:t,...o}){return jsx(Be.Provider,{value:{size:a},children:jsx("ul",{className:f(Te({intent:r}),t),...o})})}var Ue=createContext({showLines:true,expandedKeys:null,onToggleKey:()=>{},size:"md"});function me({showLines:r=true,showRoot:a=true,expandedKeys:t,defaultExpandedKeys:o="all",onExpandedKeysChange:s,size:c="md",className:i,children:g,...d}){let [T,w]=useState(()=>o),u=useCallback(p=>{if(t){let b=new Set(t);b.has(p)?b.delete(p):b.add(p),s?.(b);}else w(b=>{if(b==="all")return new Set(["__ALL_MINUS__",p]);let y=new Set(b);return y.has(p)?y.delete(p):y.add(p),y});},[t,s]),m=t??(T==="all"?null:T);return jsx(Ue.Provider,{value:{showLines:r,expandedKeys:m,onToggleKey:u,size:c},children:a?jsx("ul",{className:f("text-sm",i),role:"tree",...d,children:g}):jsx("ul",{className:f("text-sm",i),role:"tree",...d,children:jsx(qe,{children:g})})})}function qe({children:r}){let a=Ce(r);return jsx(Fragment,{children:a.map(t=>re.isValidElement(t)&&t.props.children?t.props.children:null)})}function Ce(r){let a=[];return re.Children.forEach(r,t=>{re.isValidElement(t)&&t.type===re.Fragment?a.push(...Ce(t.props.children)):a.push(t);}),a}function $e({avatar:r,sender:a}){return r?typeof r=="string"?/^(?:https?|data|blob):/.test(r)?jsx("img",{src:r,alt:a,className:"h-8 w-8 shrink-0 rounded-full object-cover",draggable:false}):jsx("div",{className:"bg-primary-200 text-primary-600 dark:bg-primary-700 dark:text-primary-300 flex h-8 w-8 shrink-0 items-center justify-center rounded-full text-lg select-none",children:r}):jsx("div",{className:"flex h-8 w-8 shrink-0 items-center justify-center rounded-full",children:r}):jsx("div",{className:"bg-primary-200 text-primary-600 dark:bg-primary-700 dark:text-primary-300 flex h-8 w-8 shrink-0 items-center justify-center rounded-full text-sm font-semibold select-none",children:a.charAt(0).toUpperCase()})}function Ge({msg:r,alignRight:a}){return jsxs("div",{className:f("flex gap-2.5",a?"flex-row-reverse":"flex-row"),children:[jsx($e,{avatar:r.avatar,sender:r.sender}),jsxs("div",{className:f("flex max-w-[75%] flex-col gap-0.5",a?"items-end":"items-start"),children:[jsx("span",{className:"text-primary-500 dark:text-primary-400 text-xs",children:r.sender}),jsx("div",{className:f("rounded-xl px-3 py-2 text-sm leading-relaxed",a?"rounded-tr-sm bg-primary-500 text-white dark:bg-primary-600":"bg-primary-100 text-primary-800 dark:bg-primary-800 dark:text-primary-200 rounded-tl-sm"),children:r.content}),r.time&&jsx("span",{className:"text-primary-400 dark:text-primary-500 text-[10px]",children:r.time})]})]})}function ue({messages:r,mode:a="split",autoScroll:t=true,className:o,...s}){let c=useRef(null);return useEffect(()=>{t&&c.current?.scrollIntoView({behavior:"smooth"});},[r,t]),jsxs("div",{className:f("flex flex-col gap-4 overflow-y-auto rounded-lg border p-4","border-primary-200 dark:border-primary-700 dark:bg-primary-900 bg-white",o),...s,children:[r.map(i=>{let g=a==="split"&&!!i.self;return jsx(Ge,{msg:i,alignRight:g},i.id)}),jsx("div",{ref:c})]})}var Ze={name:"onyx-css-vars",type:"dark",settings:[{settings:{foreground:"var(--color-syntax-plain)",background:"var(--color-syntax-bg)"}},{scope:["comment","punctuation.definition.comment"],settings:{foreground:"var(--color-syntax-comment)",fontStyle:"italic"}},{scope:["keyword","keyword.control","keyword.operator.new","keyword.operator.expression","storage.type","storage.modifier"],settings:{foreground:"var(--color-syntax-keyword)"}},{scope:["string","string.quoted","string.template"],settings:{foreground:"var(--color-syntax-string)"}},{scope:["entity.name.function","support.function","meta.function-call"],settings:{foreground:"var(--color-syntax-function)"}},{scope:["variable","variable.other","variable.parameter","meta.definition.variable"],settings:{foreground:"var(--color-syntax-variable)"}},{scope:["constant.numeric","constant.language"],settings:{foreground:"var(--color-syntax-number)"}},{scope:["keyword.operator","keyword.operator.assignment","keyword.operator.comparison","keyword.operator.arithmetic"],settings:{foreground:"var(--color-syntax-operator)"}},{scope:["entity.name.tag","punctuation.definition.tag","support.class.component"],settings:{foreground:"var(--color-syntax-tag)"}},{scope:["entity.other.attribute-name","meta.tag.attributes"],settings:{foreground:"var(--color-syntax-attr)"}},{scope:["punctuation","meta.brace","punctuation.definition.block","punctuation.separator","punctuation.terminator"],settings:{foreground:"var(--color-syntax-punctuation)"}},{scope:["entity.name.type","support.type","support.class","entity.other.inherited-class"],settings:{foreground:"var(--color-syntax-type)"}}]},et={typescript:()=>import('@shikijs/langs/typescript'),javascript:()=>import('@shikijs/langs/javascript'),tsx:()=>import('@shikijs/langs/tsx'),jsx:()=>import('@shikijs/langs/jsx'),html:()=>import('@shikijs/langs/html'),css:()=>import('@shikijs/langs/css'),json:()=>import('@shikijs/langs/json'),markdown:()=>import('@shikijs/langs/markdown'),python:()=>import('@shikijs/langs/python'),rust:()=>import('@shikijs/langs/rust'),go:()=>import('@shikijs/langs/go'),java:()=>import('@shikijs/langs/java'),c:()=>import('@shikijs/langs/c'),cpp:()=>import('@shikijs/langs/cpp'),csharp:()=>import('@shikijs/langs/csharp'),vue:()=>import('@shikijs/langs/vue'),xml:()=>import('@shikijs/langs/xml'),yaml:()=>import('@shikijs/langs/yaml'),sql:()=>import('@shikijs/langs/sql'),bash:()=>import('@shikijs/langs/bash'),shell:()=>import('@shikijs/langs/shell')},be=null,Ve=new Set;function tt(){return be||(be=Promise.all([import('shiki/core'),import('shiki/engine/javascript')]).then(([{createHighlighterCore:r},{createJavaScriptRegexEngine:a}])=>r({themes:[Ze],langs:[],engine:a()}))),be}async function rt(r,a,t){let o=await tt();if(a&&!Ve.has(a)){let c=et[a];if(c)try{let i=await c();await o.loadLanguage(i.default??i),Ve.add(a);}catch{a="text";}else a="text";}let s=o.codeToHtml(r,{lang:a||"text",theme:"onyx-css-vars"});if(s=s.replace(/(<pre [^>]*style=")/,"$1line-height:1.7;tab-size:2;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;"),t){let c=0;s=s.replace(/<span class="line">/g,()=>(c++,`<span class="line"><span class="line-number" data-line="${c}"></span>`));}return s}function ye({code:r,language:a="text",lineNumbers:t=false,editable:o=false,onCodeChange:s,size:c,className:i,...g}){let[d,T]=useState(""),w=useRef(null),N=useRef(null),u=useRef(null);useEffect(()=>{let v=false;return rt(r,a,o?false:t).then(x=>{v||T(x);}),()=>{v=true;}},[r,a,t,o]);let m=useCallback(()=>{let v=N.current,x=u.current?.querySelector("pre"),L=w.current?.querySelector("[data-gutter]");v&&x&&(x.scrollTop=v.scrollTop,x.scrollLeft=v.scrollLeft),v&&L&&(L.scrollTop=v.scrollTop);},[]),p=useCallback(v=>{s?.(v.target.value);},[s]),b=useCallback(v=>{if(v.key==="Tab"){v.preventDefault();let x=v.currentTarget,L=x.selectionStart,O=x.selectionEnd,P=x.value.substring(0,L)+" "+x.value.substring(O);s?.(P),requestAnimationFrame(()=>{x.selectionStart=x.selectionEnd=L+2;});}},[s]),y=t&&"[&_.line-number]:inline-block [&_.line-number]:w-8 [&_.line-number]:mr-4 [&_.line-number]:text-right [&_.line-number]:text-secondary-400 [&_.line-number]:select-none [&_.line-number]:before:content-[attr(data-line)]",k="ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace",I=1.7,S=r.split(`
2
+ `).length;return o?jsxs("div",{ref:w,className:f(le({size:c}),"flex border border-primary-200 dark:border-primary-700",i),style:{background:"var(--color-syntax-bg)"},...g,children:[t&&jsx("div",{"data-gutter":true,"aria-hidden":true,className:"shrink-0 select-none overflow-hidden py-4 pl-3 pr-1 text-right text-secondary-400",style:{fontFamily:k,lineHeight:I,width:"3rem"},children:Array.from({length:S},(v,x)=>jsx("div",{children:x+1},x))}),jsxs("div",{className:"relative min-w-0 flex-1",children:[jsx("textarea",{ref:N,value:r,onChange:p,onScroll:m,onKeyDown:b,spellCheck:false,autoCapitalize:"off",autoComplete:"off",autoCorrect:"off",className:"relative z-2 m-0 block h-full w-full resize-none overflow-auto whitespace-pre border-none bg-transparent p-4 text-transparent caret-primary-600 outline-none dark:caret-primary-400",style:{fontFamily:k,lineHeight:I,tabSize:2,minHeight:"6rem"}}),jsx("div",{ref:u,"aria-hidden":true,className:"pointer-events-none absolute inset-0 z-1 overflow-hidden [&_pre]:m-0 [&_pre]:h-full [&_pre]:overflow-hidden [&_pre]:p-4 [&_code]:bg-transparent",dangerouslySetInnerHTML:d?{__html:d}:void 0})]})]}):jsx("div",{ref:w,className:f(le({size:c}),"border border-primary-200 dark:border-primary-700",y,i),style:{background:"var(--color-syntax-bg)"},...g,children:jsx("div",{ref:u,className:"[&_pre]:m-0 [&_pre]:p-4",dangerouslySetInnerHTML:d?{__html:d}:void 0,children:d?void 0:jsx("pre",{className:"m-0 p-4",style:{background:"var(--color-syntax-bg)"},children:jsx("code",{children:r})})})})}var ot={up:TrendingUp,down:TrendingDown,neutral:Minus},it={up:"text-success-600 dark:text-success-400",down:"text-danger-600 dark:text-danger-400",neutral:"text-secondary-500 dark:text-secondary-400"};function xe({title:r,value:a,prefix:t,suffix:o,icon:s,trend:c,trendValue:i,description:g,intent:d,size:T,className:w}){let N=c?ot[c]:null,u=c?it[c]:"";return jsx("div",{className:f(Ne({intent:d,size:T}),w),children:jsxs("div",{className:"flex items-start justify-between gap-3",children:[jsxs("div",{className:"min-w-0 flex-1",children:[jsx("p",{className:"truncate text-xs font-medium tracking-wider uppercase text-secondary-500 dark:text-secondary-400",children:r}),jsxs("p",{className:"mt-1 flex items-baseline gap-1 text-2xl font-bold text-primary-900 dark:text-primary-50",children:[t&&jsx("span",{className:"text-base font-semibold text-secondary-500 dark:text-secondary-400",children:t}),jsx("span",{children:a}),o&&jsx("span",{className:"text-base font-semibold text-secondary-500 dark:text-secondary-400",children:o})]}),(c||g)&&jsxs("div",{className:"mt-2 flex items-center gap-2",children:[c&&N&&jsxs("span",{className:f("flex items-center gap-0.5 text-xs font-semibold",u),children:[jsx(N,{className:"h-3.5 w-3.5"}),i]}),g&&jsx("span",{className:"text-xs text-secondary-500 dark:text-secondary-400",children:g})]})]}),s&&jsx("div",{className:f("flex h-10 w-10 shrink-0 items-center justify-center rounded-xl [&_svg]:h-5 [&_svg]:w-5",d==="success"&&"bg-success-100 text-success-600 dark:bg-success-900/30 dark:text-success-400",d==="danger"&&"bg-danger-100 text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",d==="warning"&&"bg-warning-100 text-warning-600 dark:bg-warning-900/30 dark:text-warning-400",(!d||d==="primary")&&"bg-primary-100 text-primary-600 dark:bg-primary-800 dark:text-primary-400"),children:s})]})})}function ut(r){return 1-Math.pow(1-r,4)}function ft(r,a,t,o,s){let[c,i]=useState(()=>s?s(a):a.toFixed(o)),g=useRef(null),d=useRef(null);return useEffect(()=>{g.current!==null&&cancelAnimationFrame(g.current),d.current=null;let T=w=>{d.current===null&&(d.current=w);let N=w-d.current,u=Math.min(N/t,1),m=ut(u),p=a+(r-a)*m;i(s?s(p):p.toFixed(o)),u<1&&(g.current=requestAnimationFrame(T));};return g.current=requestAnimationFrame(T),()=>{g.current!==null&&cancelAnimationFrame(g.current);}},[r,a,t,o,s]),c}var gt={up:TrendingUp,down:TrendingDown,neutral:Minus},bt={up:"text-success-600 dark:text-success-400",down:"text-danger-600 dark:text-danger-400",neutral:"text-secondary-500 dark:text-secondary-400"},Pe={primary:"bg-primary-100 text-primary-600 dark:bg-primary-800/60 dark:text-primary-300",success:"bg-success-100 text-success-600 dark:bg-success-900/30 dark:text-success-400",danger:"bg-danger-100 text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",warning:"bg-warning-100 text-warning-600 dark:bg-warning-900/30 dark:text-warning-400"};function he({title:r,value:a,decimals:t=0,prefix:o,suffix:s,icon:c,trend:i,trendValue:g,description:d,animateDuration:T=1200,formatter:w,from:N=0,intent:u,size:m,className:p}){let b=ft(a,N,T,t,w),y=i?gt[i]:null,k=i?bt[i]:"";return jsxs("div",{className:f(Re({intent:u,size:m}),p),children:[jsx("div",{className:f("pointer-events-none absolute inset-x-0 top-0 h-0.5 rounded-t-xl",u==="success"&&"bg-gradient-to-r from-success-400 to-success-600",u==="danger"&&"bg-gradient-to-r from-danger-400 to-danger-600",u==="warning"&&"bg-gradient-to-r from-warning-400 to-warning-600",(!u||u==="primary")&&"bg-gradient-to-r from-primary-400 to-primary-600")}),jsxs("div",{className:"flex items-start justify-between gap-4",children:[jsxs("div",{className:"min-w-0 flex-1",children:[jsx("p",{className:"text-xs font-semibold tracking-widest uppercase text-secondary-500 dark:text-secondary-400",children:r}),jsxs("p",{className:"mt-2 flex items-baseline gap-1",children:[o&&jsx("span",{className:"text-lg font-semibold text-secondary-400 dark:text-secondary-500",children:o}),jsx("span",{className:"font-mono text-3xl font-bold tabular-nums text-primary-900 dark:text-primary-50",children:b}),s&&jsx("span",{className:"text-lg font-semibold text-secondary-400 dark:text-secondary-500",children:s})]})]}),c&&jsx("div",{className:f("flex h-12 w-12 shrink-0 items-center justify-center rounded-2xl [&_svg]:h-6 [&_svg]:w-6",Pe[u??"primary"]??Pe.primary),children:c})]}),(i||d)&&jsxs("div",{className:"mt-3 flex items-center gap-2 border-t border-primary-100 pt-3 dark:border-primary-700/50",children:[i&&y&&jsxs("span",{className:f("flex items-center gap-0.5 text-xs font-bold",k),children:[jsx(y,{className:"h-3.5 w-3.5"}),g]}),d&&jsx("span",{className:"text-xs text-secondary-500 dark:text-secondary-400",children:d})]})]})}var He="onyx-vlist:";function _e(r,a){let t=0,o=r.length-2;for(;t<=o;){let s=t+o>>1;if(r[s+1]<=a)t=s+1;else if(r[s]>a)o=s-1;else return s}return Math.max(0,t)}function Ke(r,a){let{items:t,itemHeight:o,estimatedItemHeight:s=48,direction:c="vertical",overscan:i=3,onReachEnd:g,reachEndThreshold:d=120,isLoading:T,onScroll:w,onVisibleRangeChange:N,scrollRestorationId:u}=r,m=c==="vertical",p=typeof o=="number",b=p?o:0,y=useRef(null),[k,I]=useState(300);useEffect(()=>{let e=y.current;if(!e)return;let n=new ResizeObserver(([V])=>{let E=m?V.contentRect.height:V.contentRect.width;E>0&&I(E);});n.observe(e);let l=e.getBoundingClientRect(),h=m?l.height:l.width;return h>0&&I(h),()=>n.disconnect()},[m]);let[S,v]=useState(0);useEffect(()=>{if(!u)return;let e=y.current;if(e)try{let n=localStorage.getItem(He+u);if(n!==null){let l=parseFloat(n);!Number.isNaN(l)&&l>0&&requestAnimationFrame(()=>{m?e.scrollTop=l:e.scrollLeft=l;});}}catch{}},[]);let x=useRef(false),L=useRef(t.length);t.length!==L.current&&(L.current=t.length,x.current=false);let O=useCallback(()=>{let e=y.current;if(!e)return;let n=m?e.scrollTop:e.scrollLeft;if(v(n),w?.(n),u)try{localStorage.setItem(He+u,String(n));}catch{}g&&!T&&(m?e.scrollHeight-e.clientHeight:e.scrollWidth-e.clientWidth)-n<=d&&(x.current||(x.current=true,g()));},[m,w,u,g,T,d]);useEffect(()=>{let e=y.current;if(e)return e.addEventListener("scroll",O,{passive:true}),()=>e.removeEventListener("scroll",O)},[O]),useEffect(()=>{if(m)return;let e=y.current;if(!e)return;let n=l=>{Math.abs(l.deltaX)>=Math.abs(l.deltaY)||(l.preventDefault(),e.scrollLeft+=l.deltaY);};return e.addEventListener("wheel",n,{passive:false}),()=>e.removeEventListener("wheel",n)},[m]),useEffect(()=>{if(m)return;let e=y.current;if(!e)return;let n=5,l=false,h=false,V=0,E=0,Q=z=>{z.target.closest("button,a,input,select,textarea,[role=button],[role=checkbox],[role=radio],[role=option]")||z.button===0&&(l=true,h=false,V=z.clientX,E=e.scrollLeft,e.setPointerCapture(z.pointerId));},_=z=>{if(!l)return;let ie=V-z.clientX;if(!h){if(Math.abs(ie)<n)return;h=true,e.style.cursor="grabbing",e.style.userSelect="none";}e.scrollLeft=E+ie;},te=z=>{if(l){l=false,e.style.cursor="",e.style.userSelect="";try{e.releasePointerCapture(z.pointerId);}catch{}}};return e.addEventListener("pointerdown",Q),e.addEventListener("pointermove",_),e.addEventListener("pointerup",te),e.addEventListener("pointercancel",te),()=>{e.removeEventListener("pointerdown",Q),e.removeEventListener("pointermove",_),e.removeEventListener("pointerup",te),e.removeEventListener("pointercancel",te);}},[m]);let P=useRef(new Map),[ee,se]=useState(0),oe=useCallback((e,n)=>{if(p||!n)return;let l=m?n.offsetHeight:n.offsetWidth;l>0&&P.current.get(e)!==l&&(P.current.set(e,l),se(h=>h+1));},[p,m]),Y=useRef(t);Y.current!==t&&(Y.current=t,p||(P.current=new Map));let C=useMemo(()=>{if(p)return [];let e=new Array(t.length+1);e[0]=0;for(let n=0;n<t.length;n++){let l=P.current.get(n),h;l!==void 0?h=l:typeof o=="function"?h=t[n]!==void 0?o(t[n],n):s:h=s,e[n+1]=e[n]+h;}return e},[p,t,o,s,ee]),R=useCallback(e=>p?e*b:C[e]??0,[p,b,C]),j=useCallback(e=>{if(p)return b;let n=P.current.get(e);return n!==void 0?n:typeof o=="function"&&t[e]!==void 0?o(t[e],e):s},[p,b,o,t,s,ee]),$,H,D;if(p){$=b*t.length;let e=Math.floor(S/b),n=Math.ceil((S+k)/b);H=Math.max(0,e-i),D=Math.min(t.length-1,n+i-1);}else if($=C[t.length]??0,C.length>1){let e=_e(C,S);H=Math.max(0,e-i);let n=e;for(;n<t.length&&C[n]<S+k;)n++;D=Math.min(t.length-1,n+i-1);}else H=0,D=Math.min(t.length-1,i*2);H=Math.max(0,H),D=Math.max(H,Math.min(t.length-1,D));let G=useRef({start:-1,end:-1});return useEffect(()=>{let e,n;if(p&&b>0)e=Math.max(0,Math.floor(S/b)),n=Math.min(t.length-1,Math.ceil((S+k)/b)-1);else {for(e=_e(C,S),n=e;n<t.length&&C[n]<S+k;)n++;n=Math.max(0,n-1);}(G.current.start!==e||G.current.end!==n)&&(G.current={start:e,end:n},N?.(e,n));}),useImperativeHandle(a,()=>({scrollToIndex(e,n="auto"){let l=y.current;if(!l)return;let h=R(e),V=j(e),E=m?l.clientHeight:l.clientWidth,Q=m?l.scrollTop:l.scrollLeft,_;if(n==="start")_=h;else if(n==="end")_=h-E+V;else if(n==="center")_=h-(E-V)/2;else if(h<Q)_=h;else if(h+V>Q+E)_=h-E+V;else return;l.scrollTo({[m?"top":"left"]:Math.max(0,_),behavior:"smooth"});},scrollToOffset(e){let n=y.current;n&&n.scrollTo({[m?"top":"left"]:e,behavior:"smooth"});},getScrollOffset(){let e=y.current;return e?m?e.scrollTop:e.scrollLeft:0}}),[R,j,m]),{scrollerRef:y,startIndex:H,endIndex:D,totalSize:$,getItemOffset:R,getItemSize:j,measureItem:oe}}function vt({text:r="Loading\u2026"}){return jsxs("div",{className:"flex items-center justify-center gap-2 py-4 text-sm text-primary-400",children:[jsx("span",{"aria-hidden":true,className:"h-4 w-4 animate-spin rounded-full border-2 border-primary-200 border-t-primary-500"}),jsx("span",{children:r})]})}function wt({text:r="No items"}){return jsxs("div",{className:"flex h-full min-h-[120px] flex-col items-center justify-center gap-2 text-sm text-primary-400",children:[jsx("svg",{"aria-hidden":true,xmlns:"http://www.w3.org/2000/svg",className:"h-8 w-8 opacity-40",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",strokeWidth:1.5,children:jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M20 13V6a2 2 0 00-2-2H6a2 2 0 00-2 2v7m16 0v5a2 2 0 01-2 2H6a2 2 0 01-2-2v-5m16 0h-2.586a1 1 0 00-.707.293l-2.414 2.414a1 1 0 01-.707.293h-3.172a1 1 0 01-.707-.293l-2.414-2.414A1 1 0 006.586 13H4"})}),jsx("span",{children:r})]})}function kt(r,a){let{items:t,renderItem:o,getItemKey:s,itemHeight:c,direction:i="vertical",height:g="100%",width:d="100%",isLoading:T=false,loadingRenderer:w,loadingText:N,emptyRenderer:u,emptyText:m,itemClassName:p,className:b,style:y}=r,k=i==="vertical",I=typeof c!="number",{scrollerRef:S,startIndex:v,endIndex:x,totalSize:L,getItemOffset:O,getItemSize:P,measureItem:ee}=Ke(r,a),se={position:"relative",overflowX:k?"hidden":"auto",overflowY:k?"auto":"hidden",height:g,width:d,cursor:k?void 0:"grab"},oe={position:"relative",[k?"height":"width"]:L,[k?"width":"height"]:"100%",overflow:"hidden"},Y=[];for(let R=v;R<=x;R++){let j=t[R];if(j===void 0)continue;let $=O(R),H=P(R),D=s?s(j,R):R,G={position:"absolute",[k?"top":"left"]:$,[k?"height":"width"]:I?void 0:H,[k?"width":"height"]:"100%",boxSizing:"border-box"};Y.push(jsx("div",{role:"row","aria-rowindex":R+1,style:G,className:f("onyx-vlist-item",p),ref:I?e=>ee(R,e):void 0,children:o(j,R)},D));}let C=t.length===0;return jsxs("div",{ref:S,role:"grid","aria-rowcount":t.length,"data-virtual-list":true,"data-direction":i,className:f("onyx-virtual-list",b),style:{...se,...y},children:[C?u?u():jsx(wt,{text:m}):jsx("div",{style:oe,children:Y}),T&&(w?w():jsx(vt,{text:N}))]})}var ae=forwardRef(kt);var Tt={Table:ce,List:de,Tree:me,Chat:ue,CodeBlock:ye,Stat:xe,MetricCard:he,VirtualList:ae},an=Tt;
3
+ export{ue as Chat,ye as CodeBlock,Tt as DataDisplay,de as List,he as MetricCard,xe as Stat,ce as Table,me as Tree,ae as VirtualList,an as default};
@@ -1,4 +1,4 @@
1
- 'use strict';var Qe=require('react'),clsx=require('clsx'),tailwindMerge=require('tailwind-merge'),reactDom=require('react-dom'),lucideReact=require('lucide-react'),classVarianceAuthority=require('class-variance-authority'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Qe__default=/*#__PURE__*/_interopDefault(Qe);function u(...t){return tailwindMerge.twMerge(clsx.clsx(t))}var ke=classVarianceAuthority.cva("rounded-lg bg-white p-6 shadow-xl dark:bg-primary-900",{variants:{size:{sm:"w-full max-w-sm",md:"w-full max-w-lg",lg:"w-full max-w-2xl",xl:"w-full max-w-4xl",full:"h-[calc(100vh-4rem)] w-[calc(100vw-4rem)]"}},defaultVariants:{size:"md"}});classVarianceAuthority.cva("absolute z-50 rounded px-2 py-1 text-xs shadow-md animate-fade-in",{variants:{intent:{default:"bg-primary-900 text-white dark:bg-primary-100 dark:text-primary-900",light:"border border-primary-200 bg-white text-primary-700 dark:border-primary-600 dark:bg-primary-800 dark:text-primary-200"}},defaultVariants:{intent:"default"}});var E=[];function Tt(t){E.push(t);}function St(t){let a=E.indexOf(t);a!==-1&&E.splice(a,1);}function Ne(t){return E.length>0&&E[E.length-1]===t}function Lt(t){let a=E.indexOf(t);return a!==-1?a:E.length}var Xe=Qe.createContext(null);function Ye({open:t,onOpenChange:a,modal:p=true,closeOnOutsideClick:v=false,children:k}){let d=Qe.useId();return Qe.useEffect(()=>{if(t)return Tt(d),()=>St(d)},[t,d]),Qe.useEffect(()=>{if(!t||!p)return;let S=A=>{A.key==="Escape"&&Ne(d)&&a(false);};return document.addEventListener("keydown",S),()=>document.removeEventListener("keydown",S)},[t,p,a,d]),Qe.useEffect(()=>{if(!t||!p)return;let S=document.body.style.overflow;return document.body.style.overflow="hidden",()=>{document.body.style.overflow=S;}},[t,p]),t?jsxRuntime.jsx(Xe.Provider,{value:{id:d,onOpenChange:a,modal:p,closeOnOutsideClick:v},children:reactDom.createPortal(k,document.body)}):null}function Ke({size:t,position:a="center",className:p,children:v,...k}){let d=Qe.useContext(Xe);if(!d)return null;let A=200+Lt(d.id)*10,J=()=>{d.closeOnOutsideClick&&Ne(d.id)&&d.onOpenChange(false);},L=a==="bottom";return d.modal?jsxRuntime.jsx("div",{className:u("animate-fade-in fixed inset-0 bg-black/50",L?"flex items-end justify-center":"flex items-center justify-center p-4"),style:{zIndex:A},onClick:J,children:jsxRuntime.jsx("div",{className:u(ke({size:t}),L?"animate-slide-in-bottom w-full rounded-b-none rounded-t-(--dialog-sheet-radius) max-h-[85vh] overflow-y-auto":"animate-scale-in",p),role:"dialog","aria-modal":"true",onClick:O=>O.stopPropagation(),...k,children:v})}):jsxRuntime.jsx("div",{className:u("fixed inset-0 flex items-center justify-center p-4",d.closeOnOutsideClick?"pointer-events-auto":"pointer-events-none"),style:{zIndex:A},onClick:d.closeOnOutsideClick&&Ne(d.id)?()=>d.onOpenChange(false):void 0,children:jsxRuntime.jsx("div",{className:u(ke({size:t}),"animate-scale-in pointer-events-auto shadow-2xl",p),role:"dialog",onClick:d.closeOnOutsideClick?O=>O.stopPropagation():void 0,...k,children:v})})}function $e({className:t,...a}){return jsxRuntime.jsx("div",{className:u("mb-4 space-y-1",t),...a})}function We({className:t,...a}){return jsxRuntime.jsx("h2",{className:u("text-primary-900 dark:text-primary-100 flex items-center gap-1.5 text-lg font-semibold [&_svg]:h-5 [&_svg]:w-5 [&_svg]:shrink-0",t),...a})}function qe({className:t,...a}){return jsxRuntime.jsx("p",{className:u("text-primary-500 dark:text-primary-400 text-sm",t),...a})}function Ge({className:t,...a}){return jsxRuntime.jsx("div",{className:u("mt-6 flex justify-end gap-2",t),...a})}var Ue=classVarianceAuthority.cva("inline-flex cursor-pointer items-center justify-center gap-1.5 rounded font-medium transition-colors disabled:pointer-events-none disabled:opacity-50 [&_svg]:shrink-0",{variants:{intent:{primary:"bg-primary-500 text-white hover:bg-primary-600 active:bg-primary-700",secondary:"bg-secondary-500 text-white hover:bg-secondary-600 active:bg-secondary-700",danger:"bg-danger-500 text-white hover:bg-danger-600 active:bg-danger-700",warning:"bg-warning-500 text-white hover:bg-warning-600 active:bg-warning-700",ghost:"bg-transparent text-primary-700 hover:bg-primary-100 active:bg-primary-200 dark:text-primary-300 dark:hover:bg-primary-800",outline:"border border-primary-300 bg-transparent text-primary-700 hover:bg-primary-50 dark:border-primary-600 dark:text-primary-300 dark:hover:bg-primary-800"},size:{sm:"h-7 px-3 text-xs [&_svg]:h-3.5 [&_svg]:w-3.5",md:"h-9 px-4 text-sm [&_svg]:h-4 [&_svg]:w-4",lg:"h-11 px-6 text-base [&_svg]:h-5 [&_svg]:w-5"}},defaultVariants:{intent:"primary",size:"md"}});classVarianceAuthority.cva("inline-flex items-center gap-1 rounded border font-semibold [&_svg]:shrink-0",{variants:{intent:{success:"border-success-200 bg-success-100 text-success-800 dark:border-success-800 dark:bg-success-900/30 dark:text-success-400",warning:"border-warning-200 bg-warning-100 text-warning-800 dark:border-warning-800 dark:bg-warning-900/30 dark:text-warning-400",error:"border-danger-200 bg-danger-100 text-danger-800 dark:border-danger-800 dark:bg-danger-900/30 dark:text-danger-400",info:"border-primary-200 bg-primary-100 text-primary-800 dark:border-primary-800 dark:bg-primary-900/30 dark:text-primary-400",primary:"border-secondary-200 bg-secondary-100 text-secondary-700 dark:border-secondary-700 dark:bg-secondary-800 dark:text-secondary-300"},size:{sm:"px-1.5 py-0 text-[0.625rem] [&_svg]:h-2.5 [&_svg]:w-2.5",md:"px-2.5 py-0.5 text-xs [&_svg]:h-3 [&_svg]:w-3",lg:"px-3 py-1 text-sm [&_svg]:h-3.5 [&_svg]:w-3.5"}},defaultVariants:{intent:"primary",size:"md"}});classVarianceAuthority.cva("absolute flex items-center justify-center rounded-full font-bold leading-none ring-2 ring-white select-none pointer-events-none z-10 dark:ring-primary-900",{variants:{intent:{danger:"bg-danger-500 text-white",success:"bg-success-500 text-white",warning:"bg-warning-500 text-white",info:"bg-primary-500 text-white",primary:"bg-secondary-500 text-white"},size:{sm:"text-[0.5rem]",md:"text-[0.625rem]",lg:"text-xs"},dot:{true:"",false:""},placement:{"top-right":"top-0 right-0 translate-x-1/2 -translate-y-1/2","top-left":"top-0 left-0 -translate-x-1/2 -translate-y-1/2","bottom-right":"bottom-0 right-0 translate-x-1/2 translate-y-1/2","bottom-left":"bottom-0 left-0 -translate-x-1/2 translate-y-1/2"}},compoundVariants:[{dot:true,size:"sm",class:"h-1.5 w-1.5 min-w-0 ring-1"},{dot:true,size:"md",class:"h-2 w-2 min-w-0"},{dot:true,size:"lg",class:"h-2.5 w-2.5 min-w-0"},{dot:false,size:"sm",class:"h-4 min-w-4 px-1"},{dot:false,size:"md",class:"h-5 min-w-5 px-1.5"},{dot:false,size:"lg",class:"h-6 min-w-6 px-2"}],defaultVariants:{intent:"danger",size:"md",dot:false,placement:"top-right"}});classVarianceAuthority.cva("w-full rounded-md border bg-white text-secondary-900 transition-colors placeholder:text-secondary-400 focus:outline-none focus:ring-2 dark:bg-secondary-900 dark:text-secondary-100 dark:placeholder:text-secondary-600",{variants:{state:{default:"border-secondary-300 focus:border-primary-500 focus:ring-primary-500/20 dark:border-secondary-600",error:"border-danger-400 focus:border-danger-500 focus:ring-danger-500/20"},size:{sm:"h-7 px-2 text-xs",md:"h-9 px-3 py-2 text-sm",lg:"h-11 px-4 py-2.5 text-base"}},defaultVariants:{state:"default",size:"md"}});classVarianceAuthority.cva("inline-flex items-center gap-1 font-medium [&_svg]:shrink-0",{variants:{size:{sm:"text-xs [&_svg]:h-3 [&_svg]:w-3",md:"text-sm [&_svg]:h-3.5 [&_svg]:w-3.5",lg:"text-base [&_svg]:h-4 [&_svg]:w-4"},intent:{default:"text-primary-700 dark:text-primary-300",muted:"text-primary-400 dark:text-primary-500",required:"text-primary-700 dark:text-primary-300 after:ml-0.5 after:text-danger-500 after:content-['*']"}},defaultVariants:{size:"md",intent:"default"}});classVarianceAuthority.cva("relative inline-flex shrink-0 items-center justify-center rounded border-2 transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2",{variants:{intent:{primary:"border-primary-300 dark:border-primary-600 focus-visible:ring-primary-500/40",secondary:"border-secondary-300 dark:border-secondary-600 focus-visible:ring-secondary-500/40",danger:"border-danger-300 dark:border-danger-600 focus-visible:ring-danger-500/40",warning:"border-warning-300 dark:border-warning-600 focus-visible:ring-warning-500/40",success:"border-success-300 dark:border-success-600 focus-visible:ring-success-500/40"},size:{sm:"h-4 w-4 rounded-[3px]",md:"h-5 w-5 rounded",lg:"h-6 w-6 rounded-[5px]"},checked:{on:"",off:"bg-white dark:bg-primary-900"}},compoundVariants:[{intent:"primary",checked:"on",class:"border-primary-500 bg-primary-500 dark:border-primary-500 dark:bg-primary-500"},{intent:"secondary",checked:"on",class:"border-secondary-500 bg-secondary-500 dark:border-secondary-500 dark:bg-secondary-500"},{intent:"danger",checked:"on",class:"border-danger-500 bg-danger-500 dark:border-danger-500 dark:bg-danger-500"},{intent:"warning",checked:"on",class:"border-warning-500 bg-warning-500 dark:border-warning-500 dark:bg-warning-500"},{intent:"success",checked:"on",class:"border-success-500 bg-success-500 dark:border-success-500 dark:bg-success-500"}],defaultVariants:{intent:"primary",size:"md",checked:"off"}});classVarianceAuthority.cva("relative inline-flex shrink-0 items-center justify-center rounded-full border-2 transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2",{variants:{intent:{primary:"border-primary-300 dark:border-primary-600 focus-visible:ring-primary-500/40",secondary:"border-secondary-300 dark:border-secondary-600 focus-visible:ring-secondary-500/40",danger:"border-danger-300 dark:border-danger-600 focus-visible:ring-danger-500/40",warning:"border-warning-300 dark:border-warning-600 focus-visible:ring-warning-500/40",success:"border-success-300 dark:border-success-600 focus-visible:ring-success-500/40"},size:{sm:"h-4 w-4",md:"h-5 w-5",lg:"h-6 w-6"},checked:{on:"",off:"bg-white dark:bg-primary-900"}},compoundVariants:[{intent:"primary",checked:"on",class:"border-primary-500 bg-primary-500 dark:border-primary-500 dark:bg-primary-500"},{intent:"secondary",checked:"on",class:"border-secondary-500 bg-secondary-500 dark:border-secondary-500 dark:bg-secondary-500"},{intent:"danger",checked:"on",class:"border-danger-500 bg-danger-500 dark:border-danger-500 dark:bg-danger-500"},{intent:"warning",checked:"on",class:"border-warning-500 bg-warning-500 dark:border-warning-500 dark:bg-warning-500"},{intent:"success",checked:"on",class:"border-success-500 bg-success-500 dark:border-success-500 dark:bg-success-500"}],defaultVariants:{intent:"primary",size:"md",checked:"off"}});classVarianceAuthority.cva("",{variants:{intent:{primary:"",secondary:"",danger:"",warning:"",success:""},size:{sm:"",md:"",lg:""},checked:{on:"",off:"bg-primary-300 dark:bg-primary-800"}},compoundVariants:[{intent:"primary",checked:"on",class:"bg-primary-500 dark:bg-primary-500"},{intent:"secondary",checked:"on",class:"bg-secondary-500 dark:bg-secondary-500"},{intent:"danger",checked:"on",class:"bg-danger-500 dark:bg-danger-500"},{intent:"warning",checked:"on",class:"bg-warning-500 dark:bg-warning-500"},{intent:"success",checked:"on",class:"bg-success-500 dark:bg-success-500"}],defaultVariants:{intent:"primary",size:"md",checked:"off"}});classVarianceAuthority.cva("bg-primary-200 text-primary-700 dark:bg-primary-700 dark:text-primary-200",{variants:{size:{xs:"h-6 w-6 text-[10px]",sm:"h-8 w-8 text-xs",md:"h-10 w-10 text-sm",lg:"h-12 w-12 text-base",xl:"h-16 w-16 text-lg"},shape:{circular:"rounded-full",rounded:"rounded-lg",square:"rounded-none"}},defaultVariants:{size:"md",shape:"circular"}});classVarianceAuthority.cva("relative flex w-full touch-none select-none items-center",{variants:{intent:{primary:"[&_.slider-fill]:bg-primary-500 [&_.slider-thumb]:border-primary-500",secondary:"[&_.slider-fill]:bg-secondary-500 [&_.slider-thumb]:border-secondary-500",success:"[&_.slider-fill]:bg-success-500 [&_.slider-thumb]:border-success-500",danger:"[&_.slider-fill]:bg-danger-500 [&_.slider-thumb]:border-danger-500",warning:"[&_.slider-fill]:bg-warning-500 [&_.slider-thumb]:border-warning-500"},size:{sm:"h-4",md:"h-5",lg:"h-6"}},defaultVariants:{intent:"primary",size:"md"}});classVarianceAuthority.cva("inline-flex items-center gap-1 rounded-full font-medium select-none transition-colors [&_svg]:shrink-0",{variants:{intent:{primary:"bg-primary-100 text-primary-700 dark:bg-primary-800 dark:text-primary-200",secondary:"bg-secondary-100 text-secondary-700 dark:bg-secondary-800 dark:text-secondary-200",success:"bg-success-100 text-success-700 dark:bg-success-900/40 dark:text-success-300",danger:"bg-danger-100 text-danger-700 dark:bg-danger-900/40 dark:text-danger-300",warning:"bg-warning-100 text-warning-700 dark:bg-warning-900/40 dark:text-warning-300",info:"bg-blue-100 text-blue-700 dark:bg-blue-900/40 dark:text-blue-300"},size:{sm:"h-5 px-2 text-[0.6875rem] gap-0.5",md:"h-6 px-2.5 text-xs gap-1",lg:"h-7 px-3 text-sm gap-1"},variant:{solid:"",outline:"bg-transparent border",soft:""}},compoundVariants:[{intent:"primary",variant:"outline",class:"border-primary-300 text-primary-700 dark:border-primary-600 dark:text-primary-300"},{intent:"secondary",variant:"outline",class:"border-secondary-300 text-secondary-700 dark:border-secondary-600 dark:text-secondary-300"},{intent:"success",variant:"outline",class:"border-success-400 text-success-700 dark:border-success-600 dark:text-success-300"},{intent:"danger",variant:"outline",class:"border-danger-400 text-danger-700 dark:border-danger-600 dark:text-danger-300"},{intent:"warning",variant:"outline",class:"border-warning-400 text-warning-700 dark:border-warning-600 dark:text-warning-300"},{intent:"info",variant:"outline",class:"border-blue-400 text-blue-700 dark:border-blue-600 dark:text-blue-300"}],defaultVariants:{intent:"primary",size:"md",variant:"solid"}});classVarianceAuthority.cva("relative w-full cursor-pointer rounded-md border bg-white text-sm transition-colors dark:bg-primary-900",{variants:{intent:{default:"border-primary-300 text-primary-900 hover:border-primary-400 focus-within:border-primary-500 focus-within:ring-2 focus-within:ring-primary-500/20 dark:border-primary-600 dark:text-primary-100 dark:hover:border-primary-500 dark:focus-within:border-primary-400",danger:"border-danger-500 text-primary-900 focus-within:ring-2 focus-within:ring-danger-500/20 dark:border-danger-500 dark:text-primary-100"},size:{sm:"h-7 px-2 text-xs",md:"h-9 px-3 text-sm",lg:"h-11 px-4 text-base"}},defaultVariants:{intent:"default",size:"md"}});function Me({intent:t,size:a,className:p,...v}){return jsxRuntime.jsx("button",{className:u(Ue({intent:t,size:a}),p),...v})}function le(t){let a=t.lastIndexOf(".");return a>0?t.slice(a).toLowerCase():""}function tt(t){return t==null?"\u2014":t<1024?`${t} B`:t<1024*1024?`${(t/1024).toFixed(1)} KB`:t<1024*1024*1024?`${(t/(1024*1024)).toFixed(1)} MB`:`${(t/(1024*1024*1024)).toFixed(2)} GB`}function Ve(t){return t?(typeof t=="string"?new Date(t):t).toLocaleDateString(void 0,{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"}):"\u2014"}var $t={".png":lucideReact.Image,".jpg":lucideReact.Image,".jpeg":lucideReact.Image,".gif":lucideReact.Image,".svg":lucideReact.Image,".webp":lucideReact.Image,".ico":lucideReact.Image,".bmp":lucideReact.Image,".mp3":lucideReact.Music,".wav":lucideReact.Music,".flac":lucideReact.Music,".ogg":lucideReact.Music,".aac":lucideReact.Music,".m4a":lucideReact.Music,".mp4":lucideReact.Video,".mkv":lucideReact.Video,".avi":lucideReact.Video,".mov":lucideReact.Video,".wmv":lucideReact.Video,".webm":lucideReact.Video,".ts":lucideReact.FileCode,".tsx":lucideReact.FileCode,".js":lucideReact.FileCode,".jsx":lucideReact.FileCode,".json":lucideReact.FileCode,".html":lucideReact.FileCode,".css":lucideReact.FileCode,".scss":lucideReact.FileCode,".py":lucideReact.FileCode,".rs":lucideReact.FileCode,".go":lucideReact.FileCode,".java":lucideReact.FileCode,".c":lucideReact.FileCode,".cpp":lucideReact.FileCode,".h":lucideReact.FileCode,".sh":lucideReact.Terminal,".bat":lucideReact.Terminal,".ps1":lucideReact.Terminal,".md":lucideReact.FileText,".txt":lucideReact.FileText,".pdf":lucideReact.FileText,".doc":lucideReact.FileText,".docx":lucideReact.FileText,".rtf":lucideReact.FileText,".csv":lucideReact.FileSpreadsheet,".xls":lucideReact.FileSpreadsheet,".xlsx":lucideReact.FileSpreadsheet,".db":lucideReact.Database,".sqlite":lucideReact.Database,".sql":lucideReact.Database,".zip":lucideReact.FileArchive,".tar":lucideReact.FileArchive,".gz":lucideReact.FileArchive,".rar":lucideReact.FileArchive,".7z":lucideReact.FileArchive};function Te(t){if(t.type==="directory")return lucideReact.Folder;let a=t.extension||le(t.name);return $t[a]||lucideReact.File}function U(t,a,p){return Math.max(a,Math.min(p,t))}function rt(t){return t<480?"xs":t<640?"sm":t<1024?"md":"lg"}function nt(t,a){if(t<480)return {size:{width:t-16,height:a-48},pos:{x:8,y:24}};if(t<640){let k=t-24,d=Math.min(a-64,540);return {size:{width:k,height:d},pos:{x:12,y:32}}}if(t<1024){let k=Math.min(640,t-32),d=Math.min(480,a-64);return {size:{width:k,height:d},pos:{x:Math.max(0,Math.round((t-k)/2)),y:Math.max(0,Math.round((a-d)/2))}}}let p=720,v=520;return {size:{width:p,height:v},pos:{x:Math.max(0,Math.round((t-p)/2)),y:Math.max(0,Math.round((a-v)/2))}}}function Rr({files:t,title:a="File Explorer",accent:p="#8b5cf6",defaultView:v="list",initialPosition:k,initialSize:d,dockable:S=false,dockSide:A="right",visible:J=true,onFileOpen:L,onSelectionChange:O,onNavigate:ie,onDelete:ue,onClose:st,onMinimize:Se,onPathSubmit:Le,defaultInputMode:ot="search",actions:it,resizable:dt=true,minSize:Z={width:400,height:300},className:ct}){let[me,lt]=Qe.useState(v),[b,P]=Qe.useState(new Set),[_e,ee]=Qe.useState(null),[c,pe]=Qe.useState(false),[te,ge]=Qe.useState(false),[_,ut]=Qe.useState(""),[F,mt]=Qe.useState(ot),[pt,gt]=Qe.useState(J),[ft,de]=Qe.useState(false),[B,bt]=Qe.useState({w:window.innerWidth,h:window.innerHeight}),Fe=nt(window.innerWidth,window.innerHeight),[g,j]=Qe.useState(k??Fe.pos),[z,ce]=Qe.useState(d??Fe.size),[M,xt]=Qe.useState(null),re=Qe.useRef(false),X=Qe.useRef({x:0,y:0}),fe=Qe.useRef(null),R=Qe.useRef(false),ne=Qe.useRef({x:0,y:0,w:0,h:0,px:0,py:0}),ae=Qe.useRef(false),Re=Qe.useRef(c);Qe.useEffect(()=>{Re.current=c;},[c]);let be=J!==void 0?J:pt,xe=Qe.useMemo(()=>{let e=t.filter(s=>s.type==="directory"),n=t.filter(s=>s.type==="file");return e.sort((s,o)=>s.name.localeCompare(o.name)),n.sort((s,o)=>s.name.localeCompare(o.name)),[...e,...n]},[t]),x=Qe.useMemo(()=>{if(F!=="search"||!_.trim())return xe;let e=_.toLowerCase();return xe.filter(n=>n.name.toLowerCase().includes(e))},[xe,_,F]),m=_e!=null?x[_e]:null;Qe.useEffect(()=>{let e=rt(window.innerWidth),n=()=>{let s=window.innerWidth,o=window.innerHeight;if(bt({w:s,h:o}),Re.current)return;let l=rt(s);if(l!==e&&!ae.current&&!d){let y=nt(s,o);ce(y.size),j(y.pos);}e=l;};return window.addEventListener("resize",n),()=>window.removeEventListener("resize",n)},[d]);let Ie=Qe.useCallback((e,n)=>{P(s=>{let o=new Set(s);return n.ctrlKey||n.metaKey?o.has(e)?o.delete(e):o.add(e):(o.clear(),o.add(e)),o}),ee(e);},[]);Qe.useEffect(()=>{if(!O)return;let e=Array.from(b).map(n=>x[n]).filter(Boolean);O(e);},[b]);let He=Qe.useCallback(e=>{let n=x[e];n&&(n.type==="directory"?ie?.(n.path):L?.(n));},[x,L,ie]),ht=Qe.useCallback(e=>{c||e.target.closest("button")||(ae.current=true,re.current=true,X.current={x:e.clientX-g.x,y:e.clientY-g.y},e.preventDefault());},[g,c]),yt=Qe.useCallback(e=>{if(c||e.target.closest("button"))return;ae.current=true;let n=e.touches[0];re.current=true,X.current={x:n.clientX-g.x,y:n.clientY-g.y};},[g,c]);Qe.useEffect(()=>{let e=o=>{if(!re.current)return;let l=window.innerWidth-100,y=window.innerHeight-40;j({x:U(o.clientX-X.current.x,0,l),y:U(o.clientY-X.current.y,0,y)});},n=o=>{if(!re.current)return;o.preventDefault();let l=o.touches[0],y=window.innerWidth-100,I=window.innerHeight-40;j({x:U(l.clientX-X.current.x,0,y),y:U(l.clientY-X.current.y,0,I)});},s=()=>{re.current=false,R.current=false,document.body.style.cursor="",document.body.style.userSelect="";};return window.addEventListener("mousemove",e),window.addEventListener("mouseup",s),window.addEventListener("touchmove",n,{passive:false}),window.addEventListener("touchend",s),()=>{window.removeEventListener("mousemove",e),window.removeEventListener("mouseup",s),window.removeEventListener("touchmove",n),window.removeEventListener("touchend",s);}},[]);let D=Qe.useCallback((e,n)=>{c||(n.preventDefault(),n.stopPropagation(),ae.current=true,R.current=e,ne.current={x:n.clientX,y:n.clientY,w:z.width,h:z.height,px:g.x,py:g.y},document.body.style.cursor=e==="e"||e==="w"?"ew-resize":e==="n"||e==="s"?"ns-resize":e==="nw"||e==="se"?"nwse-resize":"nesw-resize",document.body.style.userSelect="none");},[c,z,g]),C=Qe.useCallback((e,n)=>{if(c)return;n.preventDefault(),n.stopPropagation(),ae.current=true;let s=n.touches[0];R.current=e,ne.current={x:s.clientX,y:s.clientY,w:z.width,h:z.height,px:g.x,py:g.y},document.body.style.userSelect="none";},[c,z,g]);Qe.useEffect(()=>{let e=(l,y)=>{let I=R.current;if(!I)return;let Pe=l-ne.current.x,Be=y-ne.current.y,{w:Y,h:K,px:we,py:ve}=ne.current;if(I.includes("e")&&(Y=Math.max(Z.width,Y+Pe)),I.includes("w")){let se=Math.max(Z.width,Y-Pe);we=we+(Y-se),Y=se;}if(I.includes("s")&&(K=Math.max(Z.height,K+Be)),I.includes("n")){let se=Math.max(Z.height,K-Be);ve=ve+(K-se),K=se;}ce({width:Y,height:K}),j({x:we,y:ve});},n=l=>{R.current&&e(l.clientX,l.clientY);},s=l=>{R.current&&(l.preventDefault(),e(l.touches[0].clientX,l.touches[0].clientY));},o=()=>{R.current=false,document.body.style.cursor="",document.body.style.userSelect="";};return window.addEventListener("mousemove",n),window.addEventListener("mouseup",o),window.addEventListener("touchmove",s,{passive:false}),window.addEventListener("touchend",o),()=>{window.removeEventListener("mousemove",n),window.removeEventListener("mouseup",o),window.removeEventListener("touchmove",s),window.removeEventListener("touchend",o);}},[Z]);let Ae=Qe.useCallback(()=>{c?(M&&(j(M.pos),ce(M.size)),pe(false)):(xt({pos:g,size:z}),pe(true));},[c,g,z,M]),wt=Qe.useCallback(()=>{te?ge(false):(c&&(pe(false),M&&(j(M.pos),ce(M.size))),ge(true),Se?.());},[te,c,M,Se]);Qe.useEffect(()=>{if(!be||te)return;let e=n=>{if(!(!fe.current?.contains(document.activeElement)&&document.activeElement!==fe.current)){if(n.key==="Escape"&&(ee(null),P(new Set)),n.ctrlKey&&n.key==="a"){n.preventDefault();let s=new Set(x.map((o,l)=>l));P(s);}n.key==="Delete"&&b.size>0&&ue&&(n.preventDefault(),de(true));}};return window.addEventListener("keydown",e),()=>window.removeEventListener("keydown",e)},[be,te,x,b,ue]);let Oe={"--fe-accent":p};if(te)return jsxRuntime.jsx("div",{className:u("fixed z-100 cursor-pointer transition-all duration-300",A==="right"?"right-0 top-1/2 -translate-y-1/2":"left-0 top-1/2 -translate-y-1/2"),style:Oe,onClick:()=>ge(false),title:`Restore ${a}`,children:jsxRuntime.jsxs("div",{className:"fe-dock flex items-center gap-1.5 rounded-l-lg px-2 py-3 backdrop-blur-md",style:{writingMode:"vertical-rl",textOrientation:"mixed"},children:[jsxRuntime.jsx(lucideReact.HardDrive,{className:"h-3.5 w-3.5 text-(--fe-accent)"}),jsxRuntime.jsx("span",{className:"text-[10px] font-bold uppercase tracking-widest text-(--fe-text)",children:a})]})});if(!be)return null;let he=c?B.w:Math.min(z.width,B.w-8),vt=c?B.h:Math.min(z.height,B.h-8),kt=c?0:U(g.x,0,Math.max(0,B.w-he)),zt=c?0:U(g.y,0,Math.max(0,B.h-40)),ye=he<500;return jsxRuntime.jsxs("div",{ref:fe,className:u("fe-window fixed z-100 flex flex-col overflow-hidden","rounded-xl border border-(--fe-border)","animate-[fe-window-in_0.35s_cubic-bezier(0.16,1,0.3,1)_both]",c&&"rounded-none",ct),style:{...Oe,left:kt,top:zt,width:he,height:vt,transition:c?"left 0.3s, top 0.3s, width 0.3s, height 0.3s":void 0},tabIndex:0,children:[jsxRuntime.jsxs("div",{className:"fe-titlebar group/titlebar flex h-10 shrink-0 cursor-grab items-center justify-between px-3 select-none active:cursor-grabbing",onMouseDown:ht,onTouchStart:yt,onDoubleClick:Ae,children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-2",children:[jsxRuntime.jsx("div",{className:"flex h-5 w-5 items-center justify-center rounded",style:{background:"color-mix(in srgb, var(--fe-accent) 25%, transparent)"},children:jsxRuntime.jsx(lucideReact.HardDrive,{className:"h-3 w-3 text-(--fe-accent)"})}),jsxRuntime.jsx("span",{className:"text-xs font-bold uppercase tracking-widest text-(--fe-text)",children:a}),jsxRuntime.jsx("div",{className:"ml-2 hidden h-px w-20 md:block",style:{background:"linear-gradient(90deg, var(--fe-accent), transparent)",opacity:.3}})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-0.5",children:[jsxRuntime.jsx("button",{className:"fe-btn mr-1",onClick:()=>lt(e=>e==="list"?"grid":"list"),title:me==="list"?"Grid view":"List view",children:me==="list"?jsxRuntime.jsx(lucideReact.LayoutGrid,{className:"h-3.5 w-3.5"}):jsxRuntime.jsx(lucideReact.LayoutList,{className:"h-3.5 w-3.5"})}),S&&jsxRuntime.jsx("button",{className:"fe-btn",onClick:wt,title:"Dock to edge",children:jsxRuntime.jsx(lucideReact.Minus,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:"fe-btn",onClick:Ae,title:c?"Restore":"Maximize",children:c?jsxRuntime.jsx(lucideReact.Minimize2,{className:"h-3.5 w-3.5"}):jsxRuntime.jsx(lucideReact.Maximize2,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:"fe-btn hover:bg-red-500/40! hover:text-red-300!",onClick:()=>{st?.(),gt(false);},title:"Close",children:jsxRuntime.jsx(lucideReact.X,{className:"h-3.5 w-3.5"})})]})]}),jsxRuntime.jsxs("div",{className:"fe-toolbar flex h-9 shrink-0 items-center gap-2 px-3",children:[jsxRuntime.jsx("button",{className:"fe-btn p-1",onClick:()=>ie?.(".."),title:"Go up",children:jsxRuntime.jsx(lucideReact.FolderUp,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:"fe-btn shrink-0 px-1.5 py-0.5 text-[9px] font-bold uppercase tracking-wider",style:F==="navigate"?{color:"var(--fe-accent)",background:"color-mix(in srgb, var(--fe-accent) 15%, transparent)"}:void 0,onClick:()=>mt(e=>e==="search"?"navigate":"search"),title:F==="search"?"Switch to path navigation":"Switch to file search",children:F==="search"?jsxRuntime.jsx(lucideReact.Search,{className:"h-3 w-3"}):jsxRuntime.jsx(lucideReact.CornerRightDown,{className:"h-3 w-3"})}),jsxRuntime.jsx("div",{className:"relative flex-1",children:jsxRuntime.jsx("input",{type:"text",value:_,onChange:e=>ut(e.target.value),onKeyDown:e=>{e.key==="Enter"&&_.trim()&&F==="navigate"&&(Le?Le(_.trim()):ie?.(_.trim()));},placeholder:F==="search"?"Search files\u2026":"Enter path and press Enter\u2026",className:"h-6 w-full rounded border border-(--fe-input-border) bg-(--fe-input-bg) px-2 text-[11px] text-(--fe-text-strong) placeholder:text-(--fe-text-muted) outline-none transition-colors focus:border-(--fe-accent)/40 focus:bg-(--fe-input-bg)"})}),jsxRuntime.jsxs("span",{className:"shrink-0 font-mono text-[10px] text-(--fe-text-muted)",children:[x.length," item",x.length!==1?"s":"",b.size>0&&` \xB7 ${b.size} selected`]})]}),jsxRuntime.jsxs("div",{className:"relative flex flex-1 min-h-0",children:[jsxRuntime.jsx("div",{className:"flex-1 overflow-y-auto overflow-x-hidden p-1.5",onClick:e=>{e.target===e.currentTarget&&(P(new Set),ee(null));},children:x.length===0?jsxRuntime.jsxs("div",{className:"flex h-full flex-col items-center justify-center text-(--fe-text-muted)",children:[jsxRuntime.jsx(lucideReact.Folder,{className:"mb-2 h-10 w-10"}),jsxRuntime.jsx("span",{className:"text-xs",children:"No files found"})]}):me==="list"?jsxRuntime.jsx("div",{className:"space-y-px",children:x.map((e,n)=>{let s=Te(e),o=b.has(n),l=e.extension||le(e.name);return jsxRuntime.jsxs("div",{className:u("fe-item group/item flex items-center gap-2.5 rounded-lg px-2.5 py-1.5 text-(--fe-text) transition-all duration-150 cursor-pointer",o?"bg-(--fe-accent)/15 text-(--fe-text-strong)":"hover:bg-(--fe-surface-hover) hover:text-(--fe-text-strong)"),style:o?{boxShadow:"inset 2px 0 0 var(--fe-accent)"}:void 0,onClick:y=>Ie(n,y),onDoubleClick:()=>He(n),children:[jsxRuntime.jsx(s,{className:u("h-4 w-4 shrink-0",e.type==="directory"?"text-(--fe-accent)":"text-(--fe-text-muted)")}),jsxRuntime.jsx("span",{className:"flex-1 truncate text-xs font-medium",children:e.name}),l&&e.type==="file"&&jsxRuntime.jsx("span",{className:"shrink-0 rounded bg-(--fe-badge-bg) px-1.5 py-0.5 font-mono text-[9px] uppercase text-(--fe-text-muted)",children:l}),e.size!=null&&jsxRuntime.jsx("span",{className:"shrink-0 font-mono text-[10px] text-(--fe-text-muted)",children:tt(e.size)}),e.modifiedAt&&jsxRuntime.jsx("span",{className:"hidden shrink-0 font-mono text-[10px] text-(--fe-text-muted) lg:inline",children:Ve(e.modifiedAt)})]},e.path+n)})}):jsxRuntime.jsx("div",{className:"grid grid-cols-[repeat(auto-fill,minmax(90px,1fr))] gap-1.5 p-1",children:x.map((e,n)=>{let s=Te(e),o=b.has(n),l=e.extension||le(e.name);return jsxRuntime.jsxs("div",{className:u("fe-item group/item flex cursor-pointer flex-col items-center gap-1 rounded-lg px-2 py-2.5 text-center transition-all duration-150",o?"bg-(--fe-accent)/15 text-(--fe-text-strong) ring-1 ring-(--fe-accent)/30":"text-(--fe-text) hover:bg-(--fe-surface-hover) hover:text-(--fe-text-strong)"),onClick:y=>Ie(n,y),onDoubleClick:()=>He(n),children:[jsxRuntime.jsx(s,{className:u("h-7 w-7",e.type==="directory"?"text-(--fe-accent)":"text-(--fe-text-muted)")}),jsxRuntime.jsx("span",{className:"w-full truncate text-[10px] font-medium leading-tight",children:e.name}),l&&e.type==="file"&&jsxRuntime.jsx("span",{className:"font-mono text-[8px] uppercase text-(--fe-text-muted)",children:l})]},e.path+n)})})}),jsxRuntime.jsx("div",{className:u("overflow-hidden transition-[width,opacity] duration-300 ease-out",ye?u("absolute right-0 top-0 bottom-0 z-10",m?"w-44 opacity-100":"w-0 opacity-0 pointer-events-none"):u("shrink-0",m?"w-56":"w-0")),children:m&&jsxRuntime.jsxs("div",{className:u("flex h-full flex-col p-4",ye?"fe-panel-narrow w-44":"fe-panel w-56 border-l border-(--fe-border)"),children:[ye&&jsxRuntime.jsx("button",{className:"fe-btn mb-2 self-end",onClick:()=>{ee(null),P(new Set);},title:"Close panel",children:jsxRuntime.jsx(lucideReact.X,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsxs("div",{className:"mb-3 flex flex-col items-center",children:[Qe__default.default.createElement(Te(m),{className:u("h-10 w-10 mb-2",m.type==="directory"?"text-(--fe-accent)":"text-(--fe-text-muted)")}),jsxRuntime.jsx("span",{className:"w-full text-center text-xs font-semibold text-(--fe-text-strong) break-all leading-tight",children:m.name})]}),jsxRuntime.jsxs("div",{className:"space-y-2.5 text-[10px]",children:[jsxRuntime.jsx(Q,{label:"Type",value:m.type==="directory"?"Directory":m.mimeType||m.extension||le(m.name)||"File"}),m.size!=null&&jsxRuntime.jsx(Q,{label:"Size",value:tt(m.size)}),jsxRuntime.jsx(Q,{label:"Path",value:m.path,mono:true}),m.extension&&jsxRuntime.jsx(Q,{label:"Extension",value:m.extension}),m.modifiedAt&&jsxRuntime.jsx(Q,{label:"Modified",value:Ve(m.modifiedAt)}),m.createdAt&&jsxRuntime.jsx(Q,{label:"Created",value:Ve(m.createdAt)})]}),jsxRuntime.jsxs("div",{className:"mt-auto flex flex-col gap-1.5",children:[m.type==="file"&&L&&jsxRuntime.jsxs("button",{className:"flex items-center justify-center gap-1.5 rounded-lg py-1.5 text-[10px] font-semibold uppercase tracking-wider text-(--fe-text-strong) transition-colors",style:{background:"color-mix(in srgb, var(--fe-accent) 20%, transparent)",border:"1px solid color-mix(in srgb, var(--fe-accent) 30%, transparent)"},onClick:()=>L(m),children:[jsxRuntime.jsx(lucideReact.ArrowUp,{className:"h-3 w-3 rotate-45"}),"Open"]}),it?.map(e=>jsxRuntime.jsxs("button",{className:"fe-action flex items-center justify-center gap-1.5 rounded-lg py-1.5 text-[10px] font-semibold uppercase tracking-wider text-(--fe-text) transition-colors hover:text-(--fe-text-strong)",onClick:()=>e.onClick(m),children:[e.icon&&Qe__default.default.createElement(e.icon,{className:"h-3 w-3"}),e.label]},e.key))]})]})})]}),jsxRuntime.jsxs("div",{className:"fe-statusbar flex h-6 shrink-0 items-center justify-between px-3 text-[9px] font-mono text-(--fe-text-muted)",children:[jsxRuntime.jsxs("span",{children:[x.length," items"]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-2",children:[b.size>0&&jsxRuntime.jsxs("span",{className:"text-(--fe-accent)/70",children:[b.size," selected"]}),jsxRuntime.jsx("span",{className:"opacity-50",children:"Ctrl+Click multi-select \xB7 Esc clear"})]})]}),dt&&!c&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"absolute top-0 left-4 right-4 h-3 cursor-ns-resize",onMouseDown:e=>D("n",e),onTouchStart:e=>C("n",e)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 left-4 right-4 h-3 cursor-ns-resize",onMouseDown:e=>D("s",e),onTouchStart:e=>C("s",e)}),jsxRuntime.jsx("div",{className:"absolute top-4 left-0 bottom-4 w-3 cursor-ew-resize",onMouseDown:e=>D("w",e),onTouchStart:e=>C("w",e)}),jsxRuntime.jsx("div",{className:"absolute top-4 right-0 bottom-4 w-3 cursor-ew-resize",onMouseDown:e=>D("e",e),onTouchStart:e=>C("e",e)}),jsxRuntime.jsx("div",{className:"absolute top-0 left-0 h-6 w-6 cursor-nwse-resize",onMouseDown:e=>D("nw",e),onTouchStart:e=>C("nw",e)}),jsxRuntime.jsx("div",{className:"absolute top-0 right-0 h-6 w-6 cursor-nesw-resize",onMouseDown:e=>D("ne",e),onTouchStart:e=>C("ne",e)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 left-0 h-6 w-6 cursor-nesw-resize",onMouseDown:e=>D("sw",e),onTouchStart:e=>C("sw",e)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 right-0 h-6 w-6 cursor-nwse-resize",onMouseDown:e=>D("se",e),onTouchStart:e=>C("se",e)})]}),jsxRuntime.jsx("style",{children:`
1
+ 'use strict';var Qe=require('react'),clsx=require('clsx'),tailwindMerge=require('tailwind-merge'),reactDom=require('react-dom'),lucideReact=require('lucide-react'),classVarianceAuthority=require('class-variance-authority'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Qe__default=/*#__PURE__*/_interopDefault(Qe);function u(...t){return tailwindMerge.twMerge(clsx.clsx(t))}var ke=classVarianceAuthority.cva("rounded-lg bg-white p-6 shadow-xl dark:bg-primary-900",{variants:{size:{sm:"w-full max-w-sm",md:"w-full max-w-lg",lg:"w-full max-w-2xl",xl:"w-full max-w-4xl",full:"h-[calc(100vh-4rem)] w-[calc(100vw-4rem)]"}},defaultVariants:{size:"md"}});classVarianceAuthority.cva("absolute z-50 rounded px-2 py-1 text-xs shadow-md animate-fade-in",{variants:{intent:{default:"bg-primary-900 text-white dark:bg-primary-100 dark:text-primary-900",light:"border border-primary-200 bg-white text-primary-700 dark:border-primary-600 dark:bg-primary-800 dark:text-primary-200"}},defaultVariants:{intent:"default"}});var E=[];function _t(t){E.push(t);}function Tt(t){let a=E.indexOf(t);a!==-1&&E.splice(a,1);}function Ne(t){return E.length>0&&E[E.length-1]===t}function St(t){let a=E.indexOf(t);return a!==-1?a:E.length}var Xe=Qe.createContext(null);function Ye({open:t,onOpenChange:a,modal:p=true,closeOnOutsideClick:v=false,children:k}){let d=Qe.useId();return Qe.useEffect(()=>{if(t)return _t(d),()=>Tt(d)},[t,d]),Qe.useEffect(()=>{if(!t||!p)return;let T=A=>{A.key==="Escape"&&Ne(d)&&a(false);};return document.addEventListener("keydown",T),()=>document.removeEventListener("keydown",T)},[t,p,a,d]),Qe.useEffect(()=>{if(!t||!p)return;let T=document.body.style.overflow;return document.body.style.overflow="hidden",()=>{document.body.style.overflow=T;}},[t,p]),t?jsxRuntime.jsx(Xe.Provider,{value:{id:d,onOpenChange:a,modal:p,closeOnOutsideClick:v},children:reactDom.createPortal(k,document.body)}):null}function Ke({size:t,position:a="center",className:p,children:v,...k}){let d=Qe.useContext(Xe);if(!d)return null;let A=200+St(d.id)*10,J=()=>{d.closeOnOutsideClick&&Ne(d.id)&&d.onOpenChange(false);},S=a==="bottom";return d.modal?jsxRuntime.jsx("div",{className:u("animate-fade-in fixed inset-0 bg-black/50",S?"flex items-end justify-center":"flex items-center justify-center p-4"),style:{zIndex:A},onClick:J,children:jsxRuntime.jsx("div",{className:u(ke({size:t}),S?"animate-slide-in-bottom w-full rounded-b-none rounded-t-(--dialog-sheet-radius) max-h-[85vh] overflow-y-auto":"animate-scale-in",p),role:"dialog","aria-modal":"true",onClick:O=>O.stopPropagation(),...k,children:v})}):jsxRuntime.jsx("div",{className:u("fixed inset-0 flex items-center justify-center p-4",d.closeOnOutsideClick?"pointer-events-auto":"pointer-events-none"),style:{zIndex:A},onClick:d.closeOnOutsideClick&&Ne(d.id)?()=>d.onOpenChange(false):void 0,children:jsxRuntime.jsx("div",{className:u(ke({size:t}),"animate-scale-in pointer-events-auto shadow-2xl",p),role:"dialog",onClick:d.closeOnOutsideClick?O=>O.stopPropagation():void 0,...k,children:v})})}function $e({className:t,...a}){return jsxRuntime.jsx("div",{className:u("mb-4 space-y-1",t),...a})}function We({className:t,...a}){return jsxRuntime.jsx("h2",{className:u("text-primary-900 dark:text-primary-100 flex items-center gap-1.5 text-lg font-semibold [&_svg]:h-5 [&_svg]:w-5 [&_svg]:shrink-0",t),...a})}function qe({className:t,...a}){return jsxRuntime.jsx("p",{className:u("text-primary-500 dark:text-primary-400 text-sm",t),...a})}function Ge({className:t,...a}){return jsxRuntime.jsx("div",{className:u("mt-6 flex justify-end gap-2",t),...a})}var Ue=classVarianceAuthority.cva("inline-flex cursor-pointer items-center justify-center gap-1.5 rounded font-medium transition-colors disabled:pointer-events-none disabled:opacity-50 [&_svg]:shrink-0",{variants:{intent:{primary:"bg-primary-500 text-white hover:bg-primary-600 active:bg-primary-700",secondary:"bg-secondary-500 text-white hover:bg-secondary-600 active:bg-secondary-700",danger:"bg-danger-500 text-white hover:bg-danger-600 active:bg-danger-700",warning:"bg-warning-500 text-white hover:bg-warning-600 active:bg-warning-700",ghost:"bg-transparent text-primary-700 hover:bg-primary-100 active:bg-primary-200 dark:text-primary-300 dark:hover:bg-primary-800",outline:"border border-primary-300 bg-transparent text-primary-700 hover:bg-primary-50 dark:border-primary-600 dark:text-primary-300 dark:hover:bg-primary-800"},size:{sm:"h-7 px-3 text-xs [&_svg]:h-3.5 [&_svg]:w-3.5",md:"h-9 px-4 text-sm [&_svg]:h-4 [&_svg]:w-4",lg:"h-11 px-6 text-base [&_svg]:h-5 [&_svg]:w-5"}},defaultVariants:{intent:"primary",size:"md"}});classVarianceAuthority.cva("inline-flex items-center gap-1 rounded border font-semibold [&_svg]:shrink-0",{variants:{intent:{success:"border-success-200 bg-success-100 text-success-800 dark:border-success-800 dark:bg-success-900/30 dark:text-success-400",warning:"border-warning-200 bg-warning-100 text-warning-800 dark:border-warning-800 dark:bg-warning-900/30 dark:text-warning-400",error:"border-danger-200 bg-danger-100 text-danger-800 dark:border-danger-800 dark:bg-danger-900/30 dark:text-danger-400",info:"border-primary-200 bg-primary-100 text-primary-800 dark:border-primary-800 dark:bg-primary-900/30 dark:text-primary-400",primary:"border-secondary-200 bg-secondary-100 text-secondary-700 dark:border-secondary-700 dark:bg-secondary-800 dark:text-secondary-300"},size:{sm:"px-1.5 py-0 text-[0.625rem] [&_svg]:h-2.5 [&_svg]:w-2.5",md:"px-2.5 py-0.5 text-xs [&_svg]:h-3 [&_svg]:w-3",lg:"px-3 py-1 text-sm [&_svg]:h-3.5 [&_svg]:w-3.5"}},defaultVariants:{intent:"primary",size:"md"}});classVarianceAuthority.cva("absolute flex items-center justify-center rounded-full font-bold leading-none ring-2 ring-white select-none pointer-events-none z-10 dark:ring-primary-900",{variants:{intent:{danger:"bg-danger-500 text-white",success:"bg-success-500 text-white",warning:"bg-warning-500 text-white",info:"bg-primary-500 text-white",primary:"bg-secondary-500 text-white"},size:{sm:"text-[0.5rem]",md:"text-[0.625rem]",lg:"text-xs"},dot:{true:"",false:""},placement:{"top-right":"top-0 right-0 translate-x-1/2 -translate-y-1/2","top-left":"top-0 left-0 -translate-x-1/2 -translate-y-1/2","bottom-right":"bottom-0 right-0 translate-x-1/2 translate-y-1/2","bottom-left":"bottom-0 left-0 -translate-x-1/2 translate-y-1/2"}},compoundVariants:[{dot:true,size:"sm",class:"h-1.5 w-1.5 min-w-0 ring-1"},{dot:true,size:"md",class:"h-2 w-2 min-w-0"},{dot:true,size:"lg",class:"h-2.5 w-2.5 min-w-0"},{dot:false,size:"sm",class:"h-4 min-w-4 px-1"},{dot:false,size:"md",class:"h-5 min-w-5 px-1.5"},{dot:false,size:"lg",class:"h-6 min-w-6 px-2"}],defaultVariants:{intent:"danger",size:"md",dot:false,placement:"top-right"}});classVarianceAuthority.cva("w-full rounded-md border bg-white text-secondary-900 transition-colors placeholder:text-secondary-400 focus:outline-none focus:ring-2 dark:bg-secondary-900 dark:text-secondary-100 dark:placeholder:text-secondary-600",{variants:{state:{default:"border-secondary-300 focus:border-primary-500 focus:ring-primary-500/20 dark:border-secondary-600",error:"border-danger-400 focus:border-danger-500 focus:ring-danger-500/20"},size:{sm:"h-7 px-2 text-xs",md:"h-9 px-3 py-2 text-sm",lg:"h-11 px-4 py-2.5 text-base"}},defaultVariants:{state:"default",size:"md"}});classVarianceAuthority.cva("inline-flex items-center gap-1 font-medium [&_svg]:shrink-0",{variants:{size:{sm:"text-xs [&_svg]:h-3 [&_svg]:w-3",md:"text-sm [&_svg]:h-3.5 [&_svg]:w-3.5",lg:"text-base [&_svg]:h-4 [&_svg]:w-4"},intent:{default:"text-primary-700 dark:text-primary-300",muted:"text-primary-400 dark:text-primary-500",required:"text-primary-700 dark:text-primary-300 after:ml-0.5 after:text-danger-500 after:content-['*']"}},defaultVariants:{size:"md",intent:"default"}});classVarianceAuthority.cva("relative inline-flex shrink-0 items-center justify-center rounded border-2 transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2",{variants:{intent:{primary:"border-primary-300 dark:border-primary-600 focus-visible:ring-primary-500/40",secondary:"border-secondary-300 dark:border-secondary-600 focus-visible:ring-secondary-500/40",danger:"border-danger-300 dark:border-danger-600 focus-visible:ring-danger-500/40",warning:"border-warning-300 dark:border-warning-600 focus-visible:ring-warning-500/40",success:"border-success-300 dark:border-success-600 focus-visible:ring-success-500/40"},size:{sm:"h-4 w-4 rounded-[3px]",md:"h-5 w-5 rounded",lg:"h-6 w-6 rounded-[5px]"},checked:{on:"",off:"bg-white dark:bg-primary-900"}},compoundVariants:[{intent:"primary",checked:"on",class:"border-primary-500 bg-primary-500 dark:border-primary-500 dark:bg-primary-500"},{intent:"secondary",checked:"on",class:"border-secondary-500 bg-secondary-500 dark:border-secondary-500 dark:bg-secondary-500"},{intent:"danger",checked:"on",class:"border-danger-500 bg-danger-500 dark:border-danger-500 dark:bg-danger-500"},{intent:"warning",checked:"on",class:"border-warning-500 bg-warning-500 dark:border-warning-500 dark:bg-warning-500"},{intent:"success",checked:"on",class:"border-success-500 bg-success-500 dark:border-success-500 dark:bg-success-500"}],defaultVariants:{intent:"primary",size:"md",checked:"off"}});classVarianceAuthority.cva("relative inline-flex shrink-0 items-center justify-center rounded-full border-2 transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2",{variants:{intent:{primary:"border-primary-300 dark:border-primary-600 focus-visible:ring-primary-500/40",secondary:"border-secondary-300 dark:border-secondary-600 focus-visible:ring-secondary-500/40",danger:"border-danger-300 dark:border-danger-600 focus-visible:ring-danger-500/40",warning:"border-warning-300 dark:border-warning-600 focus-visible:ring-warning-500/40",success:"border-success-300 dark:border-success-600 focus-visible:ring-success-500/40"},size:{sm:"h-4 w-4",md:"h-5 w-5",lg:"h-6 w-6"},checked:{on:"",off:"bg-white dark:bg-primary-900"}},compoundVariants:[{intent:"primary",checked:"on",class:"border-primary-500 bg-primary-500 dark:border-primary-500 dark:bg-primary-500"},{intent:"secondary",checked:"on",class:"border-secondary-500 bg-secondary-500 dark:border-secondary-500 dark:bg-secondary-500"},{intent:"danger",checked:"on",class:"border-danger-500 bg-danger-500 dark:border-danger-500 dark:bg-danger-500"},{intent:"warning",checked:"on",class:"border-warning-500 bg-warning-500 dark:border-warning-500 dark:bg-warning-500"},{intent:"success",checked:"on",class:"border-success-500 bg-success-500 dark:border-success-500 dark:bg-success-500"}],defaultVariants:{intent:"primary",size:"md",checked:"off"}});classVarianceAuthority.cva("",{variants:{intent:{primary:"",secondary:"",danger:"",warning:"",success:""},size:{sm:"",md:"",lg:""},checked:{on:"",off:"bg-primary-300 dark:bg-primary-800"}},compoundVariants:[{intent:"primary",checked:"on",class:"bg-primary-500 dark:bg-primary-500"},{intent:"secondary",checked:"on",class:"bg-secondary-500 dark:bg-secondary-500"},{intent:"danger",checked:"on",class:"bg-danger-500 dark:bg-danger-500"},{intent:"warning",checked:"on",class:"bg-warning-500 dark:bg-warning-500"},{intent:"success",checked:"on",class:"bg-success-500 dark:bg-success-500"}],defaultVariants:{intent:"primary",size:"md",checked:"off"}});classVarianceAuthority.cva("bg-primary-200 text-primary-700 dark:bg-primary-700 dark:text-primary-200",{variants:{size:{xs:"h-6 w-6 text-[10px]",sm:"h-8 w-8 text-xs",md:"h-10 w-10 text-sm",lg:"h-12 w-12 text-base",xl:"h-16 w-16 text-lg"},shape:{circular:"rounded-full",rounded:"rounded-lg",square:"rounded-none"}},defaultVariants:{size:"md",shape:"circular"}});classVarianceAuthority.cva("inline-flex items-center",{variants:{size:{sm:"gap-0.5 [&_.rating-icon]:h-4 [&_.rating-icon]:w-4",md:"gap-1 [&_.rating-icon]:h-6 [&_.rating-icon]:w-6",lg:"gap-1.5 [&_.rating-icon]:h-8 [&_.rating-icon]:w-8"}},defaultVariants:{size:"md"}});classVarianceAuthority.cva("inline-flex items-center justify-center rounded font-mono font-medium select-none",{variants:{size:{xs:"h-4 min-w-4 px-1 text-[0.6rem]",sm:"h-5 min-w-5 px-1.5 text-xs",md:"h-6 min-w-6 px-2 text-sm",lg:"h-8 min-w-8 px-2.5 text-base"},variant:{default:"border border-secondary-300 bg-secondary-100 text-secondary-700 shadow-[0_2px_0_0_var(--color-secondary-300)] dark:border-secondary-600 dark:bg-secondary-800 dark:text-secondary-300 dark:shadow-[0_2px_0_0_var(--color-secondary-600)]",outline:"border border-secondary-400 bg-transparent text-secondary-700 dark:border-secondary-500 dark:text-secondary-300",ghost:"text-secondary-600 dark:text-secondary-400"}},defaultVariants:{size:"sm",variant:"default"}});classVarianceAuthority.cva("relative flex w-full touch-none select-none items-center",{variants:{intent:{primary:"[&_.slider-fill]:bg-primary-500 [&_.slider-thumb]:border-primary-500",secondary:"[&_.slider-fill]:bg-secondary-500 [&_.slider-thumb]:border-secondary-500",success:"[&_.slider-fill]:bg-success-500 [&_.slider-thumb]:border-success-500",danger:"[&_.slider-fill]:bg-danger-500 [&_.slider-thumb]:border-danger-500",warning:"[&_.slider-fill]:bg-warning-500 [&_.slider-thumb]:border-warning-500"},size:{sm:"h-4",md:"h-5",lg:"h-6"}},defaultVariants:{intent:"primary",size:"md"}});classVarianceAuthority.cva("inline-flex items-center gap-1 rounded-full font-medium select-none transition-colors [&_svg]:shrink-0",{variants:{intent:{primary:"bg-primary-100 text-primary-700 dark:bg-primary-800 dark:text-primary-200",secondary:"bg-secondary-100 text-secondary-700 dark:bg-secondary-800 dark:text-secondary-200",success:"bg-success-100 text-success-700 dark:bg-success-900/40 dark:text-success-300",danger:"bg-danger-100 text-danger-700 dark:bg-danger-900/40 dark:text-danger-300",warning:"bg-warning-100 text-warning-700 dark:bg-warning-900/40 dark:text-warning-300",info:"bg-blue-100 text-blue-700 dark:bg-blue-900/40 dark:text-blue-300"},size:{sm:"h-5 px-2 text-[0.6875rem] gap-0.5",md:"h-6 px-2.5 text-xs gap-1",lg:"h-7 px-3 text-sm gap-1"},variant:{solid:"",outline:"bg-transparent border",soft:""}},compoundVariants:[{intent:"primary",variant:"outline",class:"border-primary-300 text-primary-700 dark:border-primary-600 dark:text-primary-300"},{intent:"secondary",variant:"outline",class:"border-secondary-300 text-secondary-700 dark:border-secondary-600 dark:text-secondary-300"},{intent:"success",variant:"outline",class:"border-success-400 text-success-700 dark:border-success-600 dark:text-success-300"},{intent:"danger",variant:"outline",class:"border-danger-400 text-danger-700 dark:border-danger-600 dark:text-danger-300"},{intent:"warning",variant:"outline",class:"border-warning-400 text-warning-700 dark:border-warning-600 dark:text-warning-300"},{intent:"info",variant:"outline",class:"border-blue-400 text-blue-700 dark:border-blue-600 dark:text-blue-300"}],defaultVariants:{intent:"primary",size:"md",variant:"solid"}});classVarianceAuthority.cva("relative w-full cursor-pointer rounded-md border bg-white text-sm transition-colors dark:bg-primary-900",{variants:{intent:{default:"border-primary-300 text-primary-900 hover:border-primary-400 focus-within:border-primary-500 focus-within:ring-2 focus-within:ring-primary-500/20 dark:border-primary-600 dark:text-primary-100 dark:hover:border-primary-500 dark:focus-within:border-primary-400",danger:"border-danger-500 text-primary-900 focus-within:ring-2 focus-within:ring-danger-500/20 dark:border-danger-500 dark:text-primary-100"},size:{sm:"h-7 px-2 text-xs",md:"h-9 px-3 text-sm",lg:"h-11 px-4 text-base"}},defaultVariants:{intent:"default",size:"md"}});function Me({intent:t,size:a,className:p,...v}){return jsxRuntime.jsx("button",{className:u(Ue({intent:t,size:a}),p),...v})}function le(t){let a=t.lastIndexOf(".");return a>0?t.slice(a).toLowerCase():""}function tt(t){return t==null?"\u2014":t<1024?`${t} B`:t<1024*1024?`${(t/1024).toFixed(1)} KB`:t<1024*1024*1024?`${(t/(1024*1024)).toFixed(1)} MB`:`${(t/(1024*1024*1024)).toFixed(2)} GB`}function Ve(t){return t?(typeof t=="string"?new Date(t):t).toLocaleDateString(void 0,{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"}):"\u2014"}var $t={".png":lucideReact.Image,".jpg":lucideReact.Image,".jpeg":lucideReact.Image,".gif":lucideReact.Image,".svg":lucideReact.Image,".webp":lucideReact.Image,".ico":lucideReact.Image,".bmp":lucideReact.Image,".mp3":lucideReact.Music,".wav":lucideReact.Music,".flac":lucideReact.Music,".ogg":lucideReact.Music,".aac":lucideReact.Music,".m4a":lucideReact.Music,".mp4":lucideReact.Video,".mkv":lucideReact.Video,".avi":lucideReact.Video,".mov":lucideReact.Video,".wmv":lucideReact.Video,".webm":lucideReact.Video,".ts":lucideReact.FileCode,".tsx":lucideReact.FileCode,".js":lucideReact.FileCode,".jsx":lucideReact.FileCode,".json":lucideReact.FileCode,".html":lucideReact.FileCode,".css":lucideReact.FileCode,".scss":lucideReact.FileCode,".py":lucideReact.FileCode,".rs":lucideReact.FileCode,".go":lucideReact.FileCode,".java":lucideReact.FileCode,".c":lucideReact.FileCode,".cpp":lucideReact.FileCode,".h":lucideReact.FileCode,".sh":lucideReact.Terminal,".bat":lucideReact.Terminal,".ps1":lucideReact.Terminal,".md":lucideReact.FileText,".txt":lucideReact.FileText,".pdf":lucideReact.FileText,".doc":lucideReact.FileText,".docx":lucideReact.FileText,".rtf":lucideReact.FileText,".csv":lucideReact.FileSpreadsheet,".xls":lucideReact.FileSpreadsheet,".xlsx":lucideReact.FileSpreadsheet,".db":lucideReact.Database,".sqlite":lucideReact.Database,".sql":lucideReact.Database,".zip":lucideReact.FileArchive,".tar":lucideReact.FileArchive,".gz":lucideReact.FileArchive,".rar":lucideReact.FileArchive,".7z":lucideReact.FileArchive};function _e(t){if(t.type==="directory")return lucideReact.Folder;let a=t.extension||le(t.name);return $t[a]||lucideReact.File}function U(t,a,p){return Math.max(a,Math.min(p,t))}function rt(t){return t<480?"xs":t<640?"sm":t<1024?"md":"lg"}function nt(t,a){if(t<480)return {size:{width:t-16,height:a-48},pos:{x:8,y:24}};if(t<640){let k=t-24,d=Math.min(a-64,540);return {size:{width:k,height:d},pos:{x:12,y:32}}}if(t<1024){let k=Math.min(640,t-32),d=Math.min(480,a-64);return {size:{width:k,height:d},pos:{x:Math.max(0,Math.round((t-k)/2)),y:Math.max(0,Math.round((a-d)/2))}}}let p=720,v=520;return {size:{width:p,height:v},pos:{x:Math.max(0,Math.round((t-p)/2)),y:Math.max(0,Math.round((a-v)/2))}}}function Hr({files:t,title:a="File Explorer",accent:p="#8b5cf6",defaultView:v="list",initialPosition:k,initialSize:d,dockable:T=false,dockSide:A="right",visible:J=true,onFileOpen:S,onSelectionChange:O,onNavigate:ie,onDelete:ue,onClose:st,onMinimize:Te,onPathSubmit:Se,defaultInputMode:ot="search",actions:it,resizable:dt=true,minSize:Z={width:400,height:300},className:ct}){let[me,lt]=Qe.useState(v),[x,P]=Qe.useState(new Set),[Le,ee]=Qe.useState(null),[c,pe]=Qe.useState(false),[te,ge]=Qe.useState(false),[L,ut]=Qe.useState(""),[F,mt]=Qe.useState(ot),[pt,gt]=Qe.useState(J),[ft,de]=Qe.useState(false),[B,xt]=Qe.useState({w:window.innerWidth,h:window.innerHeight}),Fe=nt(window.innerWidth,window.innerHeight),[g,j]=Qe.useState(k??Fe.pos),[z,ce]=Qe.useState(d??Fe.size),[M,bt]=Qe.useState(null),re=Qe.useRef(false),X=Qe.useRef({x:0,y:0}),fe=Qe.useRef(null),R=Qe.useRef(false),ne=Qe.useRef({x:0,y:0,w:0,h:0,px:0,py:0}),ae=Qe.useRef(false),Re=Qe.useRef(c);Qe.useEffect(()=>{Re.current=c;},[c]);let xe=J!==void 0?J:pt,be=Qe.useMemo(()=>{let e=t.filter(s=>s.type==="directory"),n=t.filter(s=>s.type==="file");return e.sort((s,o)=>s.name.localeCompare(o.name)),n.sort((s,o)=>s.name.localeCompare(o.name)),[...e,...n]},[t]),b=Qe.useMemo(()=>{if(F!=="search"||!L.trim())return be;let e=L.toLowerCase();return be.filter(n=>n.name.toLowerCase().includes(e))},[be,L,F]),m=Le!=null?b[Le]:null;Qe.useEffect(()=>{let e=rt(window.innerWidth),n=()=>{let s=window.innerWidth,o=window.innerHeight;if(xt({w:s,h:o}),Re.current)return;let l=rt(s);if(l!==e&&!ae.current&&!d){let w=nt(s,o);ce(w.size),j(w.pos);}e=l;};return window.addEventListener("resize",n),()=>window.removeEventListener("resize",n)},[d]);let Ie=Qe.useCallback((e,n)=>{P(s=>{let o=new Set(s);return n.ctrlKey||n.metaKey?o.has(e)?o.delete(e):o.add(e):(o.clear(),o.add(e)),o}),ee(e);},[]);Qe.useEffect(()=>{if(!O)return;let e=Array.from(x).map(n=>b[n]).filter(Boolean);O(e);},[x]);let He=Qe.useCallback(e=>{let n=b[e];n&&(n.type==="directory"?ie?.(n.path):S?.(n));},[b,S,ie]),ht=Qe.useCallback(e=>{c||e.target.closest("button")||(ae.current=true,re.current=true,X.current={x:e.clientX-g.x,y:e.clientY-g.y},e.preventDefault());},[g,c]),yt=Qe.useCallback(e=>{if(c||e.target.closest("button"))return;ae.current=true;let n=e.touches[0];re.current=true,X.current={x:n.clientX-g.x,y:n.clientY-g.y};},[g,c]);Qe.useEffect(()=>{let e=o=>{if(!re.current)return;let l=window.innerWidth-100,w=window.innerHeight-40;j({x:U(o.clientX-X.current.x,0,l),y:U(o.clientY-X.current.y,0,w)});},n=o=>{if(!re.current)return;o.preventDefault();let l=o.touches[0],w=window.innerWidth-100,I=window.innerHeight-40;j({x:U(l.clientX-X.current.x,0,w),y:U(l.clientY-X.current.y,0,I)});},s=()=>{re.current=false,R.current=false,document.body.style.cursor="",document.body.style.userSelect="";};return window.addEventListener("mousemove",e),window.addEventListener("mouseup",s),window.addEventListener("touchmove",n,{passive:false}),window.addEventListener("touchend",s),()=>{window.removeEventListener("mousemove",e),window.removeEventListener("mouseup",s),window.removeEventListener("touchmove",n),window.removeEventListener("touchend",s);}},[]);let D=Qe.useCallback((e,n)=>{c||(n.preventDefault(),n.stopPropagation(),ae.current=true,R.current=e,ne.current={x:n.clientX,y:n.clientY,w:z.width,h:z.height,px:g.x,py:g.y},document.body.style.cursor=e==="e"||e==="w"?"ew-resize":e==="n"||e==="s"?"ns-resize":e==="nw"||e==="se"?"nwse-resize":"nesw-resize",document.body.style.userSelect="none");},[c,z,g]),C=Qe.useCallback((e,n)=>{if(c)return;n.preventDefault(),n.stopPropagation(),ae.current=true;let s=n.touches[0];R.current=e,ne.current={x:s.clientX,y:s.clientY,w:z.width,h:z.height,px:g.x,py:g.y},document.body.style.userSelect="none";},[c,z,g]);Qe.useEffect(()=>{let e=(l,w)=>{let I=R.current;if(!I)return;let Pe=l-ne.current.x,Be=w-ne.current.y,{w:Y,h:K,px:we,py:ve}=ne.current;if(I.includes("e")&&(Y=Math.max(Z.width,Y+Pe)),I.includes("w")){let se=Math.max(Z.width,Y-Pe);we=we+(Y-se),Y=se;}if(I.includes("s")&&(K=Math.max(Z.height,K+Be)),I.includes("n")){let se=Math.max(Z.height,K-Be);ve=ve+(K-se),K=se;}ce({width:Y,height:K}),j({x:we,y:ve});},n=l=>{R.current&&e(l.clientX,l.clientY);},s=l=>{R.current&&(l.preventDefault(),e(l.touches[0].clientX,l.touches[0].clientY));},o=()=>{R.current=false,document.body.style.cursor="",document.body.style.userSelect="";};return window.addEventListener("mousemove",n),window.addEventListener("mouseup",o),window.addEventListener("touchmove",s,{passive:false}),window.addEventListener("touchend",o),()=>{window.removeEventListener("mousemove",n),window.removeEventListener("mouseup",o),window.removeEventListener("touchmove",s),window.removeEventListener("touchend",o);}},[Z]);let Ae=Qe.useCallback(()=>{c?(M&&(j(M.pos),ce(M.size)),pe(false)):(bt({pos:g,size:z}),pe(true));},[c,g,z,M]),wt=Qe.useCallback(()=>{te?ge(false):(c&&(pe(false),M&&(j(M.pos),ce(M.size))),ge(true),Te?.());},[te,c,M,Te]);Qe.useEffect(()=>{if(!xe||te)return;let e=n=>{if(!(!fe.current?.contains(document.activeElement)&&document.activeElement!==fe.current)){if(n.key==="Escape"&&(ee(null),P(new Set)),n.ctrlKey&&n.key==="a"){n.preventDefault();let s=new Set(b.map((o,l)=>l));P(s);}n.key==="Delete"&&x.size>0&&ue&&(n.preventDefault(),de(true));}};return window.addEventListener("keydown",e),()=>window.removeEventListener("keydown",e)},[xe,te,b,x,ue]);let Oe={"--fe-accent":p};if(te)return jsxRuntime.jsx("div",{className:u("fixed z-100 cursor-pointer transition-all duration-300",A==="right"?"right-0 top-1/2 -translate-y-1/2":"left-0 top-1/2 -translate-y-1/2"),style:Oe,onClick:()=>ge(false),title:`Restore ${a}`,children:jsxRuntime.jsxs("div",{className:"fe-dock flex items-center gap-1.5 rounded-l-lg px-2 py-3 backdrop-blur-md",style:{writingMode:"vertical-rl",textOrientation:"mixed"},children:[jsxRuntime.jsx(lucideReact.HardDrive,{className:"h-3.5 w-3.5 text-(--fe-accent)"}),jsxRuntime.jsx("span",{className:"text-[10px] font-bold uppercase tracking-widest text-(--fe-text)",children:a})]})});if(!xe)return null;let he=c?B.w:Math.min(z.width,B.w-8),vt=c?B.h:Math.min(z.height,B.h-8),kt=c?0:U(g.x,0,Math.max(0,B.w-he)),zt=c?0:U(g.y,0,Math.max(0,B.h-40)),ye=he<500;return jsxRuntime.jsxs("div",{ref:fe,className:u("fe-window fixed z-100 flex flex-col overflow-hidden","rounded-xl border border-(--fe-border)","animate-[fe-window-in_0.35s_cubic-bezier(0.16,1,0.3,1)_both]",c&&"rounded-none",ct),style:{...Oe,left:kt,top:zt,width:he,height:vt,transition:c?"left 0.3s, top 0.3s, width 0.3s, height 0.3s":void 0},tabIndex:0,children:[jsxRuntime.jsxs("div",{className:"fe-titlebar group/titlebar flex h-10 shrink-0 cursor-grab items-center justify-between px-3 select-none active:cursor-grabbing",onMouseDown:ht,onTouchStart:yt,onDoubleClick:Ae,children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-2",children:[jsxRuntime.jsx("div",{className:"flex h-5 w-5 items-center justify-center rounded",style:{background:"color-mix(in srgb, var(--fe-accent) 25%, transparent)"},children:jsxRuntime.jsx(lucideReact.HardDrive,{className:"h-3 w-3 text-(--fe-accent)"})}),jsxRuntime.jsx("span",{className:"text-xs font-bold uppercase tracking-widest text-(--fe-text)",children:a}),jsxRuntime.jsx("div",{className:"ml-2 hidden h-px w-20 md:block",style:{background:"linear-gradient(90deg, var(--fe-accent), transparent)",opacity:.3}})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-0.5",children:[jsxRuntime.jsx("button",{className:"fe-btn mr-1",onClick:()=>lt(e=>e==="list"?"grid":"list"),title:me==="list"?"Grid view":"List view",children:me==="list"?jsxRuntime.jsx(lucideReact.LayoutGrid,{className:"h-3.5 w-3.5"}):jsxRuntime.jsx(lucideReact.LayoutList,{className:"h-3.5 w-3.5"})}),T&&jsxRuntime.jsx("button",{className:"fe-btn",onClick:wt,title:"Dock to edge",children:jsxRuntime.jsx(lucideReact.Minus,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:"fe-btn",onClick:Ae,title:c?"Restore":"Maximize",children:c?jsxRuntime.jsx(lucideReact.Minimize2,{className:"h-3.5 w-3.5"}):jsxRuntime.jsx(lucideReact.Maximize2,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:"fe-btn hover:bg-red-500/40! hover:text-red-300!",onClick:()=>{st?.(),gt(false);},title:"Close",children:jsxRuntime.jsx(lucideReact.X,{className:"h-3.5 w-3.5"})})]})]}),jsxRuntime.jsxs("div",{className:"fe-toolbar flex h-9 shrink-0 items-center gap-2 px-3",children:[jsxRuntime.jsx("button",{className:"fe-btn p-1",onClick:()=>ie?.(".."),title:"Go up",children:jsxRuntime.jsx(lucideReact.FolderUp,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:"fe-btn shrink-0 px-1.5 py-0.5 text-[9px] font-bold uppercase tracking-wider",style:F==="navigate"?{color:"var(--fe-accent)",background:"color-mix(in srgb, var(--fe-accent) 15%, transparent)"}:void 0,onClick:()=>mt(e=>e==="search"?"navigate":"search"),title:F==="search"?"Switch to path navigation":"Switch to file search",children:F==="search"?jsxRuntime.jsx(lucideReact.Search,{className:"h-3 w-3"}):jsxRuntime.jsx(lucideReact.CornerRightDown,{className:"h-3 w-3"})}),jsxRuntime.jsx("div",{className:"relative flex-1",children:jsxRuntime.jsx("input",{type:"text",value:L,onChange:e=>ut(e.target.value),onKeyDown:e=>{e.key==="Enter"&&L.trim()&&F==="navigate"&&(Se?Se(L.trim()):ie?.(L.trim()));},placeholder:F==="search"?"Search files\u2026":"Enter path and press Enter\u2026",className:"h-6 w-full rounded border border-(--fe-input-border) bg-(--fe-input-bg) px-2 text-[11px] text-(--fe-text-strong) placeholder:text-(--fe-text-muted) outline-none transition-colors focus:border-(--fe-accent)/40 focus:bg-(--fe-input-bg)"})}),jsxRuntime.jsxs("span",{className:"shrink-0 font-mono text-[10px] text-(--fe-text-muted)",children:[b.length," item",b.length!==1?"s":"",x.size>0&&` \xB7 ${x.size} selected`]})]}),jsxRuntime.jsxs("div",{className:"relative flex flex-1 min-h-0",children:[jsxRuntime.jsx("div",{className:"flex-1 overflow-y-auto overflow-x-hidden p-1.5",onClick:e=>{e.target===e.currentTarget&&(P(new Set),ee(null));},children:b.length===0?jsxRuntime.jsxs("div",{className:"flex h-full flex-col items-center justify-center text-(--fe-text-muted)",children:[jsxRuntime.jsx(lucideReact.Folder,{className:"mb-2 h-10 w-10"}),jsxRuntime.jsx("span",{className:"text-xs",children:"No files found"})]}):me==="list"?jsxRuntime.jsx("div",{className:"space-y-px",children:b.map((e,n)=>{let s=_e(e),o=x.has(n),l=e.extension||le(e.name);return jsxRuntime.jsxs("div",{className:u("fe-item group/item flex items-center gap-2.5 rounded-lg px-2.5 py-1.5 text-(--fe-text) transition-all duration-150 cursor-pointer",o?"bg-(--fe-accent)/15 text-(--fe-text-strong)":"hover:bg-(--fe-surface-hover) hover:text-(--fe-text-strong)"),style:o?{boxShadow:"inset 2px 0 0 var(--fe-accent)"}:void 0,onClick:w=>Ie(n,w),onDoubleClick:()=>He(n),children:[jsxRuntime.jsx(s,{className:u("h-4 w-4 shrink-0",e.type==="directory"?"text-(--fe-accent)":"text-(--fe-text-muted)")}),jsxRuntime.jsx("span",{className:"flex-1 truncate text-xs font-medium",children:e.name}),l&&e.type==="file"&&jsxRuntime.jsx("span",{className:"shrink-0 rounded bg-(--fe-badge-bg) px-1.5 py-0.5 font-mono text-[9px] uppercase text-(--fe-text-muted)",children:l}),e.size!=null&&jsxRuntime.jsx("span",{className:"shrink-0 font-mono text-[10px] text-(--fe-text-muted)",children:tt(e.size)}),e.modifiedAt&&jsxRuntime.jsx("span",{className:"hidden shrink-0 font-mono text-[10px] text-(--fe-text-muted) lg:inline",children:Ve(e.modifiedAt)})]},e.path+n)})}):jsxRuntime.jsx("div",{className:"grid grid-cols-[repeat(auto-fill,minmax(90px,1fr))] gap-1.5 p-1",children:b.map((e,n)=>{let s=_e(e),o=x.has(n),l=e.extension||le(e.name);return jsxRuntime.jsxs("div",{className:u("fe-item group/item flex cursor-pointer flex-col items-center gap-1 rounded-lg px-2 py-2.5 text-center transition-all duration-150",o?"bg-(--fe-accent)/15 text-(--fe-text-strong) ring-1 ring-(--fe-accent)/30":"text-(--fe-text) hover:bg-(--fe-surface-hover) hover:text-(--fe-text-strong)"),onClick:w=>Ie(n,w),onDoubleClick:()=>He(n),children:[jsxRuntime.jsx(s,{className:u("h-7 w-7",e.type==="directory"?"text-(--fe-accent)":"text-(--fe-text-muted)")}),jsxRuntime.jsx("span",{className:"w-full truncate text-[10px] font-medium leading-tight",children:e.name}),l&&e.type==="file"&&jsxRuntime.jsx("span",{className:"font-mono text-[8px] uppercase text-(--fe-text-muted)",children:l})]},e.path+n)})})}),jsxRuntime.jsx("div",{className:u("overflow-hidden transition-[width,opacity] duration-300 ease-out",ye?u("absolute right-0 top-0 bottom-0 z-10",m?"w-44 opacity-100":"w-0 opacity-0 pointer-events-none"):u("shrink-0",m?"w-56":"w-0")),children:m&&jsxRuntime.jsxs("div",{className:u("flex h-full flex-col p-4",ye?"fe-panel-narrow w-44":"fe-panel w-56 border-l border-(--fe-border)"),children:[ye&&jsxRuntime.jsx("button",{className:"fe-btn mb-2 self-end",onClick:()=>{ee(null),P(new Set);},title:"Close panel",children:jsxRuntime.jsx(lucideReact.X,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsxs("div",{className:"mb-3 flex flex-col items-center",children:[Qe__default.default.createElement(_e(m),{className:u("h-10 w-10 mb-2",m.type==="directory"?"text-(--fe-accent)":"text-(--fe-text-muted)")}),jsxRuntime.jsx("span",{className:"w-full text-center text-xs font-semibold text-(--fe-text-strong) break-all leading-tight",children:m.name})]}),jsxRuntime.jsxs("div",{className:"space-y-2.5 text-[10px]",children:[jsxRuntime.jsx(Q,{label:"Type",value:m.type==="directory"?"Directory":m.mimeType||m.extension||le(m.name)||"File"}),m.size!=null&&jsxRuntime.jsx(Q,{label:"Size",value:tt(m.size)}),jsxRuntime.jsx(Q,{label:"Path",value:m.path,mono:true}),m.extension&&jsxRuntime.jsx(Q,{label:"Extension",value:m.extension}),m.modifiedAt&&jsxRuntime.jsx(Q,{label:"Modified",value:Ve(m.modifiedAt)}),m.createdAt&&jsxRuntime.jsx(Q,{label:"Created",value:Ve(m.createdAt)})]}),jsxRuntime.jsxs("div",{className:"mt-auto flex flex-col gap-1.5",children:[m.type==="file"&&S&&jsxRuntime.jsxs("button",{className:"flex items-center justify-center gap-1.5 rounded-lg py-1.5 text-[10px] font-semibold uppercase tracking-wider text-(--fe-text-strong) transition-colors",style:{background:"color-mix(in srgb, var(--fe-accent) 20%, transparent)",border:"1px solid color-mix(in srgb, var(--fe-accent) 30%, transparent)"},onClick:()=>S(m),children:[jsxRuntime.jsx(lucideReact.ArrowUp,{className:"h-3 w-3 rotate-45"}),"Open"]}),it?.map(e=>jsxRuntime.jsxs("button",{className:"fe-action flex items-center justify-center gap-1.5 rounded-lg py-1.5 text-[10px] font-semibold uppercase tracking-wider text-(--fe-text) transition-colors hover:text-(--fe-text-strong)",onClick:()=>e.onClick(m),children:[e.icon&&Qe__default.default.createElement(e.icon,{className:"h-3 w-3"}),e.label]},e.key))]})]})})]}),jsxRuntime.jsxs("div",{className:"fe-statusbar flex h-6 shrink-0 items-center justify-between px-3 text-[9px] font-mono text-(--fe-text-muted)",children:[jsxRuntime.jsxs("span",{children:[b.length," items"]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-2",children:[x.size>0&&jsxRuntime.jsxs("span",{className:"text-(--fe-accent)/70",children:[x.size," selected"]}),jsxRuntime.jsx("span",{className:"opacity-50",children:"Ctrl+Click multi-select \xB7 Esc clear"})]})]}),dt&&!c&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"absolute top-0 left-4 right-4 h-3 cursor-ns-resize",onMouseDown:e=>D("n",e),onTouchStart:e=>C("n",e)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 left-4 right-4 h-3 cursor-ns-resize",onMouseDown:e=>D("s",e),onTouchStart:e=>C("s",e)}),jsxRuntime.jsx("div",{className:"absolute top-4 left-0 bottom-4 w-3 cursor-ew-resize",onMouseDown:e=>D("w",e),onTouchStart:e=>C("w",e)}),jsxRuntime.jsx("div",{className:"absolute top-4 right-0 bottom-4 w-3 cursor-ew-resize",onMouseDown:e=>D("e",e),onTouchStart:e=>C("e",e)}),jsxRuntime.jsx("div",{className:"absolute top-0 left-0 h-6 w-6 cursor-nwse-resize",onMouseDown:e=>D("nw",e),onTouchStart:e=>C("nw",e)}),jsxRuntime.jsx("div",{className:"absolute top-0 right-0 h-6 w-6 cursor-nesw-resize",onMouseDown:e=>D("ne",e),onTouchStart:e=>C("ne",e)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 left-0 h-6 w-6 cursor-nesw-resize",onMouseDown:e=>D("sw",e),onTouchStart:e=>C("sw",e)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 right-0 h-6 w-6 cursor-nwse-resize",onMouseDown:e=>D("se",e),onTouchStart:e=>C("se",e)})]}),jsxRuntime.jsx("style",{children:`
2
2
  .fe-window {
3
3
  background: var(--fe-bg);
4
4
  box-shadow: var(--fe-shadow);
@@ -59,4 +59,4 @@
59
59
  from { opacity: 0; transform: translateX(-4px); }
60
60
  to { opacity: 1; transform: translateX(0); }
61
61
  }
62
- `}),jsxRuntime.jsx(Ye,{open:ft,onOpenChange:de,children:jsxRuntime.jsxs(Ke,{size:"sm",children:[jsxRuntime.jsxs($e,{children:[jsxRuntime.jsxs(We,{children:[jsxRuntime.jsx(lucideReact.AlertTriangle,{className:"text-danger-500"}),"Confirm Deletion"]}),jsxRuntime.jsxs(qe,{children:[b.size===1?`Are you sure you want to delete "${x[Array.from(b)[0]]?.name}"?`:`Are you sure you want to delete ${b.size} selected items?`," ","This action cannot be undone."]})]}),jsxRuntime.jsxs(Ge,{children:[jsxRuntime.jsx(Me,{intent:"ghost",onClick:()=>de(false),children:"Cancel"}),jsxRuntime.jsxs(Me,{intent:"danger",onClick:()=>{let e=Array.from(b).map(n=>x[n]).filter(Boolean);ue?.(e),P(new Set),ee(null),de(false);},children:[jsxRuntime.jsx(lucideReact.Trash2,{className:"h-4 w-4"}),"Delete"]})]})]})})]})}function Q({label:t,value:a,mono:p}){return jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"mb-0.5 font-semibold uppercase tracking-wider text-(--fe-text-muted)",children:t}),jsxRuntime.jsx("div",{className:u("text-(--fe-text) break-all leading-snug",p&&"font-mono text-[9px]"),children:a})]})}exports.FileExplorer=Rr;
62
+ `}),jsxRuntime.jsx(Ye,{open:ft,onOpenChange:de,children:jsxRuntime.jsxs(Ke,{size:"sm",children:[jsxRuntime.jsxs($e,{children:[jsxRuntime.jsxs(We,{children:[jsxRuntime.jsx(lucideReact.AlertTriangle,{className:"text-danger-500"}),"Confirm Deletion"]}),jsxRuntime.jsxs(qe,{children:[x.size===1?`Are you sure you want to delete "${b[Array.from(x)[0]]?.name}"?`:`Are you sure you want to delete ${x.size} selected items?`," ","This action cannot be undone."]})]}),jsxRuntime.jsxs(Ge,{children:[jsxRuntime.jsx(Me,{intent:"ghost",onClick:()=>de(false),children:"Cancel"}),jsxRuntime.jsxs(Me,{intent:"danger",onClick:()=>{let e=Array.from(x).map(n=>b[n]).filter(Boolean);ue?.(e),P(new Set),ee(null),de(false);},children:[jsxRuntime.jsx(lucideReact.Trash2,{className:"h-4 w-4"}),"Delete"]})]})]})})]})}function Q({label:t,value:a,mono:p}){return jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"mb-0.5 font-semibold uppercase tracking-wider text-(--fe-text-muted)",children:t}),jsxRuntime.jsx("div",{className:u("text-(--fe-text) break-all leading-snug",p&&"font-mono text-[9px]"),children:a})]})}exports.FileExplorer=Hr;