@jacshuo/onyx 2.1.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.
- package/README.md +358 -361
- package/dist/Chart/BarChart.cjs +1 -1
- package/dist/Chart/BarChart.js +1 -1
- package/dist/Chart/PieChart.cjs +1 -1
- package/dist/Chart/PieChart.js +1 -1
- package/dist/Chart/ScatterChart.cjs +1 -1
- package/dist/Chart/ScatterChart.js +1 -1
- package/dist/Chart/index.cjs +1 -1
- package/dist/Chart/index.js +1 -1
- package/dist/DataDisplay/VirtualList.cjs +2 -0
- package/dist/DataDisplay/VirtualList.css +1 -0
- package/dist/DataDisplay/VirtualList.d.cts +5 -0
- package/dist/DataDisplay/VirtualList.d.ts +5 -0
- package/dist/DataDisplay/VirtualList.js +2 -0
- package/dist/DataDisplay/index.cjs +3 -2
- package/dist/DataDisplay/index.css +1 -0
- package/dist/DataDisplay/index.d.cts +5 -0
- package/dist/DataDisplay/index.d.ts +5 -0
- package/dist/DataDisplay/index.js +3 -2
- package/dist/Extras/DateTimePicker.cjs +1 -0
- package/dist/Extras/DateTimePicker.css +1 -0
- package/dist/Extras/DateTimePicker.d.cts +5 -0
- package/dist/Extras/DateTimePicker.d.ts +5 -0
- package/dist/Extras/DateTimePicker.js +1 -0
- package/dist/Extras/FileExplorer.cjs +2 -2
- package/dist/Extras/FileExplorer.js +2 -2
- package/dist/Extras/LoginPanel.cjs +1 -0
- package/dist/Extras/LoginPanel.css +1 -0
- package/dist/Extras/LoginPanel.d.cts +3 -0
- package/dist/Extras/LoginPanel.d.ts +3 -0
- package/dist/Extras/LoginPanel.js +1 -0
- package/dist/Extras/RichTextEditor.cjs +45 -0
- package/dist/Extras/RichTextEditor.css +1 -0
- package/dist/Extras/RichTextEditor.d.cts +10 -0
- package/dist/Extras/RichTextEditor.d.ts +10 -0
- package/dist/Extras/RichTextEditor.js +45 -0
- package/dist/Extras/index.cjs +48 -4
- package/dist/Extras/index.css +1 -1
- package/dist/Extras/index.d.cts +12 -0
- package/dist/Extras/index.d.ts +12 -0
- package/dist/Extras/index.js +48 -4
- package/dist/Forms/Form.cjs +1 -1
- package/dist/Forms/Form.js +1 -1
- package/dist/Forms/OTPInput.cjs +1 -0
- package/dist/Forms/OTPInput.css +1 -0
- package/dist/Forms/OTPInput.d.cts +4 -0
- package/dist/Forms/OTPInput.d.ts +4 -0
- package/dist/Forms/OTPInput.js +1 -0
- package/dist/Forms/Select.cjs +1 -1
- package/dist/Forms/Select.js +1 -1
- package/dist/Forms/index.cjs +1 -1
- package/dist/Forms/index.css +1 -0
- package/dist/Forms/index.d.cts +4 -0
- package/dist/Forms/index.d.ts +4 -0
- package/dist/Forms/index.js +1 -1
- package/dist/Layout/SplitPanel.cjs +1 -0
- package/dist/Layout/SplitPanel.d.cts +3 -0
- package/dist/Layout/SplitPanel.d.ts +3 -0
- package/dist/Layout/SplitPanel.js +1 -0
- package/dist/Layout/index.cjs +1 -1
- package/dist/Layout/index.d.cts +3 -0
- package/dist/Layout/index.d.ts +3 -0
- package/dist/Layout/index.js +1 -1
- package/dist/Navigation/Header.cjs +1 -1
- package/dist/Navigation/Header.js +1 -1
- package/dist/Navigation/RibbonBar.d.cts +3 -3
- package/dist/Navigation/RibbonBar.d.ts +3 -3
- package/dist/Navigation/SideNav.cjs +1 -1
- package/dist/Navigation/SideNav.js +1 -1
- package/dist/Navigation/index.cjs +2 -2
- package/dist/Navigation/index.d.cts +3 -3
- package/dist/Navigation/index.d.ts +3 -3
- package/dist/Navigation/index.js +2 -2
- package/dist/Primitives/Avatar.cjs +1 -1
- package/dist/Primitives/Avatar.js +1 -1
- package/dist/Primitives/Badge.cjs +1 -1
- package/dist/Primitives/Badge.js +1 -1
- package/dist/Primitives/Button.cjs +1 -1
- package/dist/Primitives/Button.js +1 -1
- package/dist/Primitives/Checkbox.cjs +1 -1
- package/dist/Primitives/Checkbox.js +1 -1
- package/dist/Primitives/Dropdown.cjs +1 -1
- package/dist/Primitives/Dropdown.js +1 -1
- package/dist/Primitives/DropdownButton.cjs +1 -1
- package/dist/Primitives/DropdownButton.js +1 -1
- package/dist/Primitives/Indicator.cjs +1 -1
- package/dist/Primitives/Indicator.js +1 -1
- package/dist/Primitives/Input.cjs +1 -1
- package/dist/Primitives/Input.js +1 -1
- package/dist/Primitives/Kbd.cjs +1 -0
- package/dist/Primitives/Kbd.css +0 -0
- package/dist/Primitives/Kbd.d.cts +6 -0
- package/dist/Primitives/Kbd.d.ts +6 -0
- package/dist/Primitives/Kbd.js +1 -0
- package/dist/Primitives/Label.cjs +1 -1
- package/dist/Primitives/Label.js +1 -1
- package/dist/Primitives/Radio.cjs +1 -1
- package/dist/Primitives/Radio.js +1 -1
- package/dist/Primitives/Rating.cjs +2 -0
- package/dist/Primitives/Rating.css +0 -0
- package/dist/Primitives/Rating.d.cts +4 -0
- package/dist/Primitives/Rating.d.ts +4 -0
- package/dist/Primitives/Rating.js +2 -0
- package/dist/Primitives/Slider.cjs +1 -1
- package/dist/Primitives/Slider.js +1 -1
- package/dist/Primitives/Switch.cjs +1 -1
- package/dist/Primitives/Switch.js +1 -1
- package/dist/Primitives/Tag.cjs +1 -1
- package/dist/Primitives/Tag.js +1 -1
- package/dist/Primitives/index.cjs +2 -1
- package/dist/Primitives/index.d.cts +10 -0
- package/dist/Primitives/index.d.ts +10 -0
- package/dist/Primitives/index.js +2 -1
- package/dist/_tsup-dts-rollup.d.cts +990 -3
- package/dist/_tsup-dts-rollup.d.ts +990 -3
- package/dist/index.cjs +49 -5
- package/dist/index.css +1 -1
- package/dist/index.d.cts +40 -0
- package/dist/index.d.ts +40 -0
- package/dist/index.js +49 -5
- package/dist/styles/DataDisplay/VirtualList.css +35 -0
- package/dist/styles/Extras/DateTimePicker.css +566 -0
- package/dist/styles/Extras/LoginPanel.css +16 -0
- package/dist/styles/Extras/RichTextEditor.css +908 -0
- package/dist/styles/Forms/OTPInput.css +11 -0
- package/dist/styles/Layout/SplitPanel.css +15 -0
- package/dist/styles/Primitives/Kbd.css +1 -0
- package/dist/styles/Primitives/Rating.css +1 -0
- package/dist/styles/base.css +312 -7
- package/dist/styles.css +770 -7
- package/dist/theme.cjs +1 -1
- package/dist/theme.d.cts +3 -0
- package/dist/theme.d.ts +3 -0
- package/dist/theme.js +1 -1
- package/package.json +21 -1
package/dist/Extras/index.cjs
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
'use strict';Object.defineProperty(exports,'__esModule',{value:true});var br=require('react'),reactDom=require('react-dom'),clsx=require('clsx'),tailwindMerge=require('tailwind-merge'),lucideReact=require('lucide-react'),jsxRuntime=require('react/jsx-runtime'),classVarianceAuthority=require('class-variance-authority');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var br__default=/*#__PURE__*/_interopDefault(br);function o(...e){return tailwindMerge.twMerge(clsx.clsx(e))}var rr="#1c1914",nr="#130f0b",an="#2e261e",St="#504638",et="#6b5d4d",pt=`url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")`,on=[{key:"like",icon:jsxRuntime.jsx(lucideReact.Heart,{className:"h-5 w-5"}),activeIcon:jsxRuntime.jsx(lucideReact.Heart,{className:"h-5 w-5",fill:"currentColor"}),label:"Like",toggle:true},{key:"dislike",icon:jsxRuntime.jsx(lucideReact.ThumbsDown,{className:"h-5 w-5"}),label:"Dislike"},{key:"bookmark",icon:jsxRuntime.jsx(lucideReact.Bookmark,{className:"h-5 w-5"}),activeIcon:jsxRuntime.jsx(lucideReact.Bookmark,{className:"h-5 w-5",fill:"currentColor"}),label:"Bookmark",toggle:true},{key:"share",icon:jsxRuntime.jsx(lucideReact.Share2,{className:"h-5 w-5"}),label:"Share"},{key:"download",icon:jsxRuntime.jsx(lucideReact.Download,{className:"h-5 w-5"}),label:"Download"}];function Pt({photos:e,layout:t="strip",actions:n=on,onAction:u,className:f,showGrain:c=true,sheetTitle:d,sheetLabel:v}){let[y,h]=br.useState(null),[L,w]=br.useState(new Set),l=br.useCallback(H=>h(H),[]),m=br.useCallback(()=>h(null),[]),P=br.useCallback((H,E)=>{if(n.find(V=>V.key===H)?.toggle){let V=`${E}-${H}`;w(O=>{let $=new Set(O);return $.has(V)?$.delete(V):$.add(V),$});}u?.(H,e[E],E);},[n,u,e]);return jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(t==="strip"?sn:t==="sheet"?ln:cn,{photos:e,onPhotoClick:l,showGrain:c,className:f,sheetTitle:d,sheetLabel:v}),y!==null&&reactDom.createPortal(jsxRuntime.jsx(dn,{photos:e,currentIndex:y,onIndexChange:h,onClose:m,actions:n,activeActions:L,onAction:P,showGrain:c}),document.body)]})}function tr({count:e=30}){return jsxRuntime.jsx("div",{className:"flex shrink-0 items-center justify-between px-3",style:{height:22,background:rr},children:Array.from({length:e}).map((t,n)=>jsxRuntime.jsx("div",{className:"rounded-xs",style:{width:12,height:8,background:an}},n))})}function sn({photos:e,onPhotoClick:t,showGrain:n,className:u}){let f=br.useRef(null);return jsxRuntime.jsxs("div",{className:o("select-none rounded-lg overflow-hidden",u),style:{background:nr},children:[jsxRuntime.jsx(tr,{count:Math.max(30,e.length*6)}),jsxRuntime.jsx("div",{ref:f,className:"flex gap-1 overflow-x-auto scroll-smooth px-1 py-1",style:{background:rr,scrollSnapType:"x mandatory"},children:e.map((c,d)=>jsxRuntime.jsxs("div",{className:"group relative shrink-0 cursor-pointer",style:{scrollSnapAlign:"center"},onClick:()=>t(d),children:[jsxRuntime.jsxs("div",{className:"overflow-hidden rounded-xs border",style:{borderColor:St,width:280,height:187},children:[jsxRuntime.jsx("img",{src:c.src,alt:c.alt??c.title??"",className:"h-full w-full object-cover transition-transform duration-700 ease-out group-hover:scale-110",draggable:false}),jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 mix-blend-multiply opacity-0 transition-opacity duration-300 group-hover:opacity-100",style:{background:"rgba(255, 175, 60, 0.06)"}}),n&&jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 opacity-0 transition-opacity duration-300 group-hover:opacity-[0.06]",style:{backgroundImage:pt,animation:"film-grain-shift 0.6s steps(5) infinite"}}),jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 opacity-30 transition-opacity duration-300 group-hover:opacity-50",style:{background:"radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.5) 100%)"}})]}),jsxRuntime.jsxs("div",{className:"mt-0.5 text-center font-mono text-[9px] tracking-widest",style:{color:et},children:[String(d+1).padStart(2,"0"),d%2===0?"":"A"]})]},d))}),jsxRuntime.jsx(tr,{count:Math.max(30,e.length*6)})]})}function ln({photos:e,onPhotoClick:t,showGrain:n,className:u,sheetTitle:f,sheetLabel:c}){return jsxRuntime.jsxs("div",{className:o("rounded-lg p-5",u),style:{background:nr},children:[jsxRuntime.jsxs("div",{className:"mb-4 flex items-center justify-between",children:[jsxRuntime.jsx("span",{className:"font-mono text-[10px] uppercase tracking-[0.25em]",style:{color:et},children:f??`JAC\xB7Film 35mm \xB7 ${e.length} exposures`}),jsxRuntime.jsx("span",{className:"font-mono text-[10px] uppercase tracking-[0.25em]",style:{color:et},children:c??"Contact Sheet"})]}),jsxRuntime.jsx("div",{className:"grid grid-cols-3 gap-2 sm:grid-cols-4 md:grid-cols-5 lg:grid-cols-6",children:e.map((d,v)=>jsxRuntime.jsxs("div",{className:"group cursor-pointer",style:{animation:`reveal-up 0.4s ease-out ${v*50}ms both`},onClick:()=>t(v),children:[jsxRuntime.jsx("div",{className:"mb-0.5 font-mono text-[9px] tracking-wider",style:{color:et},children:String(v+1).padStart(2,"0")}),jsxRuntime.jsxs("div",{className:"relative overflow-hidden rounded-[1px] border transition-all duration-300 group-hover:border-amber-600/50 group-hover:shadow-[0_0_20px_rgba(217,171,89,0.15)]",style:{borderColor:St,aspectRatio:"3/2"},children:[jsxRuntime.jsx("img",{src:d.src,alt:d.alt??"",className:"h-full w-full object-cover transition-transform duration-500 group-hover:scale-105",draggable:false}),n&&jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 opacity-[0.04]",style:{backgroundImage:pt}}),jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-x-0 bottom-0 translate-y-full bg-linear-to-t from-black/70 to-transparent p-2 pt-6 transition-transform duration-300 group-hover:translate-y-0",children:jsxRuntime.jsx("span",{className:"text-xs font-medium text-white/90",children:d.title})})]})]},v))})]})}function cn({photos:e,onPhotoClick:t,showGrain:n,className:u}){let[f,c]=br.useState(false),[d,v]=br.useState(null),y=Math.min(e.length,8),h=e.slice(0,y),L=l=>{let m=Math.sin(l*137.508+1)*1e4,P=(m%12-6).toFixed(1),N=(m/7%8-4).toFixed(1),H=(m/13%6-3).toFixed(1);return `rotate(${P}deg) translate(${N}px, ${H}px)`},w=(l,m)=>{let P=(m-1)/2,N=((l-P)*7).toFixed(1),H=((l-P)*110).toFixed(0),E=(-Math.abs(l-P)*10+(d===l?-18:0)).toFixed(0);return `translateX(${H}px) translateY(${E}px) rotate(${N}deg)`};return jsxRuntime.jsxs("div",{className:o("flex flex-col items-center gap-4",u),children:[jsxRuntime.jsx("div",{className:"relative flex h-85 w-full items-center justify-center",onMouseEnter:()=>c(true),onMouseLeave:()=>{c(false),v(null);},children:h.map((l,m)=>jsxRuntime.jsx("div",{className:"absolute cursor-pointer rounded-lg shadow-xl transition-all duration-500",style:{transitionTimingFunction:"cubic-bezier(0.34, 1.56, 0.64, 1)",transitionDelay:f?`${m*35}ms`:`${(y-m)*25}ms`,transform:f?w(m,h.length):L(m),zIndex:f?m+1:h.length-m,width:220,height:147},onClick:()=>t(m),onMouseEnter:()=>f&&v(m),onMouseLeave:()=>v(null),children:jsxRuntime.jsxs("div",{className:"relative h-full w-full overflow-hidden rounded-lg border transition-shadow duration-300",style:{borderColor:f&&d===m?"rgba(217,171,89,0.5)":St,boxShadow:f&&d===m?"0 25px 50px rgba(0,0,0,0.5), 0 0 30px rgba(217,171,89,0.1)":"0 10px 30px rgba(0,0,0,0.4)"},children:[jsxRuntime.jsx("img",{src:l.src,alt:l.alt??"",className:"h-full w-full object-cover",draggable:false}),n&&jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 opacity-[0.04]",style:{backgroundImage:pt}}),jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0",style:{background:"radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.35) 100%)"}}),f&&d===m&&jsxRuntime.jsx("div",{className:"absolute inset-x-0 bottom-0 bg-linear-to-t from-black/80 to-transparent p-3 pt-8",style:{animation:"reveal-up 0.25s ease-out"},children:jsxRuntime.jsx("span",{className:"text-sm font-medium text-white/90",children:l.title})})]})},m))}),e.length>y&&jsxRuntime.jsxs("span",{className:"font-mono text-xs",style:{color:et},children:["+ ",e.length-y," more"]}),jsxRuntime.jsx("span",{className:"font-mono text-[10px] uppercase tracking-[0.3em] transition-opacity duration-300",style:{color:et,opacity:f?0:.7},children:"Hover to explore"})]})}function dn({photos:e,currentIndex:t,onIndexChange:n,onClose:u,actions:f,activeActions:c,onAction:d,showGrain:v}){let y=e[t],[h,L]=br.useState(1),[w,l]=br.useState({x:0,y:0}),[m,P]=br.useState(false),[N,H]=br.useState(false),E=br.useRef(false),z=br.useRef({x:0,y:0}),V=br.useRef(null);br.useLayoutEffect(()=>{requestAnimationFrame(()=>H(true));},[]),br.useEffect(()=>{let s=document.body.style.overflow;return document.body.style.overflow="hidden",()=>{document.body.style.overflow=s;}},[]),br.useEffect(()=>{let s=A=>{switch(A.key){case "Escape":u();break;case "ArrowLeft":O(-1);break;case "ArrowRight":O(1);break;case "i":case "I":P(Y=>!Y);break}};return document.addEventListener("keydown",s),()=>document.removeEventListener("keydown",s)}),br.useEffect(()=>{let s=V.current;if(!s)return;let A=Y=>{Y.preventDefault();let ne=Y.deltaY<0?1.12:.89;L(q=>{let ve=Math.min(8,Math.max(1,q*ne));return ve<=1&&l({x:0,y:0}),ve});};return s.addEventListener("wheel",A,{passive:false}),()=>s.removeEventListener("wheel",A)},[]);let O=br.useCallback(s=>{let A=t+s;A>=0&&A<e.length&&(n(A),L(1),l({x:0,y:0}));},[t,e.length,n]),$=br.useCallback(s=>{h<=1||(E.current=true,z.current={x:s.clientX,y:s.clientY},s.target.setPointerCapture(s.pointerId));},[h]),me=br.useCallback(s=>{if(!E.current)return;let A=s.clientX-z.current.x,Y=s.clientY-z.current.y;z.current={x:s.clientX,y:s.clientY},l(ne=>({x:ne.x+A/h,y:ne.y+Y/h}));},[h]),b=br.useCallback(()=>{E.current=false;},[]),M=br.useCallback(()=>{h>1?(L(1),l({x:0,y:0})):L(2.5);},[h]),_=s=>c.has(`${t}-${s}`),R=y.metadata;return jsxRuntime.jsxs("div",{className:"fixed inset-0 z-200 flex flex-col",style:{animation:"lightbox-backdrop-in 0.35s ease-out"},children:[jsxRuntime.jsx("div",{className:"absolute inset-0 bg-black/95",onClick:u}),v&&jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 opacity-[0.025]",style:{backgroundImage:pt,animation:"film-grain-shift 0.6s steps(5) infinite"}}),jsxRuntime.jsxs("div",{className:"relative z-10 flex h-12 shrink-0 items-center justify-between px-4",children:[jsxRuntime.jsxs("span",{className:"font-mono text-sm text-white/50",children:[t+1," / ",e.length]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsxs("span",{className:"mr-2 font-mono text-xs text-white/40",children:[h.toFixed(1),"x"]}),jsxRuntime.jsx("button",{className:"rounded-full p-2 text-white/60 transition-colors hover:bg-white/10 hover:text-white",onClick:()=>L(s=>Math.min(8,s*1.3)),title:"Zoom in",children:jsxRuntime.jsx(lucideReact.ZoomIn,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:"rounded-full p-2 text-white/60 transition-colors hover:bg-white/10 hover:text-white",onClick:()=>{L(s=>{let A=Math.max(1,s*.7);return A<=1&&l({x:0,y:0}),A});},title:"Zoom out",children:jsxRuntime.jsx(lucideReact.ZoomOut,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:"rounded-full p-2 text-white/60 transition-colors hover:bg-white/10 hover:text-white",onClick:u,title:"Close",children:jsxRuntime.jsx(lucideReact.X,{className:"h-5 w-5"})})]})]}),jsxRuntime.jsxs("div",{ref:V,className:"relative flex flex-1 items-center justify-center overflow-hidden",style:{cursor:h>1?"grab":"default"},onPointerDown:$,onPointerMove:me,onPointerUp:b,onDoubleClick:M,children:[jsxRuntime.jsx("img",{src:y.src,alt:y.alt??y.title??"",className:"max-h-full max-w-full select-none object-contain",style:{animation:"lightbox-photo-in 0.35s cubic-bezier(0.16, 1, 0.3, 1)",transform:`scale(${h}) translate(${w.x}px, ${w.y}px)`,transition:E.current?"none":"transform 0.15s ease-out"},draggable:false},t),t>0&&jsxRuntime.jsx("button",{className:"absolute left-3 top-1/2 -translate-y-1/2 rounded-full bg-black/40 p-2.5 text-white/70 backdrop-blur-sm transition-all hover:bg-black/60 hover:text-white",onClick:s=>{s.stopPropagation(),O(-1);},children:jsxRuntime.jsx(lucideReact.ChevronLeft,{className:"h-6 w-6"})}),t<e.length-1&&jsxRuntime.jsx("button",{className:"absolute right-3 top-1/2 -translate-y-1/2 rounded-full bg-black/40 p-2.5 text-white/70 backdrop-blur-sm transition-all hover:bg-black/60 hover:text-white",onClick:s=>{s.stopPropagation(),O(1);},children:jsxRuntime.jsx(lucideReact.ChevronRight,{className:"h-6 w-6"})})]}),jsxRuntime.jsx("div",{className:o("absolute inset-x-0 bottom-0 z-20 transition-all duration-400",m?"translate-y-0 opacity-100":"pointer-events-none translate-y-full opacity-0"),children:jsxRuntime.jsxs("div",{className:"bg-linear-to-t from-black/90 via-black/75 to-transparent px-6 pb-24 pt-16",children:[y.title&&jsxRuntime.jsx("h3",{className:"mb-3 text-xl font-semibold text-white",children:y.title}),y.description&&jsxRuntime.jsx("p",{className:"mb-4 max-w-xl border-l-2 border-amber-500/40 pl-4 text-sm leading-relaxed text-white/60 italic",style:{animation:"reveal-up 0.4s ease-out 0.1s both"},children:y.description}),R&&jsxRuntime.jsxs("div",{className:"flex flex-wrap gap-x-6 gap-y-2 text-sm text-white/70",children:[R.camera&&jsxRuntime.jsxs("span",{className:"flex items-center gap-1.5",children:[jsxRuntime.jsx(lucideReact.Camera,{className:"h-3.5 w-3.5 text-amber-400/80"})," ",R.camera,R.lens&&jsxRuntime.jsx("span",{className:"text-white/40",children:"\xB7"}),R.lens&&R.lens]}),(R.aperture||R.shutter||R.iso)&&jsxRuntime.jsxs("span",{className:"flex items-center gap-1.5",children:[jsxRuntime.jsx(lucideReact.Aperture,{className:"h-3.5 w-3.5 text-amber-400/80"}),[R.aperture,R.shutter,R.iso&&`ISO ${R.iso}`].filter(Boolean).join(" \xB7 ")]}),R.date&&jsxRuntime.jsxs("span",{className:"flex items-center gap-1.5",children:[jsxRuntime.jsx(lucideReact.Calendar,{className:"h-3.5 w-3.5 text-amber-400/80"})," ",R.date]}),R.location&&jsxRuntime.jsxs("span",{className:"flex items-center gap-1.5",children:[jsxRuntime.jsx(lucideReact.MapPin,{className:"h-3.5 w-3.5 text-amber-400/80"})," ",R.location]})]})]})}),jsxRuntime.jsx("div",{className:"relative z-20 flex h-16 shrink-0 items-center justify-center gap-1",children:jsxRuntime.jsxs("div",{className:"flex items-center gap-0.5 rounded-full bg-white/6 px-2 py-1.5 backdrop-blur-xl",children:[f.map(s=>{let A=s.toggle&&_(s.key);return jsxRuntime.jsx("button",{className:o("rounded-full p-2.5 transition-all duration-200",A?"text-amber-400 hover:text-amber-300":"text-white/60 hover:bg-white/10 hover:text-white"),onClick:()=>d(s.key,t),title:s.label,children:A&&s.activeIcon?s.activeIcon:s.icon},s.key)}),jsxRuntime.jsx("div",{className:"mx-1 h-5 w-px bg-white/10"}),jsxRuntime.jsx("button",{className:o("rounded-full p-2.5 transition-all duration-200",m?"text-amber-400 hover:text-amber-300":"text-white/60 hover:bg-white/10 hover:text-white"),onClick:()=>P(s=>!s),title:"Photo info (I)",children:jsxRuntime.jsx(lucideReact.Info,{className:"h-5 w-5"})})]})})]})}var Lt="data:image/svg+xml,"+encodeURIComponent(`<svg xmlns="http://www.w3.org/2000/svg" width="200" height="200" viewBox="0 0 200 200">
|
|
1
|
+
'use strict';Object.defineProperty(exports,'__esModule',{value:true});var Yr=require('react'),reactDom=require('react-dom'),clsx=require('clsx'),tailwindMerge=require('tailwind-merge'),lucideReact=require('lucide-react'),jsxRuntime=require('react/jsx-runtime'),classVarianceAuthority=require('class-variance-authority'),react=require('@tiptap/react'),transform=require('@tiptap/pm/transform'),commands=require('@tiptap/pm/commands'),state=require('@tiptap/pm/state'),model=require('@tiptap/pm/model'),schemaList=require('@tiptap/pm/schema-list'),view=require('@tiptap/pm/view');require('@tiptap/pm/keymap');var op=require('@tiptap/starter-kit'),ap=require('@tiptap/extension-underline'),sp=require('@tiptap/extension-text-align'),extensionColor=require('@tiptap/extension-color'),lp=require('@tiptap/extension-highlight'),cp=require('@tiptap/extension-link'),dp=require('@tiptap/extension-youtube'),up=require('@tiptap/extension-placeholder'),pp=require('@tiptap/extension-character-count'),mp=require('@tiptap/extension-typography'),fp=require('@tiptap/extension-subscript'),hp=require('@tiptap/extension-superscript'),extensionTable=require('@tiptap/extension-table'),bp=require('@tiptap/extension-table-row'),vp=require('@tiptap/extension-table-header'),yp=require('@tiptap/extension-table-cell'),qu=require('@tiptap/extension-image'),marked=require('marked');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Yr__default=/*#__PURE__*/_interopDefault(Yr);var op__default=/*#__PURE__*/_interopDefault(op);var ap__default=/*#__PURE__*/_interopDefault(ap);var sp__default=/*#__PURE__*/_interopDefault(sp);var lp__default=/*#__PURE__*/_interopDefault(lp);var cp__default=/*#__PURE__*/_interopDefault(cp);var dp__default=/*#__PURE__*/_interopDefault(dp);var up__default=/*#__PURE__*/_interopDefault(up);var pp__default=/*#__PURE__*/_interopDefault(pp);var mp__default=/*#__PURE__*/_interopDefault(mp);var fp__default=/*#__PURE__*/_interopDefault(fp);var hp__default=/*#__PURE__*/_interopDefault(hp);var bp__default=/*#__PURE__*/_interopDefault(bp);var vp__default=/*#__PURE__*/_interopDefault(vp);var yp__default=/*#__PURE__*/_interopDefault(yp);var qu__default=/*#__PURE__*/_interopDefault(qu);function v(...e){return tailwindMerge.twMerge(clsx.clsx(e))}var to="#1c1914",ro="#130f0b",Ts="#2e261e",Xr="#504638",Ot="#6b5d4d",vr=`url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")`,Es=[{key:"like",icon:jsxRuntime.jsx(lucideReact.Heart,{className:"h-5 w-5"}),activeIcon:jsxRuntime.jsx(lucideReact.Heart,{className:"h-5 w-5",fill:"currentColor"}),label:"Like",toggle:true},{key:"dislike",icon:jsxRuntime.jsx(lucideReact.ThumbsDown,{className:"h-5 w-5"}),label:"Dislike"},{key:"bookmark",icon:jsxRuntime.jsx(lucideReact.Bookmark,{className:"h-5 w-5"}),activeIcon:jsxRuntime.jsx(lucideReact.Bookmark,{className:"h-5 w-5",fill:"currentColor"}),label:"Bookmark",toggle:true},{key:"share",icon:jsxRuntime.jsx(lucideReact.Share2,{className:"h-5 w-5"}),label:"Share"},{key:"download",icon:jsxRuntime.jsx(lucideReact.Download,{className:"h-5 w-5"}),label:"Download"}];function Gr({photos:e,layout:t="strip",actions:r=Es,onAction:n,className:o,showGrain:a=true,sheetTitle:s,sheetLabel:l}){let[i,d]=Yr.useState(null),[m,u]=Yr.useState(new Set),p=Yr.useCallback(g=>d(g),[]),c=Yr.useCallback(()=>d(null),[]),h=Yr.useCallback((g,b)=>{if(r.find(C=>C.key===g)?.toggle){let C=`${b}-${g}`;u(x=>{let M=new Set(x);return M.has(C)?M.delete(C):M.add(C),M});}n?.(g,e[b],b);},[r,n,e]);return jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(t==="strip"?Ps:t==="sheet"?Rs:Ds,{photos:e,onPhotoClick:p,showGrain:a,className:o,sheetTitle:s,sheetLabel:l}),i!==null&&reactDom.createPortal(jsxRuntime.jsx(As,{photos:e,currentIndex:i,onIndexChange:d,onClose:c,actions:r,activeActions:m,onAction:h,showGrain:a}),document.body)]})}function eo({count:e=30}){return jsxRuntime.jsx("div",{className:"flex shrink-0 items-center justify-between px-3",style:{height:22,background:to},children:Array.from({length:e}).map((t,r)=>jsxRuntime.jsx("div",{className:"rounded-xs",style:{width:12,height:8,background:Ts}},r))})}function Ps({photos:e,onPhotoClick:t,showGrain:r,className:n}){let o=Yr.useRef(null);return jsxRuntime.jsxs("div",{className:v("select-none rounded-lg overflow-hidden",n),style:{background:ro},children:[jsxRuntime.jsx(eo,{count:Math.max(30,e.length*6)}),jsxRuntime.jsx("div",{ref:o,className:"flex gap-1 overflow-x-auto scroll-smooth px-1 py-1",style:{background:to,scrollSnapType:"x mandatory"},children:e.map((a,s)=>jsxRuntime.jsxs("div",{className:"group relative shrink-0 cursor-pointer",style:{scrollSnapAlign:"center"},onClick:()=>t(s),children:[jsxRuntime.jsxs("div",{className:"overflow-hidden rounded-xs border",style:{borderColor:Xr,width:280,height:187},children:[jsxRuntime.jsx("img",{src:a.src,alt:a.alt??a.title??"",className:"h-full w-full object-cover transition-transform duration-700 ease-out group-hover:scale-110",draggable:false}),jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 mix-blend-multiply opacity-0 transition-opacity duration-300 group-hover:opacity-100",style:{background:"rgba(255, 175, 60, 0.06)"}}),r&&jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 opacity-0 transition-opacity duration-300 group-hover:opacity-[0.06]",style:{backgroundImage:vr,animation:"film-grain-shift 0.6s steps(5) infinite"}}),jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 opacity-30 transition-opacity duration-300 group-hover:opacity-50",style:{background:"radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.5) 100%)"}})]}),jsxRuntime.jsxs("div",{className:"mt-0.5 text-center font-mono text-[9px] tracking-widest",style:{color:Ot},children:[String(s+1).padStart(2,"0"),s%2===0?"":"A"]})]},s))}),jsxRuntime.jsx(eo,{count:Math.max(30,e.length*6)})]})}function Rs({photos:e,onPhotoClick:t,showGrain:r,className:n,sheetTitle:o,sheetLabel:a}){return jsxRuntime.jsxs("div",{className:v("rounded-lg p-5",n),style:{background:ro},children:[jsxRuntime.jsxs("div",{className:"mb-4 flex items-center justify-between",children:[jsxRuntime.jsx("span",{className:"font-mono text-[10px] uppercase tracking-[0.25em]",style:{color:Ot},children:o??`JAC\xB7Film 35mm \xB7 ${e.length} exposures`}),jsxRuntime.jsx("span",{className:"font-mono text-[10px] uppercase tracking-[0.25em]",style:{color:Ot},children:a??"Contact Sheet"})]}),jsxRuntime.jsx("div",{className:"grid grid-cols-3 gap-2 sm:grid-cols-4 md:grid-cols-5 lg:grid-cols-6",children:e.map((s,l)=>jsxRuntime.jsxs("div",{className:"group cursor-pointer",style:{animation:`reveal-up 0.4s ease-out ${l*50}ms both`},onClick:()=>t(l),children:[jsxRuntime.jsx("div",{className:"mb-0.5 font-mono text-[9px] tracking-wider",style:{color:Ot},children:String(l+1).padStart(2,"0")}),jsxRuntime.jsxs("div",{className:"relative overflow-hidden rounded-[1px] border transition-all duration-300 group-hover:border-amber-600/50 group-hover:shadow-[0_0_20px_rgba(217,171,89,0.15)]",style:{borderColor:Xr,aspectRatio:"3/2"},children:[jsxRuntime.jsx("img",{src:s.src,alt:s.alt??"",className:"h-full w-full object-cover transition-transform duration-500 group-hover:scale-105",draggable:false}),r&&jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 opacity-[0.04]",style:{backgroundImage:vr}}),jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-x-0 bottom-0 translate-y-full bg-linear-to-t from-black/70 to-transparent p-2 pt-6 transition-transform duration-300 group-hover:translate-y-0",children:jsxRuntime.jsx("span",{className:"text-xs font-medium text-white/90",children:s.title})})]})]},l))})]})}function Ds({photos:e,onPhotoClick:t,showGrain:r,className:n}){let[o,a]=Yr.useState(false),[s,l]=Yr.useState(null),i=Math.min(e.length,8),d=e.slice(0,i),m=p=>{let c=Math.sin(p*137.508+1)*1e4,h=(c%12-6).toFixed(1),f=(c/7%8-4).toFixed(1),g=(c/13%6-3).toFixed(1);return `rotate(${h}deg) translate(${f}px, ${g}px)`},u=(p,c)=>{let h=(c-1)/2,f=((p-h)*7).toFixed(1),g=((p-h)*110).toFixed(0),b=(-Math.abs(p-h)*10+(s===p?-18:0)).toFixed(0);return `translateX(${g}px) translateY(${b}px) rotate(${f}deg)`};return jsxRuntime.jsxs("div",{className:v("flex flex-col items-center gap-4",n),children:[jsxRuntime.jsx("div",{className:"relative flex h-85 w-full items-center justify-center",onMouseEnter:()=>a(true),onMouseLeave:()=>{a(false),l(null);},children:d.map((p,c)=>jsxRuntime.jsx("div",{className:"absolute cursor-pointer rounded-lg shadow-xl transition-all duration-500",style:{transitionTimingFunction:"cubic-bezier(0.34, 1.56, 0.64, 1)",transitionDelay:o?`${c*35}ms`:`${(i-c)*25}ms`,transform:o?u(c,d.length):m(c),zIndex:o?c+1:d.length-c,width:220,height:147},onClick:()=>t(c),onMouseEnter:()=>o&&l(c),onMouseLeave:()=>l(null),children:jsxRuntime.jsxs("div",{className:"relative h-full w-full overflow-hidden rounded-lg border transition-shadow duration-300",style:{borderColor:o&&s===c?"rgba(217,171,89,0.5)":Xr,boxShadow:o&&s===c?"0 25px 50px rgba(0,0,0,0.5), 0 0 30px rgba(217,171,89,0.1)":"0 10px 30px rgba(0,0,0,0.4)"},children:[jsxRuntime.jsx("img",{src:p.src,alt:p.alt??"",className:"h-full w-full object-cover",draggable:false}),r&&jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 opacity-[0.04]",style:{backgroundImage:vr}}),jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0",style:{background:"radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.35) 100%)"}}),o&&s===c&&jsxRuntime.jsx("div",{className:"absolute inset-x-0 bottom-0 bg-linear-to-t from-black/80 to-transparent p-3 pt-8",style:{animation:"reveal-up 0.25s ease-out"},children:jsxRuntime.jsx("span",{className:"text-sm font-medium text-white/90",children:p.title})})]})},c))}),e.length>i&&jsxRuntime.jsxs("span",{className:"font-mono text-xs",style:{color:Ot},children:["+ ",e.length-i," more"]}),jsxRuntime.jsx("span",{className:"font-mono text-[10px] uppercase tracking-[0.3em] transition-opacity duration-300",style:{color:Ot,opacity:o?0:.7},children:"Hover to explore"})]})}function As({photos:e,currentIndex:t,onIndexChange:r,onClose:n,actions:o,activeActions:a,onAction:s,showGrain:l}){let i=e[t],[d,m]=Yr.useState(1),[u,p]=Yr.useState({x:0,y:0}),[c,h]=Yr.useState(false),[f,g]=Yr.useState(false),b=Yr.useRef(false),w=Yr.useRef({x:0,y:0}),C=Yr.useRef(null);Yr.useLayoutEffect(()=>{requestAnimationFrame(()=>g(true));},[]),Yr.useEffect(()=>{let y=document.body.style.overflow;return document.body.style.overflow="hidden",()=>{document.body.style.overflow=y;}},[]),Yr.useEffect(()=>{let y=_=>{switch(_.key){case "Escape":n();break;case "ArrowLeft":x(-1);break;case "ArrowRight":x(1);break;case "i":case "I":h(X=>!X);break}};return document.addEventListener("keydown",y),()=>document.removeEventListener("keydown",y)}),Yr.useEffect(()=>{let y=C.current;if(!y)return;let _=X=>{X.preventDefault();let z=X.deltaY<0?1.12:.89;m(Y=>{let ge=Math.min(8,Math.max(1,Y*z));return ge<=1&&p({x:0,y:0}),ge});};return y.addEventListener("wheel",_,{passive:false}),()=>y.removeEventListener("wheel",_)},[]);let x=Yr.useCallback(y=>{let _=t+y;_>=0&&_<e.length&&(r(_),m(1),p({x:0,y:0}));},[t,e.length,r]),M=Yr.useCallback(y=>{d<=1||(b.current=true,w.current={x:y.clientX,y:y.clientY},y.target.setPointerCapture(y.pointerId));},[d]),F=Yr.useCallback(y=>{if(!b.current)return;let _=y.clientX-w.current.x,X=y.clientY-w.current.y;w.current={x:y.clientX,y:y.clientY},p(z=>({x:z.x+_/d,y:z.y+X/d}));},[d]),P=Yr.useCallback(()=>{b.current=false;},[]),L=Yr.useCallback(()=>{d>1?(m(1),p({x:0,y:0})):m(2.5);},[d]),H=y=>a.has(`${t}-${y}`),R=i.metadata;return jsxRuntime.jsxs("div",{className:"fixed inset-0 z-200 flex flex-col",style:{animation:"lightbox-backdrop-in 0.35s ease-out"},children:[jsxRuntime.jsx("div",{className:"absolute inset-0 bg-black/95",onClick:n}),l&&jsxRuntime.jsx("div",{className:"pointer-events-none absolute inset-0 opacity-[0.025]",style:{backgroundImage:vr,animation:"film-grain-shift 0.6s steps(5) infinite"}}),jsxRuntime.jsxs("div",{className:"relative z-10 flex h-12 shrink-0 items-center justify-between px-4",children:[jsxRuntime.jsxs("span",{className:"font-mono text-sm text-white/50",children:[t+1," / ",e.length]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsxs("span",{className:"mr-2 font-mono text-xs text-white/40",children:[d.toFixed(1),"x"]}),jsxRuntime.jsx("button",{className:"rounded-full p-2 text-white/60 transition-colors hover:bg-white/10 hover:text-white",onClick:()=>m(y=>Math.min(8,y*1.3)),title:"Zoom in",children:jsxRuntime.jsx(lucideReact.ZoomIn,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:"rounded-full p-2 text-white/60 transition-colors hover:bg-white/10 hover:text-white",onClick:()=>{m(y=>{let _=Math.max(1,y*.7);return _<=1&&p({x:0,y:0}),_});},title:"Zoom out",children:jsxRuntime.jsx(lucideReact.ZoomOut,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:"rounded-full p-2 text-white/60 transition-colors hover:bg-white/10 hover:text-white",onClick:n,title:"Close",children:jsxRuntime.jsx(lucideReact.X,{className:"h-5 w-5"})})]})]}),jsxRuntime.jsxs("div",{ref:C,className:"relative flex flex-1 items-center justify-center overflow-hidden",style:{cursor:d>1?"grab":"default"},onPointerDown:M,onPointerMove:F,onPointerUp:P,onDoubleClick:L,children:[jsxRuntime.jsx("img",{src:i.src,alt:i.alt??i.title??"",className:"max-h-full max-w-full select-none object-contain",style:{animation:"lightbox-photo-in 0.35s cubic-bezier(0.16, 1, 0.3, 1)",transform:`scale(${d}) translate(${u.x}px, ${u.y}px)`,transition:b.current?"none":"transform 0.15s ease-out"},draggable:false},t),t>0&&jsxRuntime.jsx("button",{className:"absolute left-3 top-1/2 -translate-y-1/2 rounded-full bg-black/40 p-2.5 text-white/70 backdrop-blur-sm transition-all hover:bg-black/60 hover:text-white",onClick:y=>{y.stopPropagation(),x(-1);},children:jsxRuntime.jsx(lucideReact.ChevronLeft,{className:"h-6 w-6"})}),t<e.length-1&&jsxRuntime.jsx("button",{className:"absolute right-3 top-1/2 -translate-y-1/2 rounded-full bg-black/40 p-2.5 text-white/70 backdrop-blur-sm transition-all hover:bg-black/60 hover:text-white",onClick:y=>{y.stopPropagation(),x(1);},children:jsxRuntime.jsx(lucideReact.ChevronRight,{className:"h-6 w-6"})})]}),jsxRuntime.jsx("div",{className:v("absolute inset-x-0 bottom-0 z-20 transition-all duration-400",c?"translate-y-0 opacity-100":"pointer-events-none translate-y-full opacity-0"),children:jsxRuntime.jsxs("div",{className:"bg-linear-to-t from-black/90 via-black/75 to-transparent px-6 pb-24 pt-16",children:[i.title&&jsxRuntime.jsx("h3",{className:"mb-3 text-xl font-semibold text-white",children:i.title}),i.description&&jsxRuntime.jsx("p",{className:"mb-4 max-w-xl border-l-2 border-amber-500/40 pl-4 text-sm leading-relaxed text-white/60 italic",style:{animation:"reveal-up 0.4s ease-out 0.1s both"},children:i.description}),R&&jsxRuntime.jsxs("div",{className:"flex flex-wrap gap-x-6 gap-y-2 text-sm text-white/70",children:[R.camera&&jsxRuntime.jsxs("span",{className:"flex items-center gap-1.5",children:[jsxRuntime.jsx(lucideReact.Camera,{className:"h-3.5 w-3.5 text-amber-400/80"})," ",R.camera,R.lens&&jsxRuntime.jsx("span",{className:"text-white/40",children:"\xB7"}),R.lens&&R.lens]}),(R.aperture||R.shutter||R.iso)&&jsxRuntime.jsxs("span",{className:"flex items-center gap-1.5",children:[jsxRuntime.jsx(lucideReact.Aperture,{className:"h-3.5 w-3.5 text-amber-400/80"}),[R.aperture,R.shutter,R.iso&&`ISO ${R.iso}`].filter(Boolean).join(" \xB7 ")]}),R.date&&jsxRuntime.jsxs("span",{className:"flex items-center gap-1.5",children:[jsxRuntime.jsx(lucideReact.Calendar,{className:"h-3.5 w-3.5 text-amber-400/80"})," ",R.date]}),R.location&&jsxRuntime.jsxs("span",{className:"flex items-center gap-1.5",children:[jsxRuntime.jsx(lucideReact.MapPin,{className:"h-3.5 w-3.5 text-amber-400/80"})," ",R.location]})]})]})}),jsxRuntime.jsx("div",{className:"relative z-20 flex h-16 shrink-0 items-center justify-center gap-1",children:jsxRuntime.jsxs("div",{className:"flex items-center gap-0.5 rounded-full bg-white/6 px-2 py-1.5 backdrop-blur-xl",children:[o.map(y=>{let _=y.toggle&&H(y.key);return jsxRuntime.jsx("button",{className:v("rounded-full p-2.5 transition-all duration-200",_?"text-amber-400 hover:text-amber-300":"text-white/60 hover:bg-white/10 hover:text-white"),onClick:()=>s(y.key,t),title:y.label,children:_&&y.activeIcon?y.activeIcon:y.icon},y.key)}),jsxRuntime.jsx("div",{className:"mx-1 h-5 w-px bg-white/10"}),jsxRuntime.jsx("button",{className:v("rounded-full p-2.5 transition-all duration-200",c?"text-amber-400 hover:text-amber-300":"text-white/60 hover:bg-white/10 hover:text-white"),onClick:()=>h(y=>!y),title:"Photo info (I)",children:jsxRuntime.jsx(lucideReact.Info,{className:"h-5 w-5"})})]})})]})}var Jr="data:image/svg+xml,"+encodeURIComponent(`<svg xmlns="http://www.w3.org/2000/svg" width="200" height="200" viewBox="0 0 200 200">
|
|
2
2
|
<rect width="200" height="200" fill="#1e1b2e"/>
|
|
3
3
|
<circle cx="100" cy="100" r="60" fill="none" stroke="#6366f1" stroke-width="1.5" opacity="0.3"/>
|
|
4
4
|
<circle cx="100" cy="100" r="20" fill="none" stroke="#6366f1" stroke-width="1" opacity="0.4"/>
|
|
5
5
|
<text x="100" y="108" text-anchor="middle" font-family="monospace" font-size="18" fill="#6366f1" opacity="0.6">\u266A</text>
|
|
6
|
-
</svg>`);function or(e){if(!isFinite(e)||e<0)return "0:00";let t=Math.floor(e/60),n=Math.floor(e%60);return `${t}:${n.toString().padStart(2,"0")}`}function Nn(e){return e.startsWith("bottom")?"bottom":e.startsWith("top")?"top":"right"}var Cn={"bottom-right":"bottom-4 right-4","bottom-left":"bottom-4 left-4","top-right":"top-4 right-4","top-left":"top-4 left-4"},Mn={"bottom-right":"bottom-4 right-0","bottom-left":"bottom-4 left-0","top-right":"top-4 right-0","top-left":"top-4 left-0"},Tn={"bottom-right":"bottom-8 right-0 w-1.5 h-16 rounded-l-full","bottom-left":"bottom-8 left-0 w-1.5 h-16 rounded-r-full","top-right":"top-8 right-0 w-1.5 h-16 rounded-l-full","top-left":"top-8 left-0 w-1.5 h-16 rounded-r-full"};function Rt({playlist:e,initialTrack:t=0,position:n="bottom-right",entrance:u,theme:f,docked:c=false,visible:d,onVisibleChange:v,onTrackChange:y,onLike:h,autoPlay:L=true,shuffle:w=false,loop:l=false,accent:m="#8b5cf6",className:P}){let [N,H]=br.useState(t),[E,z]=br.useState(false),[V,O]=br.useState(0),[$,me]=br.useState(0),[b,M]=br.useState(.8),[_,R]=br.useState(false),[s,A]=br.useState(new Set),[Y,ne]=br.useState(false),[q,ve]=br.useState(d??!c),[X,ye]=br.useState(false),[Xe,Fe]=br.useState(false),[pe,He]=br.useState(w),[be,Ve]=br.useState(l),_e=br.useRef(false),j=br.useRef(null),Ne=br.useRef(null),te=br.useRef(void 0),Z=br.useRef(null),re=br.useRef(null),he=d??q,Ee=u??Nn(n),I=e[N],J=c,fe=f==="dark"?"dark":f==="light"?"light":"",Ce="bg-(--mp-bg)",Se="text-(--mp-text)",ae="text-(--mp-text-muted)",Re="text-(--accent)",ee="border-(--mp-border)";br.useEffect(()=>{let i=j.current;i&&(i.src=I.src,i.load(),E&&i.play().catch(()=>{}));},[N,I.src]),br.useEffect(()=>{if(!L||_e.current)return;let i=j.current;if(!i)return;let F=()=>{_e.current=true,z(true),i.play().catch(()=>{});};return i.addEventListener("canplaythrough",F,{once:true}),()=>i.removeEventListener("canplaythrough",F)},[L]),br.useEffect(()=>{let i=j.current;i&&(E?i.play().catch(()=>{}):i.pause());},[E]),br.useEffect(()=>{let i=j.current;i&&(i.muted=_,re.current?re.current.gain.value=_?0:b:i.volume=b);},[b,_]),br.useEffect(()=>{let i=j.current;if(!i)return;let F=()=>O(i.currentTime),oe=()=>me(i.duration),Pe=()=>{be?(i.currentTime=0,i.play().catch(()=>{})):De();};return i.addEventListener("timeupdate",F),i.addEventListener("loadedmetadata",oe),i.addEventListener("ended",Pe),()=>{i.removeEventListener("timeupdate",F),i.removeEventListener("loadedmetadata",oe),i.removeEventListener("ended",Pe);}},[N,e.length]);let D=br.useCallback(i=>{let F=(i%e.length+e.length)%e.length;H(F),O(0),y?.(F,e[F]),he||(ve(true),v?.(true));},[e,he,y,v]),De=br.useCallback(()=>{if(pe){let i;do i=Math.floor(Math.random()*e.length);while(i===N&&e.length>1);D(i);}else D(N+1);},[D,N,pe,e.length]),qe=br.useCallback(()=>{if(pe){let i;do i=Math.floor(Math.random()*e.length);while(i===N&&e.length>1);D(i);}else D(N-1);},[D,N,pe,e.length]),Qe=br.useCallback(()=>{let i=s.has(N);A(F=>{let oe=new Set(F);return i?oe.delete(N):oe.add(N),oe}),h?.(N,I,!i);},[N,s,h,I]),ct=br.useCallback(i=>{let F=i.currentTarget.getBoundingClientRect(),Pe=Math.max(0,Math.min(1,(i.clientX-F.left)/F.width))*$;j.current&&(j.current.currentTime=Pe),O(Pe);},[$]),ce=br.useCallback(()=>{ye(true);let i=J?200:400;te.current=setTimeout(()=>{ye(false),ve(false),v?.(false);},i);},[J,v]);br.useEffect(()=>()=>{te.current&&clearTimeout(te.current);},[]),br.useEffect(()=>()=>{Z.current?.close();},[]);function xe(){if(Z.current||!j.current){Z.current?.resume();return}try{let i=window.AudioContext??window.webkitAudioContext;if(!i)return;let F=new i,oe=F.createGain();oe.gain.value=_?0:b,F.createMediaElementSource(j.current).connect(oe).connect(F.destination),Z.current=F,re.current=oe,F.resume();}catch{}}let a=Xe?"fade-in 0.2s ease-out both":`mp-enter-${Ee} 0.45s cubic-bezier(0.16, 1, 0.3, 1) both`,T=Xe?"fade-in 0.2s ease-in reverse both":`mp-exit-${Ee} 0.4s cubic-bezier(0.7, 0, 0.84, 0) both`,W=$>0?V/$*100:0;return J&&!he&&!X?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("audio",{ref:j,preload:"metadata",crossOrigin:"anonymous"}),jsxRuntime.jsxs("div",{className:o("fixed z-100 cursor-pointer transition-all duration-300",Tn[n]),style:{"--accent":m},onMouseEnter:()=>{Fe(true),ve(true),v?.(true);},children:[jsxRuntime.jsx("div",{className:o("h-full w-full rounded-full",E?"bg-(--accent)":"bg-(--mp-dock-strip)"),style:E?{animation:"mp-progress-glow 2s ease-in-out infinite",boxShadow:"0 0 12px color-mix(in srgb, var(--accent) 50%, transparent)"}:void 0}),E&&jsxRuntime.jsx("div",{className:"absolute inset-0 rounded-full bg-(--accent)/30",style:{animation:"mp-pulse-ring 2s ease-out infinite"}})]})]}):!he&&!X?jsxRuntime.jsx("audio",{ref:j,preload:"metadata",crossOrigin:"anonymous"}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("audio",{ref:j,preload:"metadata",crossOrigin:"anonymous"}),jsxRuntime.jsx("div",{className:o("fixed z-100",J?Mn[n]:Cn[n],fe),style:{"--accent":m,...X?{animation:T}:{animation:a}},onMouseEnter:()=>{J&&(te.current&&(clearTimeout(te.current),te.current=void 0),X&&ye(false),Fe(true));},onMouseLeave:()=>{J&&(Fe(false),ce());},children:jsxRuntime.jsxs("div",{className:o("w-[320px] overflow-hidden rounded-2xl border shadow-2xl backdrop-blur-xl",Ce,ee,J&&"rounded-none",n.endsWith("right")&&J&&"rounded-l-2xl",n.endsWith("left")&&J&&"rounded-r-2xl",P),children:[jsxRuntime.jsxs("div",{className:"relative",children:[jsxRuntime.jsx("div",{className:"absolute inset-0 overflow-hidden",children:jsxRuntime.jsx("img",{src:I.cover||Lt,alt:"",className:"h-full w-full scale-110 object-cover opacity-30 blur-2xl",draggable:false})}),jsxRuntime.jsxs("div",{className:"relative flex items-center gap-3.5 p-4 pb-3",children:[jsxRuntime.jsxs("div",{className:"relative h-14 w-14 shrink-0",children:[jsxRuntime.jsxs("div",{className:"h-14 w-14 overflow-hidden rounded-full border-2 border-white/10 shadow-lg",style:E?{animation:"mp-vinyl-spin 4s linear infinite"}:void 0,children:[jsxRuntime.jsx("img",{src:I.cover||Lt,alt:I.album??I.title,className:"h-full w-full object-cover",draggable:false}),jsxRuntime.jsx("div",{className:"absolute inset-0 flex items-center justify-center",children:jsxRuntime.jsx("div",{className:"h-3 w-3 rounded-full bg-black/60 ring-1 ring-white/10"})})]}),E&&jsxRuntime.jsx("div",{className:"absolute inset-0 rounded-full bg-(--accent)/20",style:{animation:"mp-pulse-ring 2.5s ease-out infinite"}})]}),jsxRuntime.jsxs("div",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("div",{className:o("truncate text-sm font-semibold",Se),children:I.title}),I.artist&&jsxRuntime.jsx("div",{className:o("truncate text-xs",ae),children:I.artist}),I.album&&jsxRuntime.jsx("div",{className:o("mt-0.5 truncate text-[10px] tracking-wide",ae,"opacity-60"),children:I.album})]}),jsxRuntime.jsxs("div",{className:"flex shrink-0 items-center gap-0.5",children:[jsxRuntime.jsx("button",{className:o("rounded-full p-1.5 transition-all duration-200",s.has(N)?"text-rose-500 hover:text-rose-400":o(ae,"hover:text-rose-500")),onClick:Qe,title:"Like",children:jsxRuntime.jsx(lucideReact.Heart,{className:"h-4 w-4",fill:s.has(N)?"currentColor":"none"})}),jsxRuntime.jsx("button",{className:o("rounded-full p-1.5 transition-colors",ae,"hover:"+Se.split(" ")[0]),onClick:()=>ne(i=>!i),title:"Playlist",children:jsxRuntime.jsx(lucideReact.ListMusic,{className:"h-4 w-4"})}),!J&&jsxRuntime.jsx("button",{className:o("rounded-full p-1.5 transition-colors",ae,"hover:"+Se.split(" ")[0]),onClick:ce,title:"Dismiss",children:jsxRuntime.jsx(lucideReact.X,{className:"h-3.5 w-3.5"})})]})]})]}),jsxRuntime.jsxs("div",{className:"px-4",children:[jsxRuntime.jsxs("div",{ref:Ne,className:"group relative h-1.5 cursor-pointer rounded-full bg-(--mp-surface)",onClick:ct,children:[jsxRuntime.jsx("div",{className:"h-full rounded-full bg-(--accent) transition-[width] duration-150",style:{width:`${W}%`}}),jsxRuntime.jsx("div",{className:"absolute top-1/2 h-3 w-3 -translate-y-1/2 rounded-full bg-(--accent) opacity-0 shadow-md transition-opacity group-hover:opacity-100",style:{left:`calc(${W}% - 6px)`}})]}),jsxRuntime.jsxs("div",{className:o("mt-1 flex justify-between text-[10px] font-mono",ae),children:[jsxRuntime.jsx("span",{children:or(V)}),jsxRuntime.jsx("span",{children:or($)})]})]}),jsxRuntime.jsxs("div",{className:"flex items-center justify-center gap-2 px-4 pb-3 pt-1",children:[jsxRuntime.jsx("button",{className:o("rounded-full p-1.5 transition-colors",pe?Re:ae,"hover:text-(--mp-text)"),onClick:()=>He(i=>!i),title:pe?"Shuffle On":"Shuffle Off",children:jsxRuntime.jsx(lucideReact.Shuffle,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:o("rounded-full p-1.5 transition-colors",be?Re:ae,"hover:text-(--mp-text)"),onClick:()=>Ve(i=>!i),title:be?"Loop On":"Loop Off",children:jsxRuntime.jsx(lucideReact.Repeat1,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:o("rounded-full p-2 transition-colors",ae,"hover:text-(--mp-text)"),onClick:qe,title:"Previous",children:jsxRuntime.jsx(lucideReact.SkipBack,{className:"h-4 w-4",fill:"currentColor"})}),jsxRuntime.jsx("button",{className:o("flex h-10 w-10 items-center justify-center rounded-full transition-all duration-200","bg-(--accent) text-white shadow-lg active:scale-95"),style:{boxShadow:"0 6px 20px color-mix(in srgb, var(--accent) 35%, transparent)"},onClick:()=>{xe(),z(i=>!i);},title:E?"Pause":"Play",children:E?jsxRuntime.jsx(lucideReact.Pause,{className:"h-4.5 w-4.5",fill:"currentColor"}):jsxRuntime.jsx(lucideReact.Play,{className:"h-4.5 w-4.5 translate-x-px",fill:"currentColor"})}),jsxRuntime.jsx("button",{className:o("rounded-full p-2 transition-colors",ae,"hover:text-(--mp-text)"),onClick:De,title:"Next",children:jsxRuntime.jsx(lucideReact.SkipForward,{className:"h-4 w-4",fill:"currentColor"})}),jsxRuntime.jsxs("div",{className:"ml-2 flex items-center gap-1.5",children:[jsxRuntime.jsx("button",{className:o("rounded-full p-1 transition-colors",ae,"hover:text-(--mp-text)"),onClick:()=>{xe();let i=!_;R(i),re.current&&(re.current.gain.value=i?0:b);},title:_?"Unmute":"Mute",children:_||b===0?jsxRuntime.jsx(lucideReact.VolumeX,{className:"h-3.5 w-3.5"}):jsxRuntime.jsx(lucideReact.Volume2,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("input",{type:"range",min:0,max:1,step:.01,value:_?0:b,onChange:i=>{xe();let F=Number(i.target.value);M(F),_&&R(false),re.current&&(re.current.gain.value=F);},className:"mp-volume-slider h-1 w-14 cursor-pointer appearance-none rounded-full bg-(--mp-surface) accent-(--accent)"})]})]}),jsxRuntime.jsx("div",{className:o("overflow-hidden transition-all duration-300 ease-in-out",Y?"max-h-60":"max-h-0"),children:jsxRuntime.jsx("div",{className:o("border-t px-2 py-2",ee),children:jsxRuntime.jsx("div",{className:"max-h-52 space-y-0.5 overflow-y-auto",children:e.map((i,F)=>{let oe=F===N;return jsxRuntime.jsxs("button",{className:o("flex w-full items-center gap-2.5 rounded-lg px-2.5 py-2 text-left transition-all duration-200",oe?"bg-(--accent)/10 dark:bg-(--accent)/15":"hover:bg-(--mp-surface-hover)"),onClick:()=>{D(F),z(true);},children:[jsxRuntime.jsx("div",{className:"flex h-8 w-8 shrink-0 items-center justify-center",children:oe&&E?jsxRuntime.jsx("div",{className:"flex items-end gap-0.5",children:[1,2,3].map(Pe=>jsxRuntime.jsx("div",{className:"w-0.75 rounded-full bg-(--accent)",style:{height:`${8+Pe*4}px`,animation:`mp-eq-bar ${.4+Pe*.15}s ease-in-out infinite alternate`}},Pe))}):oe?jsxRuntime.jsx(lucideReact.Disc3,{className:o("h-4 w-4",Re)}):jsxRuntime.jsx("span",{className:o("text-xs font-mono",ae),children:F+1})}),jsxRuntime.jsx("div",{className:"h-8 w-8 shrink-0 overflow-hidden rounded",children:jsxRuntime.jsx("img",{src:i.cover||Lt,alt:"",className:"h-full w-full object-cover",draggable:false})}),jsxRuntime.jsxs("div",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("div",{className:o("truncate text-xs font-medium",oe?Re:Se),children:i.title}),i.artist&&jsxRuntime.jsx("div",{className:o("truncate text-[10px]",ae),children:i.artist})]}),s.has(F)&&jsxRuntime.jsx(lucideReact.Heart,{className:"h-3 w-3 shrink-0 text-rose-500",fill:"currentColor"})]},F)})})})})]})})]})}function gt(e){if(!isFinite(e)||e<0)return "0:00";let t=Math.floor(e/3600),n=Math.floor(e%3600/60),u=Math.floor(e%60);return t>0?`${t}:${n.toString().padStart(2,"0")}:${u.toString().padStart(2,"0")}`:`${n}:${u.toString().padStart(2,"0")}`}var jn={title:(e,t)=>e.title.localeCompare(t.title),type:(e,t)=>(e.type??"").localeCompare(t.type??""),duration:(e,t)=>(e.duration??0)-(t.duration??0)};function zt({playlist:e,initialTrack:t=0,autoPlay:n=false,shuffle:u=false,loop:f=false,onTrackChange:c,onPlayChange:d,accent:v="#8b5cf6",className:y}){let[h,L]=br.useState(t),[w,l]=br.useState(false),[m,P]=br.useState(0),[N,H]=br.useState(0),[E,z]=br.useState(0),[V,O]=br.useState(.8),[$,me]=br.useState(false),[b,M]=br.useState(u),[_,R]=br.useState(f),[s,A]=br.useState(false),[Y,ne]=br.useState("title"),[q,ve]=br.useState(true),[X,ye]=br.useState(false),[Xe,Fe]=br.useState(false),[pe,He]=br.useState(false),[be,Ve]=br.useState(true),[_e,j]=br.useState(false),[Ne,te]=br.useState(null),Z=br.useRef(null),re=br.useRef(null),he=br.useRef(void 0),Ee=br.useRef(false),I=e[h],Ue=br__default.default.useMemo(()=>{let a=e.map((T,W)=>({media:T,originalIndex:W}));return a.sort((T,W)=>{let i=jn[Y](T.media,W.media);return q?i:-i}),a},[e,Y,q]);br.useEffect(()=>{let a=Z.current;if(!a)return;j(true),a.src=I.src,I.poster&&(a.poster=I.poster),a.load();let T=()=>{j(false),w&&a.play().catch(()=>{});};return a.addEventListener("loadeddata",T,{once:true}),()=>a.removeEventListener("loadeddata",T)},[h,I.src]),br.useEffect(()=>{if(!n||Ee.current)return;let a=Z.current;if(!a)return;let T=()=>{Ee.current=true,l(true),a.play().catch(()=>{});};return a.addEventListener("canplaythrough",T,{once:true}),()=>a.removeEventListener("canplaythrough",T)},[n]),br.useEffect(()=>{let a=Z.current;a&&(w?a.play().catch(()=>{}):a.pause(),d?.(w));},[w]),br.useEffect(()=>{let a=Z.current;a&&(a.volume=$?0:V);},[V,$]),br.useEffect(()=>{let a=Z.current;if(!a)return;let T=()=>P(a.currentTime),W=()=>H(a.duration),i=()=>{a.buffered.length>0&&z(a.buffered.end(a.buffered.length-1));},F=()=>{_?(a.currentTime=0,a.play().catch(()=>{})):Ce();};return a.addEventListener("timeupdate",T),a.addEventListener("loadedmetadata",W),a.addEventListener("progress",i),a.addEventListener("ended",F),()=>{a.removeEventListener("timeupdate",T),a.removeEventListener("loadedmetadata",W),a.removeEventListener("progress",i),a.removeEventListener("ended",F);}},[h,e.length,_]);let J=br.useCallback(()=>{Ve(true),he.current&&clearTimeout(he.current),he.current=setTimeout(()=>{w&&Ve(false);},3e3);},[w]);br.useEffect(()=>{w?J():(Ve(true),he.current&&clearTimeout(he.current));},[w,J]),br.useEffect(()=>()=>{he.current&&clearTimeout(he.current);},[]);let fe=br.useCallback(a=>{let T=(a%e.length+e.length)%e.length;L(T),P(0),l(true),c?.(T,e[T]);},[e,c]),Ce=br.useCallback(()=>{if(b){let a;do a=Math.floor(Math.random()*e.length);while(a===h&&e.length>1);fe(a);}else fe(h+1);},[fe,h,b,e.length]),Se=br.useCallback(()=>{if(b){let a;do a=Math.floor(Math.random()*e.length);while(a===h&&e.length>1);fe(a);}else fe(h-1);},[fe,h,b,e.length]),ae=br.useCallback(a=>{let T=a.currentTarget.getBoundingClientRect(),i=Math.max(0,Math.min(1,(a.clientX-T.left)/T.width))*N;Z.current&&(Z.current.currentTime=i),P(i);},[N]),Re=br.useCallback(a=>{let T=a.currentTarget.getBoundingClientRect(),W=Math.max(0,Math.min(1,(a.clientX-T.left)/T.width));te(W*N);},[N]),ee=br.useCallback(()=>{re.current&&(document.fullscreenElement?document.exitFullscreen():re.current.requestFullscreen());},[]);br.useEffect(()=>{let a=()=>He(!!document.fullscreenElement);return document.addEventListener("fullscreenchange",a),()=>document.removeEventListener("fullscreenchange",a)},[]);let D=br.useCallback(()=>{X?(Fe(true),setTimeout(()=>{ye(false),Fe(false);},500)):ye(true);},[X]),De=br.useCallback(()=>{A(a=>!a);},[]),qe=br.useCallback(()=>{let a=["title","type","duration"],T=a.indexOf(Y);q?ve(false):(ve(true),ne(a[(T+1)%a.length]));},[Y,q]);br.useEffect(()=>{let a=T=>{if(!(T.target instanceof HTMLInputElement||T.target instanceof HTMLTextAreaElement))switch(T.key){case " ":case "k":T.preventDefault(),l(W=>!W);break;case "f":T.preventDefault(),ee();break;case "t":T.preventDefault(),D();break;case "ArrowLeft":T.preventDefault(),Z.current&&(Z.current.currentTime=Math.max(0,m-5));break;case "ArrowRight":T.preventDefault(),Z.current&&(Z.current.currentTime=Math.min(N,m+5));break;case "ArrowUp":T.preventDefault(),O(W=>Math.min(1,W+.05));break;case "ArrowDown":T.preventDefault(),O(W=>Math.max(0,W-.05));break;case "Escape":X&&D();break;case "n":T.preventDefault(),Ce();break;case "p":T.preventDefault(),Se();break;case "l":T.preventDefault(),De();break}};return window.addEventListener("keydown",a),()=>window.removeEventListener("keydown",a)},[ee,D,De,Ce,Se,m,N,X]);let Qe=N>0?m/N*100:0,ct=N>0?E/N*100:0,ce="text-(--accent)",xe=jsxRuntime.jsxs("div",{ref:re,className:o("group flex overflow-hidden",pe?"h-full w-full":"aspect-video w-full",!pe&&"rounded-xl",!pe&&w&&"shadow-2xl",!pe&&!w&&"animate-[cp-glow-pulse_4s_ease-in-out_infinite] will-change-[box-shadow]",y),style:{"--accent":v,background:"var(--cp-bg)"},tabIndex:0,children:[jsxRuntime.jsxs("div",{className:o("relative flex-1 min-w-0 h-full overflow-hidden",_e&&"animate-[cp-track-transition_0.6s_ease-out]"),onMouseMove:J,onMouseLeave:()=>{w&&Ve(false);},children:[jsxRuntime.jsx("video",{ref:Z,className:"h-full w-full object-contain",poster:I.poster,playsInline:true,preload:"metadata",onClick:()=>l(a=>!a)}),!w&&!_e&&jsxRuntime.jsx("div",{className:"absolute inset-0 flex cursor-pointer items-center justify-center",style:{background:"var(--cp-overlay)"},onClick:()=>l(true),children:jsxRuntime.jsx("div",{className:"flex h-20 w-20 items-center justify-center rounded-full backdrop-blur-md transition-transform hover:scale-110 active:scale-95",style:{background:"var(--cp-surface-hover)"},children:jsxRuntime.jsx(lucideReact.Play,{className:"h-10 w-10 translate-x-0.5",fill:"currentColor",style:{color:"var(--cp-text-strong)"}})})}),_e&&!be&&jsxRuntime.jsx("div",{className:"absolute left-6 top-6 z-20 animate-[fade-in_0.4s_ease-out]",children:jsxRuntime.jsxs("div",{className:"rounded-lg px-4 py-2 backdrop-blur-md",style:{background:"var(--cp-panel-bg)"},children:[jsxRuntime.jsx("div",{className:"text-sm font-semibold",style:{color:"var(--cp-text-strong)"},children:I.title}),I.subtitle&&jsxRuntime.jsx("div",{className:"text-xs",style:{color:"var(--cp-text-muted)"},children:I.subtitle})]})}),jsxRuntime.jsx("div",{className:o("absolute inset-x-0 top-0 z-10 bg-linear-to-b from-black/70 to-transparent px-5 pb-8 pt-4 transition-opacity duration-500",be?"opacity-100":"pointer-events-none opacity-0"),children:jsxRuntime.jsxs("div",{className:"flex items-center justify-between",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("h3",{className:"text-sm font-semibold drop-shadow-md",style:{color:"var(--cp-text-strong)"},children:I.title}),I.subtitle&&jsxRuntime.jsx("p",{className:"text-xs",style:{color:"var(--cp-text-muted)"},children:I.subtitle})]}),I.type&&jsxRuntime.jsx("span",{className:"rounded-full bg-(--accent)/70 px-2.5 py-0.5 text-[10px] font-semibold uppercase tracking-wider backdrop-blur-sm",style:{color:"var(--cp-text-strong)"},children:I.type})]})}),jsxRuntime.jsxs("div",{className:o("absolute inset-x-0 bottom-0 z-10 bg-linear-to-t from-black/80 via-black/40 to-transparent px-4 pb-3 pt-10 transition-all duration-500",be?"translate-y-0 opacity-100":"pointer-events-none translate-y-2 opacity-0"),children:[jsxRuntime.jsxs("div",{className:"group/seek relative mb-3 h-1 cursor-pointer rounded-full transition-[height] duration-200 hover:h-1.5",style:{background:"var(--cp-seek-track)"},onClick:ae,onMouseMove:Re,onMouseLeave:()=>te(null),children:[jsxRuntime.jsx("div",{className:"absolute inset-y-0 left-0 rounded-full",style:{width:`${ct}%`,background:"var(--cp-seek-buffer)"}}),jsxRuntime.jsx("div",{className:"absolute inset-y-0 left-0 rounded-full bg-(--accent) transition-[width] duration-100",style:{width:`${Qe}%`}}),Ne!==null&&jsxRuntime.jsx("div",{className:"absolute -top-8 -translate-x-1/2 rounded px-2 py-0.5 text-[10px] font-mono",style:{left:`${Ne/N*100}%`,background:"var(--cp-panel-bg)",color:"var(--cp-text-strong)"},children:gt(Ne)}),jsxRuntime.jsx("div",{className:"absolute top-1/2 h-3.5 w-3.5 -translate-y-1/2 rounded-full border-2 border-(--accent) bg-white opacity-0 shadow-lg transition-opacity group-hover/seek:opacity-100",style:{left:`calc(${Qe}% - 7px)`}})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsx("button",{className:"cp-btn",onClick:()=>l(a=>!a),title:w?"Pause (k)":"Play (k)",children:w?jsxRuntime.jsx(lucideReact.Pause,{className:"h-5 w-5",fill:"currentColor"}):jsxRuntime.jsx(lucideReact.Play,{className:"h-5 w-5 translate-x-px",fill:"currentColor"})}),jsxRuntime.jsx("button",{className:"cp-btn",onClick:Se,title:"Previous (p)",children:jsxRuntime.jsx(lucideReact.SkipBack,{className:"h-4 w-4",fill:"currentColor"})}),jsxRuntime.jsx("button",{className:"cp-btn",onClick:Ce,title:"Next (n)",children:jsxRuntime.jsx(lucideReact.SkipForward,{className:"h-4 w-4",fill:"currentColor"})}),jsxRuntime.jsxs("div",{className:"group/vol ml-1 flex items-center",children:[jsxRuntime.jsx("button",{className:"cp-btn",onClick:()=>me(a=>!a),title:$?"Unmute":"Mute",children:$||V===0?jsxRuntime.jsx(lucideReact.VolumeX,{className:"h-4 w-4"}):jsxRuntime.jsx(lucideReact.Volume2,{className:"h-4 w-4"})}),jsxRuntime.jsx("div",{className:"flex w-0 items-center overflow-hidden transition-all duration-300 group-hover/vol:w-20",children:jsxRuntime.jsx("input",{type:"range",min:0,max:1,step:.01,value:$?0:V,onChange:a=>{O(Number(a.target.value)),$&&me(false);},className:"h-1 w-full cursor-pointer appearance-none rounded-full accent-(--accent)",style:{background:"var(--cp-seek-track)"}})})]}),jsxRuntime.jsxs("span",{className:"ml-2 min-w-0 shrink-0 font-mono text-xs",style:{color:"var(--cp-text-muted)"},children:[gt(m)," / ",gt(N)]}),jsxRuntime.jsx("div",{className:"flex-1"}),jsxRuntime.jsx("button",{className:o("cp-btn",b&&ce),onClick:()=>M(a=>!a),title:"Shuffle",children:jsxRuntime.jsx(lucideReact.Shuffle,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:o("cp-btn",_&&ce),onClick:()=>R(a=>!a),title:"Loop",children:jsxRuntime.jsx(lucideReact.Repeat1,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:o("cp-btn",s&&ce),onClick:De,title:"Playlist",children:jsxRuntime.jsx(lucideReact.ListVideo,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:o("cp-btn",X&&ce),onClick:D,title:"Cinema mode (t)",children:jsxRuntime.jsx(lucideReact.Theater,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:"cp-btn",onClick:ee,title:"Fullscreen (f)",children:pe?jsxRuntime.jsx(lucideReact.Minimize,{className:"h-4 w-4"}):jsxRuntime.jsx(lucideReact.Maximize,{className:"h-4 w-4"})})]})]})]}),jsxRuntime.jsx("div",{className:o("h-full shrink-0 overflow-hidden transition-[width] duration-300 ease-out",s?"w-72":"w-0"),children:jsxRuntime.jsxs("div",{className:"flex h-full w-72 flex-col backdrop-blur-xl",style:{borderLeft:"1px solid var(--cp-border)",background:"var(--cp-panel-bg)"},children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between px-4 py-3",style:{borderBottom:"1px solid var(--cp-border)"},children:[jsxRuntime.jsx("span",{className:"text-xs font-semibold uppercase tracking-wider",style:{color:"var(--cp-text)"},children:"Playlist"}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsxs("button",{className:"flex items-center gap-1 rounded px-2 py-1 text-[10px] font-medium transition-colors",style:{color:"var(--cp-text-muted)"},onClick:qe,title:`Sort: ${Y} ${q?"\u2191":"\u2193"}`,children:[jsxRuntime.jsx(lucideReact.ArrowUpDown,{className:"h-3 w-3"}),Y,q?" \u2191":" \u2193"]}),jsxRuntime.jsx("button",{className:"cp-btn p-1!",onClick:De,title:"Close",children:jsxRuntime.jsx(lucideReact.X,{className:"h-3.5 w-3.5"})})]})]}),jsxRuntime.jsx("div",{className:"flex-1 overflow-y-auto",children:Ue.map(({media:a,originalIndex:T})=>{let W=T===h;return jsxRuntime.jsxs("button",{className:o("flex w-full items-center gap-3 px-4 py-2.5 text-left transition-all duration-200",W?"bg-(--accent)/20 text-(--accent)":"hover:text-(--cp-text-strong)"),style:W?void 0:{color:"var(--cp-text)"},onClick:()=>{fe(T);},children:[jsxRuntime.jsxs("div",{className:"relative h-10 w-16 shrink-0 overflow-hidden rounded",style:{background:"var(--cp-surface)"},children:[a.poster?jsxRuntime.jsx("img",{src:a.poster,alt:"",className:"h-full w-full object-cover",draggable:false}):jsxRuntime.jsx("div",{className:"flex h-full w-full items-center justify-center",children:jsxRuntime.jsx(lucideReact.Play,{className:"h-4 w-4",style:{color:"var(--cp-seek-track)"}})}),W&&w&&jsxRuntime.jsx("div",{className:"absolute inset-0 flex items-center justify-center",style:{background:"var(--cp-overlay)"},children:jsxRuntime.jsx("div",{className:"flex items-end gap-px",children:[1,2,3,4].map(i=>jsxRuntime.jsx("div",{className:"w-0.5 rounded-full bg-(--accent)",style:{height:`${6+i*3}px`,animation:`mp-eq-bar ${.3+i*.12}s ease-in-out infinite alternate`}},i))})})]}),jsxRuntime.jsxs("div",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("div",{className:"truncate text-xs font-medium",children:a.title}),jsxRuntime.jsxs("div",{className:"flex items-center gap-2",children:[a.type&&jsxRuntime.jsx("span",{className:"text-[10px] uppercase tracking-wide opacity-50",children:a.type}),a.duration!=null&&jsxRuntime.jsx("span",{className:"font-mono text-[10px] opacity-40",children:gt(a.duration)})]})]}),W&&jsxRuntime.jsx(lucideReact.ChevronRight,{className:"h-3.5 w-3.5 shrink-0 text-(--accent)"})]},T)})})]})}),jsxRuntime.jsx("style",{children:`
|
|
6
|
+
</svg>`);function oo(e){if(!isFinite(e)||e<0)return "0:00";let t=Math.floor(e/60),r=Math.floor(e%60);return `${t}:${r.toString().padStart(2,"0")}`}function Ks(e){return e.startsWith("bottom")?"bottom":e.startsWith("top")?"top":"right"}var Ws={"bottom-right":"bottom-4 right-4","bottom-left":"bottom-4 left-4","top-right":"top-4 right-4","top-left":"top-4 left-4"},Ys={"bottom-right":"bottom-4 right-0","bottom-left":"bottom-4 left-0","top-right":"top-4 right-0","top-left":"top-4 left-0"},qs={"bottom-right":"bottom-8 right-0 w-1.5 h-16 rounded-l-full","bottom-left":"bottom-8 left-0 w-1.5 h-16 rounded-r-full","top-right":"top-8 right-0 w-1.5 h-16 rounded-l-full","top-left":"top-8 left-0 w-1.5 h-16 rounded-r-full"};function Qr({playlist:e,initialTrack:t=0,position:r="bottom-right",entrance:n,theme:o,docked:a=false,visible:s,onVisibleChange:l,onTrackChange:i,onLike:d,autoPlay:m=true,shuffle:u=false,loop:p=false,accent:c="#8b5cf6",className:h}){let [f,g]=Yr.useState(t),[b,w]=Yr.useState(false),[C,x]=Yr.useState(0),[M,F]=Yr.useState(0),[P,L]=Yr.useState(.8),[H,R]=Yr.useState(false),[y,_]=Yr.useState(new Set),[X,z]=Yr.useState(false),[Y,ge]=Yr.useState(s??!a),[E,ye]=Yr.useState(false),[fe,Ne]=Yr.useState(false),[ne,Te]=Yr.useState(u),[K,Ee]=Yr.useState(p),We=Yr.useRef(false),O=Yr.useRef(null),ae=Yr.useRef(null),le=Yr.useRef(void 0),te=Yr.useRef(null),be=Yr.useRef(null),Se=s??Y,De=n??Ks(r),J=e[f],ce=a,Pe=o==="dark"?"dark":o==="light"?"light":"",G="bg-(--mp-bg)",he="text-(--mp-text)",ke="text-(--mp-text-muted)",Ze="text-(--accent)",xe="border-(--mp-border)";Yr.useEffect(()=>{let A=O.current;A&&(A.src=J.src,A.load(),b&&A.play().catch(()=>{}));},[f,J.src]),Yr.useEffect(()=>{if(!m||We.current)return;let A=O.current;if(!A)return;let oe=()=>{We.current=true,w(true),A.play().catch(()=>{});};return A.addEventListener("canplaythrough",oe,{once:true}),()=>A.removeEventListener("canplaythrough",oe)},[m]),Yr.useEffect(()=>{let A=O.current;A&&(b?A.play().catch(()=>{}):A.pause());},[b]),Yr.useEffect(()=>{let A=O.current;A&&(A.muted=H,be.current?be.current.gain.value=H?0:P:A.volume=P);},[P,H]),Yr.useEffect(()=>{let A=O.current;if(!A)return;let oe=()=>x(A.currentTime),Re=()=>F(A.duration),et=()=>{K?(A.currentTime=0,A.play().catch(()=>{})):Ye();};return A.addEventListener("timeupdate",oe),A.addEventListener("loadedmetadata",Re),A.addEventListener("ended",et),()=>{A.removeEventListener("timeupdate",oe),A.removeEventListener("loadedmetadata",Re),A.removeEventListener("ended",et);}},[f,e.length]);let re=Yr.useCallback(A=>{let oe=(A%e.length+e.length)%e.length;g(oe),x(0),i?.(oe,e[oe]),Se||(ge(true),l?.(true));},[e,Se,i,l]),Ye=Yr.useCallback(()=>{if(ne){let A;do A=Math.floor(Math.random()*e.length);while(A===f&&e.length>1);re(A);}else re(f+1);},[re,f,ne,e.length]),ct=Yr.useCallback(()=>{if(ne){let A;do A=Math.floor(Math.random()*e.length);while(A===f&&e.length>1);re(A);}else re(f-1);},[re,f,ne,e.length]),it=Yr.useCallback(()=>{let A=y.has(f);_(oe=>{let Re=new Set(oe);return A?Re.delete(f):Re.add(f),Re}),d?.(f,J,!A);},[f,y,d,J]),St=Yr.useCallback(A=>{let oe=A.currentTarget.getBoundingClientRect(),et=Math.max(0,Math.min(1,(A.clientX-oe.left)/oe.width))*M;O.current&&(O.current.currentTime=et),x(et);},[M]),Ae=Yr.useCallback(()=>{ye(true);let A=ce?200:400;le.current=setTimeout(()=>{ye(false),ge(false),l?.(false);},A);},[ce,l]);Yr.useEffect(()=>()=>{le.current&&clearTimeout(le.current);},[]),Yr.useEffect(()=>()=>{te.current?.close();},[]);function _e(){if(te.current||!O.current){te.current?.resume();return}try{let A=window.AudioContext??window.webkitAudioContext;if(!A)return;let oe=new A,Re=oe.createGain();Re.gain.value=H?0:P,oe.createMediaElementSource(O.current).connect(Re).connect(oe.destination),te.current=oe,be.current=Re,oe.resume();}catch{}}let T=fe?"fade-in 0.2s ease-out both":`mp-enter-${De} 0.45s cubic-bezier(0.16, 1, 0.3, 1) both`,q=fe?"fade-in 0.2s ease-in reverse both":`mp-exit-${De} 0.4s cubic-bezier(0.7, 0, 0.84, 0) both`,de=M>0?C/M*100:0;return ce&&!Se&&!E?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("audio",{ref:O,preload:"metadata",crossOrigin:"anonymous"}),jsxRuntime.jsxs("div",{className:v("fixed z-100 cursor-pointer transition-all duration-300",qs[r]),style:{"--accent":c},onMouseEnter:()=>{Ne(true),ge(true),l?.(true);},children:[jsxRuntime.jsx("div",{className:v("h-full w-full rounded-full",b?"bg-(--accent)":"bg-(--mp-dock-strip)"),style:b?{animation:"mp-progress-glow 2s ease-in-out infinite",boxShadow:"0 0 12px color-mix(in srgb, var(--accent) 50%, transparent)"}:void 0}),b&&jsxRuntime.jsx("div",{className:"absolute inset-0 rounded-full bg-(--accent)/30",style:{animation:"mp-pulse-ring 2s ease-out infinite"}})]})]}):!Se&&!E?jsxRuntime.jsx("audio",{ref:O,preload:"metadata",crossOrigin:"anonymous"}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("audio",{ref:O,preload:"metadata",crossOrigin:"anonymous"}),jsxRuntime.jsx("div",{className:v("fixed z-100",ce?Ys[r]:Ws[r],Pe),style:{"--accent":c,...E?{animation:q}:{animation:T}},onMouseEnter:()=>{ce&&(le.current&&(clearTimeout(le.current),le.current=void 0),E&&ye(false),Ne(true));},onMouseLeave:()=>{ce&&(Ne(false),Ae());},children:jsxRuntime.jsxs("div",{className:v("w-[320px] overflow-hidden rounded-2xl border shadow-2xl backdrop-blur-xl",G,xe,ce&&"rounded-none",r.endsWith("right")&&ce&&"rounded-l-2xl",r.endsWith("left")&&ce&&"rounded-r-2xl",h),children:[jsxRuntime.jsxs("div",{className:"relative",children:[jsxRuntime.jsx("div",{className:"absolute inset-0 overflow-hidden",children:jsxRuntime.jsx("img",{src:J.cover||Jr,alt:"",className:"h-full w-full scale-110 object-cover opacity-30 blur-2xl",draggable:false})}),jsxRuntime.jsxs("div",{className:"relative flex items-center gap-3.5 p-4 pb-3",children:[jsxRuntime.jsxs("div",{className:"relative h-14 w-14 shrink-0",children:[jsxRuntime.jsxs("div",{className:"h-14 w-14 overflow-hidden rounded-full border-2 border-white/10 shadow-lg",style:b?{animation:"mp-vinyl-spin 4s linear infinite"}:void 0,children:[jsxRuntime.jsx("img",{src:J.cover||Jr,alt:J.album??J.title,className:"h-full w-full object-cover",draggable:false}),jsxRuntime.jsx("div",{className:"absolute inset-0 flex items-center justify-center",children:jsxRuntime.jsx("div",{className:"h-3 w-3 rounded-full bg-black/60 ring-1 ring-white/10"})})]}),b&&jsxRuntime.jsx("div",{className:"absolute inset-0 rounded-full bg-(--accent)/20",style:{animation:"mp-pulse-ring 2.5s ease-out infinite"}})]}),jsxRuntime.jsxs("div",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("div",{className:v("truncate text-sm font-semibold",he),children:J.title}),J.artist&&jsxRuntime.jsx("div",{className:v("truncate text-xs",ke),children:J.artist}),J.album&&jsxRuntime.jsx("div",{className:v("mt-0.5 truncate text-[10px] tracking-wide",ke,"opacity-60"),children:J.album})]}),jsxRuntime.jsxs("div",{className:"flex shrink-0 items-center gap-0.5",children:[jsxRuntime.jsx("button",{className:v("rounded-full p-1.5 transition-all duration-200",y.has(f)?"text-rose-500 hover:text-rose-400":v(ke,"hover:text-rose-500")),onClick:it,title:"Like",children:jsxRuntime.jsx(lucideReact.Heart,{className:"h-4 w-4",fill:y.has(f)?"currentColor":"none"})}),jsxRuntime.jsx("button",{className:v("rounded-full p-1.5 transition-colors",ke,"hover:"+he.split(" ")[0]),onClick:()=>z(A=>!A),title:"Playlist",children:jsxRuntime.jsx(lucideReact.ListMusic,{className:"h-4 w-4"})}),!ce&&jsxRuntime.jsx("button",{className:v("rounded-full p-1.5 transition-colors",ke,"hover:"+he.split(" ")[0]),onClick:Ae,title:"Dismiss",children:jsxRuntime.jsx(lucideReact.X,{className:"h-3.5 w-3.5"})})]})]})]}),jsxRuntime.jsxs("div",{className:"px-4",children:[jsxRuntime.jsxs("div",{ref:ae,className:"group relative h-1.5 cursor-pointer rounded-full bg-(--mp-surface)",onClick:St,children:[jsxRuntime.jsx("div",{className:"h-full rounded-full bg-(--accent) transition-[width] duration-150",style:{width:`${de}%`}}),jsxRuntime.jsx("div",{className:"absolute top-1/2 h-3 w-3 -translate-y-1/2 rounded-full bg-(--accent) opacity-0 shadow-md transition-opacity group-hover:opacity-100",style:{left:`calc(${de}% - 6px)`}})]}),jsxRuntime.jsxs("div",{className:v("mt-1 flex justify-between text-[10px] font-mono",ke),children:[jsxRuntime.jsx("span",{children:oo(C)}),jsxRuntime.jsx("span",{children:oo(M)})]})]}),jsxRuntime.jsxs("div",{className:"flex items-center justify-center gap-2 px-4 pb-3 pt-1",children:[jsxRuntime.jsx("button",{className:v("rounded-full p-1.5 transition-colors",ne?Ze:ke,"hover:text-(--mp-text)"),onClick:()=>Te(A=>!A),title:ne?"Shuffle On":"Shuffle Off",children:jsxRuntime.jsx(lucideReact.Shuffle,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:v("rounded-full p-1.5 transition-colors",K?Ze:ke,"hover:text-(--mp-text)"),onClick:()=>Ee(A=>!A),title:K?"Loop On":"Loop Off",children:jsxRuntime.jsx(lucideReact.Repeat1,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:v("rounded-full p-2 transition-colors",ke,"hover:text-(--mp-text)"),onClick:ct,title:"Previous",children:jsxRuntime.jsx(lucideReact.SkipBack,{className:"h-4 w-4",fill:"currentColor"})}),jsxRuntime.jsx("button",{className:v("flex h-10 w-10 items-center justify-center rounded-full transition-all duration-200","bg-(--accent) text-white shadow-lg active:scale-95"),style:{boxShadow:"0 6px 20px color-mix(in srgb, var(--accent) 35%, transparent)"},onClick:()=>{_e(),w(A=>!A);},title:b?"Pause":"Play",children:b?jsxRuntime.jsx(lucideReact.Pause,{className:"h-4.5 w-4.5",fill:"currentColor"}):jsxRuntime.jsx(lucideReact.Play,{className:"h-4.5 w-4.5 translate-x-px",fill:"currentColor"})}),jsxRuntime.jsx("button",{className:v("rounded-full p-2 transition-colors",ke,"hover:text-(--mp-text)"),onClick:Ye,title:"Next",children:jsxRuntime.jsx(lucideReact.SkipForward,{className:"h-4 w-4",fill:"currentColor"})}),jsxRuntime.jsxs("div",{className:"ml-2 flex items-center gap-1.5",children:[jsxRuntime.jsx("button",{className:v("rounded-full p-1 transition-colors",ke,"hover:text-(--mp-text)"),onClick:()=>{_e();let A=!H;R(A),be.current&&(be.current.gain.value=A?0:P);},title:H?"Unmute":"Mute",children:H||P===0?jsxRuntime.jsx(lucideReact.VolumeX,{className:"h-3.5 w-3.5"}):jsxRuntime.jsx(lucideReact.Volume2,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("input",{type:"range",min:0,max:1,step:.01,value:H?0:P,onChange:A=>{_e();let oe=Number(A.target.value);L(oe),H&&R(false),be.current&&(be.current.gain.value=oe);},className:"mp-volume-slider h-1 w-14 cursor-pointer appearance-none rounded-full bg-(--mp-surface) accent-(--accent)"})]})]}),jsxRuntime.jsx("div",{className:v("overflow-hidden transition-all duration-300 ease-in-out",X?"max-h-60":"max-h-0"),children:jsxRuntime.jsx("div",{className:v("border-t px-2 py-2",xe),children:jsxRuntime.jsx("div",{className:"max-h-52 space-y-0.5 overflow-y-auto",children:e.map((A,oe)=>{let Re=oe===f;return jsxRuntime.jsxs("button",{className:v("flex w-full items-center gap-2.5 rounded-lg px-2.5 py-2 text-left transition-all duration-200",Re?"bg-(--accent)/10 dark:bg-(--accent)/15":"hover:bg-(--mp-surface-hover)"),onClick:()=>{re(oe),w(true);},children:[jsxRuntime.jsx("div",{className:"flex h-8 w-8 shrink-0 items-center justify-center",children:Re&&b?jsxRuntime.jsx("div",{className:"flex items-end gap-0.5",children:[1,2,3].map(et=>jsxRuntime.jsx("div",{className:"w-0.75 rounded-full bg-(--accent)",style:{height:`${8+et*4}px`,animation:`mp-eq-bar ${.4+et*.15}s ease-in-out infinite alternate`}},et))}):Re?jsxRuntime.jsx(lucideReact.Disc3,{className:v("h-4 w-4",Ze)}):jsxRuntime.jsx("span",{className:v("text-xs font-mono",ke),children:oe+1})}),jsxRuntime.jsx("div",{className:"h-8 w-8 shrink-0 overflow-hidden rounded",children:jsxRuntime.jsx("img",{src:A.cover||Jr,alt:"",className:"h-full w-full object-cover",draggable:false})}),jsxRuntime.jsxs("div",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("div",{className:v("truncate text-xs font-medium",Re?Ze:he),children:A.title}),A.artist&&jsxRuntime.jsx("div",{className:v("truncate text-[10px]",ke),children:A.artist})]}),y.has(oe)&&jsxRuntime.jsx(lucideReact.Heart,{className:"h-3 w-3 shrink-0 text-rose-500",fill:"currentColor"})]},oe)})})})})]})})]})}function xr(e){if(!isFinite(e)||e<0)return "0:00";let t=Math.floor(e/3600),r=Math.floor(e%3600/60),n=Math.floor(e%60);return t>0?`${t}:${r.toString().padStart(2,"0")}:${n.toString().padStart(2,"0")}`:`${r}:${n.toString().padStart(2,"0")}`}var di={title:(e,t)=>e.title.localeCompare(t.title),type:(e,t)=>(e.type??"").localeCompare(t.type??""),duration:(e,t)=>(e.duration??0)-(t.duration??0)};function en({playlist:e,initialTrack:t=0,autoPlay:r=false,shuffle:n=false,loop:o=false,onTrackChange:a,onPlayChange:s,accent:l="#8b5cf6",className:i}){let[d,m]=Yr.useState(t),[u,p]=Yr.useState(false),[c,h]=Yr.useState(0),[f,g]=Yr.useState(0),[b,w]=Yr.useState(0),[C,x]=Yr.useState(.8),[M,F]=Yr.useState(false),[P,L]=Yr.useState(n),[H,R]=Yr.useState(o),[y,_]=Yr.useState(false),[X,z]=Yr.useState("title"),[Y,ge]=Yr.useState(true),[E,ye]=Yr.useState(false),[fe,Ne]=Yr.useState(false),[ne,Te]=Yr.useState(false),[K,Ee]=Yr.useState(true),[We,O]=Yr.useState(false),[ae,le]=Yr.useState(null),te=Yr.useRef(null),be=Yr.useRef(null),Se=Yr.useRef(void 0),De=Yr.useRef(false),J=e[d],at=Yr__default.default.useMemo(()=>{let T=e.map((q,de)=>({media:q,originalIndex:de}));return T.sort((q,de)=>{let A=di[X](q.media,de.media);return Y?A:-A}),T},[e,X,Y]);Yr.useEffect(()=>{let T=te.current;if(!T)return;O(true),T.src=J.src,J.poster&&(T.poster=J.poster),T.load();let q=()=>{O(false),u&&T.play().catch(()=>{});};return T.addEventListener("loadeddata",q,{once:true}),()=>T.removeEventListener("loadeddata",q)},[d,J.src]),Yr.useEffect(()=>{if(!r||De.current)return;let T=te.current;if(!T)return;let q=()=>{De.current=true,p(true),T.play().catch(()=>{});};return T.addEventListener("canplaythrough",q,{once:true}),()=>T.removeEventListener("canplaythrough",q)},[r]),Yr.useEffect(()=>{let T=te.current;T&&(u?T.play().catch(()=>{}):T.pause(),s?.(u));},[u]),Yr.useEffect(()=>{let T=te.current;T&&(T.volume=M?0:C);},[C,M]),Yr.useEffect(()=>{let T=te.current;if(!T)return;let q=()=>h(T.currentTime),de=()=>g(T.duration),A=()=>{T.buffered.length>0&&w(T.buffered.end(T.buffered.length-1));},oe=()=>{H?(T.currentTime=0,T.play().catch(()=>{})):G();};return T.addEventListener("timeupdate",q),T.addEventListener("loadedmetadata",de),T.addEventListener("progress",A),T.addEventListener("ended",oe),()=>{T.removeEventListener("timeupdate",q),T.removeEventListener("loadedmetadata",de),T.removeEventListener("progress",A),T.removeEventListener("ended",oe);}},[d,e.length,H]);let ce=Yr.useCallback(()=>{Ee(true),Se.current&&clearTimeout(Se.current),Se.current=setTimeout(()=>{u&&Ee(false);},3e3);},[u]);Yr.useEffect(()=>{u?ce():(Ee(true),Se.current&&clearTimeout(Se.current));},[u,ce]),Yr.useEffect(()=>()=>{Se.current&&clearTimeout(Se.current);},[]);let Pe=Yr.useCallback(T=>{let q=(T%e.length+e.length)%e.length;m(q),h(0),p(true),a?.(q,e[q]);},[e,a]),G=Yr.useCallback(()=>{if(P){let T;do T=Math.floor(Math.random()*e.length);while(T===d&&e.length>1);Pe(T);}else Pe(d+1);},[Pe,d,P,e.length]),he=Yr.useCallback(()=>{if(P){let T;do T=Math.floor(Math.random()*e.length);while(T===d&&e.length>1);Pe(T);}else Pe(d-1);},[Pe,d,P,e.length]),ke=Yr.useCallback(T=>{let q=T.currentTarget.getBoundingClientRect(),A=Math.max(0,Math.min(1,(T.clientX-q.left)/q.width))*f;te.current&&(te.current.currentTime=A),h(A);},[f]),Ze=Yr.useCallback(T=>{let q=T.currentTarget.getBoundingClientRect(),de=Math.max(0,Math.min(1,(T.clientX-q.left)/q.width));le(de*f);},[f]),xe=Yr.useCallback(()=>{be.current&&(document.fullscreenElement?document.exitFullscreen():be.current.requestFullscreen());},[]);Yr.useEffect(()=>{let T=()=>Te(!!document.fullscreenElement);return document.addEventListener("fullscreenchange",T),()=>document.removeEventListener("fullscreenchange",T)},[]);let re=Yr.useCallback(()=>{E?(Ne(true),setTimeout(()=>{ye(false),Ne(false);},500)):ye(true);},[E]),Ye=Yr.useCallback(()=>{_(T=>!T);},[]),ct=Yr.useCallback(()=>{let T=["title","type","duration"],q=T.indexOf(X);Y?ge(false):(ge(true),z(T[(q+1)%T.length]));},[X,Y]);Yr.useEffect(()=>{let T=q=>{if(!(q.target instanceof HTMLInputElement||q.target instanceof HTMLTextAreaElement))switch(q.key){case " ":case "k":q.preventDefault(),p(de=>!de);break;case "f":q.preventDefault(),xe();break;case "t":q.preventDefault(),re();break;case "ArrowLeft":q.preventDefault(),te.current&&(te.current.currentTime=Math.max(0,c-5));break;case "ArrowRight":q.preventDefault(),te.current&&(te.current.currentTime=Math.min(f,c+5));break;case "ArrowUp":q.preventDefault(),x(de=>Math.min(1,de+.05));break;case "ArrowDown":q.preventDefault(),x(de=>Math.max(0,de-.05));break;case "Escape":E&&re();break;case "n":q.preventDefault(),G();break;case "p":q.preventDefault(),he();break;case "l":q.preventDefault(),Ye();break}};return window.addEventListener("keydown",T),()=>window.removeEventListener("keydown",T)},[xe,re,Ye,G,he,c,f,E]);let it=f>0?c/f*100:0,St=f>0?b/f*100:0,Ae="text-(--accent)",_e=jsxRuntime.jsxs("div",{ref:be,className:v("group flex overflow-hidden",ne?"h-full w-full":"aspect-video w-full",!ne&&"rounded-xl",!ne&&u&&"shadow-2xl",!ne&&!u&&"animate-[cp-glow-pulse_4s_ease-in-out_infinite] will-change-[box-shadow]",i),style:{"--accent":l,background:"var(--cp-bg)"},tabIndex:0,children:[jsxRuntime.jsxs("div",{className:v("relative flex-1 min-w-0 h-full overflow-hidden",We&&"animate-[cp-track-transition_0.6s_ease-out]"),onMouseMove:ce,onMouseLeave:()=>{u&&Ee(false);},children:[jsxRuntime.jsx("video",{ref:te,className:"h-full w-full object-contain",poster:J.poster,playsInline:true,preload:"metadata",onClick:()=>p(T=>!T)}),!u&&!We&&jsxRuntime.jsx("div",{className:"absolute inset-0 flex cursor-pointer items-center justify-center",style:{background:"var(--cp-overlay)"},onClick:()=>p(true),children:jsxRuntime.jsx("div",{className:"flex h-20 w-20 items-center justify-center rounded-full backdrop-blur-md transition-transform hover:scale-110 active:scale-95",style:{background:"var(--cp-surface-hover)"},children:jsxRuntime.jsx(lucideReact.Play,{className:"h-10 w-10 translate-x-0.5",fill:"currentColor",style:{color:"var(--cp-text-strong)"}})})}),We&&!K&&jsxRuntime.jsx("div",{className:"absolute left-6 top-6 z-20 animate-[fade-in_0.4s_ease-out]",children:jsxRuntime.jsxs("div",{className:"rounded-lg px-4 py-2 backdrop-blur-md",style:{background:"var(--cp-panel-bg)"},children:[jsxRuntime.jsx("div",{className:"text-sm font-semibold",style:{color:"var(--cp-text-strong)"},children:J.title}),J.subtitle&&jsxRuntime.jsx("div",{className:"text-xs",style:{color:"var(--cp-text-muted)"},children:J.subtitle})]})}),jsxRuntime.jsx("div",{className:v("absolute inset-x-0 top-0 z-10 bg-linear-to-b from-black/70 to-transparent px-5 pb-8 pt-4 transition-opacity duration-500",K?"opacity-100":"pointer-events-none opacity-0"),children:jsxRuntime.jsxs("div",{className:"flex items-center justify-between",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("h3",{className:"text-sm font-semibold drop-shadow-md",style:{color:"var(--cp-text-strong)"},children:J.title}),J.subtitle&&jsxRuntime.jsx("p",{className:"text-xs",style:{color:"var(--cp-text-muted)"},children:J.subtitle})]}),J.type&&jsxRuntime.jsx("span",{className:"rounded-full bg-(--accent)/70 px-2.5 py-0.5 text-[10px] font-semibold uppercase tracking-wider backdrop-blur-sm",style:{color:"var(--cp-text-strong)"},children:J.type})]})}),jsxRuntime.jsxs("div",{className:v("absolute inset-x-0 bottom-0 z-10 bg-linear-to-t from-black/80 via-black/40 to-transparent px-4 pb-3 pt-10 transition-all duration-500",K?"translate-y-0 opacity-100":"pointer-events-none translate-y-2 opacity-0"),children:[jsxRuntime.jsxs("div",{className:"group/seek relative mb-3 h-1 cursor-pointer rounded-full transition-[height] duration-200 hover:h-1.5",style:{background:"var(--cp-seek-track)"},onClick:ke,onMouseMove:Ze,onMouseLeave:()=>le(null),children:[jsxRuntime.jsx("div",{className:"absolute inset-y-0 left-0 rounded-full",style:{width:`${St}%`,background:"var(--cp-seek-buffer)"}}),jsxRuntime.jsx("div",{className:"absolute inset-y-0 left-0 rounded-full bg-(--accent) transition-[width] duration-100",style:{width:`${it}%`}}),ae!==null&&jsxRuntime.jsx("div",{className:"absolute -top-8 -translate-x-1/2 rounded px-2 py-0.5 text-[10px] font-mono",style:{left:`${ae/f*100}%`,background:"var(--cp-panel-bg)",color:"var(--cp-text-strong)"},children:xr(ae)}),jsxRuntime.jsx("div",{className:"absolute top-1/2 h-3.5 w-3.5 -translate-y-1/2 rounded-full border-2 border-(--accent) bg-white opacity-0 shadow-lg transition-opacity group-hover/seek:opacity-100",style:{left:`calc(${it}% - 7px)`}})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsx("button",{className:"cp-btn",onClick:()=>p(T=>!T),title:u?"Pause (k)":"Play (k)",children:u?jsxRuntime.jsx(lucideReact.Pause,{className:"h-5 w-5",fill:"currentColor"}):jsxRuntime.jsx(lucideReact.Play,{className:"h-5 w-5 translate-x-px",fill:"currentColor"})}),jsxRuntime.jsx("button",{className:"cp-btn",onClick:he,title:"Previous (p)",children:jsxRuntime.jsx(lucideReact.SkipBack,{className:"h-4 w-4",fill:"currentColor"})}),jsxRuntime.jsx("button",{className:"cp-btn",onClick:G,title:"Next (n)",children:jsxRuntime.jsx(lucideReact.SkipForward,{className:"h-4 w-4",fill:"currentColor"})}),jsxRuntime.jsxs("div",{className:"group/vol ml-1 flex items-center",children:[jsxRuntime.jsx("button",{className:"cp-btn",onClick:()=>F(T=>!T),title:M?"Unmute":"Mute",children:M||C===0?jsxRuntime.jsx(lucideReact.VolumeX,{className:"h-4 w-4"}):jsxRuntime.jsx(lucideReact.Volume2,{className:"h-4 w-4"})}),jsxRuntime.jsx("div",{className:"flex w-0 items-center overflow-hidden transition-all duration-300 group-hover/vol:w-20",children:jsxRuntime.jsx("input",{type:"range",min:0,max:1,step:.01,value:M?0:C,onChange:T=>{x(Number(T.target.value)),M&&F(false);},className:"h-1 w-full cursor-pointer appearance-none rounded-full accent-(--accent)",style:{background:"var(--cp-seek-track)"}})})]}),jsxRuntime.jsxs("span",{className:"ml-2 min-w-0 shrink-0 font-mono text-xs",style:{color:"var(--cp-text-muted)"},children:[xr(c)," / ",xr(f)]}),jsxRuntime.jsx("div",{className:"flex-1"}),jsxRuntime.jsx("button",{className:v("cp-btn",P&&Ae),onClick:()=>L(T=>!T),title:"Shuffle",children:jsxRuntime.jsx(lucideReact.Shuffle,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:v("cp-btn",H&&Ae),onClick:()=>R(T=>!T),title:"Loop",children:jsxRuntime.jsx(lucideReact.Repeat1,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:v("cp-btn",y&&Ae),onClick:Ye,title:"Playlist",children:jsxRuntime.jsx(lucideReact.ListVideo,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:v("cp-btn",E&&Ae),onClick:re,title:"Cinema mode (t)",children:jsxRuntime.jsx(lucideReact.Theater,{className:"h-4 w-4"})}),jsxRuntime.jsx("button",{className:"cp-btn",onClick:xe,title:"Fullscreen (f)",children:ne?jsxRuntime.jsx(lucideReact.Minimize,{className:"h-4 w-4"}):jsxRuntime.jsx(lucideReact.Maximize,{className:"h-4 w-4"})})]})]})]}),jsxRuntime.jsx("div",{className:v("h-full shrink-0 overflow-hidden transition-[width] duration-300 ease-out",y?"w-72":"w-0"),children:jsxRuntime.jsxs("div",{className:"flex h-full w-72 flex-col backdrop-blur-xl",style:{borderLeft:"1px solid var(--cp-border)",background:"var(--cp-panel-bg)"},children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between px-4 py-3",style:{borderBottom:"1px solid var(--cp-border)"},children:[jsxRuntime.jsx("span",{className:"text-xs font-semibold uppercase tracking-wider",style:{color:"var(--cp-text)"},children:"Playlist"}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsxs("button",{className:"flex items-center gap-1 rounded px-2 py-1 text-[10px] font-medium transition-colors",style:{color:"var(--cp-text-muted)"},onClick:ct,title:`Sort: ${X} ${Y?"\u2191":"\u2193"}`,children:[jsxRuntime.jsx(lucideReact.ArrowUpDown,{className:"h-3 w-3"}),X,Y?" \u2191":" \u2193"]}),jsxRuntime.jsx("button",{className:"cp-btn p-1!",onClick:Ye,title:"Close",children:jsxRuntime.jsx(lucideReact.X,{className:"h-3.5 w-3.5"})})]})]}),jsxRuntime.jsx("div",{className:"flex-1 overflow-y-auto",children:at.map(({media:T,originalIndex:q})=>{let de=q===d;return jsxRuntime.jsxs("button",{className:v("flex w-full items-center gap-3 px-4 py-2.5 text-left transition-all duration-200",de?"bg-(--accent)/20 text-(--accent)":"hover:text-(--cp-text-strong)"),style:de?void 0:{color:"var(--cp-text)"},onClick:()=>{Pe(q);},children:[jsxRuntime.jsxs("div",{className:"relative h-10 w-16 shrink-0 overflow-hidden rounded",style:{background:"var(--cp-surface)"},children:[T.poster?jsxRuntime.jsx("img",{src:T.poster,alt:"",className:"h-full w-full object-cover",draggable:false}):jsxRuntime.jsx("div",{className:"flex h-full w-full items-center justify-center",children:jsxRuntime.jsx(lucideReact.Play,{className:"h-4 w-4",style:{color:"var(--cp-seek-track)"}})}),de&&u&&jsxRuntime.jsx("div",{className:"absolute inset-0 flex items-center justify-center",style:{background:"var(--cp-overlay)"},children:jsxRuntime.jsx("div",{className:"flex items-end gap-px",children:[1,2,3,4].map(A=>jsxRuntime.jsx("div",{className:"w-0.5 rounded-full bg-(--accent)",style:{height:`${6+A*3}px`,animation:`mp-eq-bar ${.3+A*.12}s ease-in-out infinite alternate`}},A))})})]}),jsxRuntime.jsxs("div",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("div",{className:"truncate text-xs font-medium",children:T.title}),jsxRuntime.jsxs("div",{className:"flex items-center gap-2",children:[T.type&&jsxRuntime.jsx("span",{className:"text-[10px] uppercase tracking-wide opacity-50",children:T.type}),T.duration!=null&&jsxRuntime.jsx("span",{className:"font-mono text-[10px] opacity-40",children:xr(T.duration)})]})]}),de&&jsxRuntime.jsx(lucideReact.ChevronRight,{className:"h-3.5 w-3.5 shrink-0 text-(--accent)"})]},q)})})]})}),jsxRuntime.jsx("style",{children:`
|
|
7
7
|
.cp-btn {
|
|
8
8
|
display: flex;
|
|
9
9
|
align-items: center;
|
|
@@ -19,7 +19,7 @@
|
|
|
19
19
|
0%, 100% { box-shadow: 0 0 20px color-mix(in srgb, var(--accent) 25%, transparent), 0 25px 50px -12px rgba(0,0,0,0.25); }
|
|
20
20
|
50% { box-shadow: 0 0 40px color-mix(in srgb, var(--accent) 55%, transparent), 0 25px 50px -12px rgba(0,0,0,0.25); }
|
|
21
21
|
}
|
|
22
|
-
`})]});return jsxRuntime.jsx("div",{className:o(X&&"fixed inset-0 z-100 flex items-center justify-center p-8",X&&(Xe?"animate-[cp-cinema-out_0.5s_ease-in_both]":"animate-[cp-cinema-in_0.5s_ease-out_both]")),onClick:X?a=>{a.target===a.currentTarget&&D();}:void 0,children:jsxRuntime.jsx("div",{className:o(X&&"w-full",X&&!pe&&"max-w-5xl"),children:xe})})}var _t=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 je=[];function Yn(e){je.push(e);}function Wn(e){let t=je.indexOf(e);t!==-1&&je.splice(t,1);}function It(e){return je.length>0&&je[je.length-1]===e}function Un(e){let t=je.indexOf(e);return t!==-1?t:je.length}var lr=br.createContext(null);function cr({open:e,onOpenChange:t,modal:n=true,closeOnOutsideClick:u=false,children:f}){let c=br.useId();return br.useEffect(()=>{if(e)return Yn(c),()=>Wn(c)},[e,c]),br.useEffect(()=>{if(!e||!n)return;let d=v=>{v.key==="Escape"&&It(c)&&t(false);};return document.addEventListener("keydown",d),()=>document.removeEventListener("keydown",d)},[e,n,t,c]),br.useEffect(()=>{if(!e||!n)return;let d=document.body.style.overflow;return document.body.style.overflow="hidden",()=>{document.body.style.overflow=d;}},[e,n]),e?jsxRuntime.jsx(lr.Provider,{value:{id:c,onOpenChange:t,modal:n,closeOnOutsideClick:u},children:reactDom.createPortal(f,document.body)}):null}function dr({size:e,position:t="center",className:n,children:u,...f}){let c=br.useContext(lr);if(!c)return null;let v=200+Un(c.id)*10,y=()=>{c.closeOnOutsideClick&&It(c.id)&&c.onOpenChange(false);},h=t==="bottom";return c.modal?jsxRuntime.jsx("div",{className:o("animate-fade-in fixed inset-0 bg-black/50",h?"flex items-end justify-center":"flex items-center justify-center p-4"),style:{zIndex:v},onClick:y,children:jsxRuntime.jsx("div",{className:o(_t({size:e}),h?"animate-slide-in-bottom w-full rounded-b-none rounded-t-(--dialog-sheet-radius) max-h-[85vh] overflow-y-auto":"animate-scale-in",n),role:"dialog","aria-modal":"true",onClick:L=>L.stopPropagation(),...f,children:u})}):jsxRuntime.jsx("div",{className:o("fixed inset-0 flex items-center justify-center p-4",c.closeOnOutsideClick?"pointer-events-auto":"pointer-events-none"),style:{zIndex:v},onClick:c.closeOnOutsideClick&&It(c.id)?()=>c.onOpenChange(false):void 0,children:jsxRuntime.jsx("div",{className:o(_t({size:e}),"animate-scale-in pointer-events-auto shadow-2xl",n),role:"dialog",onClick:c.closeOnOutsideClick?L=>L.stopPropagation():void 0,...f,children:u})})}function ur({className:e,...t}){return jsxRuntime.jsx("div",{className:o("mb-4 space-y-1",e),...t})}function mr({className:e,...t}){return jsxRuntime.jsx("h2",{className:o("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",e),...t})}function pr({className:e,...t}){return jsxRuntime.jsx("p",{className:o("text-primary-500 dark:text-primary-400 text-sm",e),...t})}function fr({className:e,...t}){return jsxRuntime.jsx("div",{className:o("mt-6 flex justify-end gap-2",e),...t})}var gr=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 Ft({intent:e,size:t,className:n,...u}){return jsxRuntime.jsx("button",{className:o(gr({intent:e,size:t}),n),...u})}function bt(e){let t=e.lastIndexOf(".");return t>0?e.slice(t).toLowerCase():""}function yr(e){return e==null?"\u2014":e<1024?`${e} B`:e<1024*1024?`${(e/1024).toFixed(1)} KB`:e<1024*1024*1024?`${(e/(1024*1024)).toFixed(1)} MB`:`${(e/(1024*1024*1024)).toFixed(2)} GB`}function $t(e){return e?(typeof e=="string"?new Date(e):e).toLocaleDateString(void 0,{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"}):"\u2014"}var ca={".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 jt(e){if(e.type==="directory")return lucideReact.Folder;let t=e.extension||bt(e.name);return ca[t]||lucideReact.File}function it(e,t,n){return Math.max(t,Math.min(n,e))}function wr(e){return e<480?"xs":e<640?"sm":e<1024?"md":"lg"}function kr(e,t){if(e<480)return {size:{width:e-16,height:t-48},pos:{x:8,y:24}};if(e<640){let f=e-24,c=Math.min(t-64,540);return {size:{width:f,height:c},pos:{x:12,y:32}}}if(e<1024){let f=Math.min(640,e-32),c=Math.min(480,t-64);return {size:{width:f,height:c},pos:{x:Math.max(0,Math.round((e-f)/2)),y:Math.max(0,Math.round((t-c)/2))}}}let n=720,u=520;return {size:{width:n,height:u},pos:{x:Math.max(0,Math.round((e-n)/2)),y:Math.max(0,Math.round((t-u)/2))}}}function Bt({files:e,title:t="File Explorer",accent:n="#8b5cf6",defaultView:u="list",initialPosition:f,initialSize:c,dockable:d=false,dockSide:v="right",visible:y=true,onFileOpen:h,onSelectionChange:L,onNavigate:w,onDelete:l,onClose:m,onMinimize:P,onPathSubmit:N,defaultInputMode:H="search",actions:E,resizable:z=true,minSize:V={width:400,height:300},className:O}){let[$,me]=br.useState(u),[b,M]=br.useState(new Set),[_,R]=br.useState(null),[s,A]=br.useState(false),[Y,ne]=br.useState(false),[q,ve]=br.useState(""),[X,ye]=br.useState(H),[Xe,Fe]=br.useState(y),[pe,He]=br.useState(false),[be,Ve]=br.useState({w:window.innerWidth,h:window.innerHeight}),_e=kr(window.innerWidth,window.innerHeight),[j,Ne]=br.useState(f??_e.pos),[te,Z]=br.useState(c??_e.size),[re,he]=br.useState(null),Ee=br.useRef(false),I=br.useRef({x:0,y:0}),Ue=br.useRef(null),J=br.useRef(false),fe=br.useRef({x:0,y:0,w:0,h:0,px:0,py:0}),Ce=br.useRef(false),Se=br.useRef(s);br.useEffect(()=>{Se.current=s;},[s]);let ae=y!==void 0?y:Xe,Re=br.useMemo(()=>{let r=e.filter(B=>B.type==="directory"),k=e.filter(B=>B.type==="file");return r.sort((B,K)=>B.name.localeCompare(K.name)),k.sort((B,K)=>B.name.localeCompare(K.name)),[...r,...k]},[e]),ee=br.useMemo(()=>{if(X!=="search"||!q.trim())return Re;let r=q.toLowerCase();return Re.filter(k=>k.name.toLowerCase().includes(r))},[Re,q,X]),D=_!=null?ee[_]:null;br.useEffect(()=>{let r=wr(window.innerWidth),k=()=>{let B=window.innerWidth,K=window.innerHeight;if(Ve({w:B,h:K}),Se.current)return;let Q=wr(B);if(Q!==r&&!Ce.current&&!c){let Me=kr(B,K);Z(Me.size),Ne(Me.pos);}r=Q;};return window.addEventListener("resize",k),()=>window.removeEventListener("resize",k)},[c]);let De=br.useCallback((r,k)=>{M(B=>{let K=new Set(B);return k.ctrlKey||k.metaKey?K.has(r)?K.delete(r):K.add(r):(K.clear(),K.add(r)),K}),R(r);},[]);br.useEffect(()=>{if(!L)return;let r=Array.from(b).map(k=>ee[k]).filter(Boolean);L(r);},[b]);let qe=br.useCallback(r=>{let k=ee[r];k&&(k.type==="directory"?w?.(k.path):h?.(k));},[ee,h,w]),Qe=br.useCallback(r=>{s||r.target.closest("button")||(Ce.current=true,Ee.current=true,I.current={x:r.clientX-j.x,y:r.clientY-j.y},r.preventDefault());},[j,s]),ct=br.useCallback(r=>{if(s||r.target.closest("button"))return;Ce.current=true;let k=r.touches[0];Ee.current=true,I.current={x:k.clientX-j.x,y:k.clientY-j.y};},[j,s]);br.useEffect(()=>{let r=K=>{if(!Ee.current)return;let Q=window.innerWidth-100,Me=window.innerHeight-40;Ne({x:it(K.clientX-I.current.x,0,Q),y:it(K.clientY-I.current.y,0,Me)});},k=K=>{if(!Ee.current)return;K.preventDefault();let Q=K.touches[0],Me=window.innerWidth-100,Ge=window.innerHeight-40;Ne({x:it(Q.clientX-I.current.x,0,Me),y:it(Q.clientY-I.current.y,0,Ge)});},B=()=>{Ee.current=false,J.current=false,document.body.style.cursor="",document.body.style.userSelect="";};return window.addEventListener("mousemove",r),window.addEventListener("mouseup",B),window.addEventListener("touchmove",k,{passive:false}),window.addEventListener("touchend",B),()=>{window.removeEventListener("mousemove",r),window.removeEventListener("mouseup",B),window.removeEventListener("touchmove",k),window.removeEventListener("touchend",B);}},[]);let ce=br.useCallback((r,k)=>{s||(k.preventDefault(),k.stopPropagation(),Ce.current=true,J.current=r,fe.current={x:k.clientX,y:k.clientY,w:te.width,h:te.height,px:j.x,py:j.y},document.body.style.cursor=r==="e"||r==="w"?"ew-resize":r==="n"||r==="s"?"ns-resize":r==="nw"||r==="se"?"nwse-resize":"nesw-resize",document.body.style.userSelect="none");},[s,te,j]),xe=br.useCallback((r,k)=>{if(s)return;k.preventDefault(),k.stopPropagation(),Ce.current=true;let B=k.touches[0];J.current=r,fe.current={x:B.clientX,y:B.clientY,w:te.width,h:te.height,px:j.x,py:j.y},document.body.style.userSelect="none";},[s,te,j]);br.useEffect(()=>{let r=(Q,Me)=>{let Ge=J.current;if(!Ge)return;let Qt=Q-fe.current.x,Zt=Me-fe.current.y,{w:Ze,h:Je,px:Mt,py:Tt}=fe.current;if(Ge.includes("e")&&(Ze=Math.max(V.width,Ze+Qt)),Ge.includes("w")){let dt=Math.max(V.width,Ze-Qt);Mt=Mt+(Ze-dt),Ze=dt;}if(Ge.includes("s")&&(Je=Math.max(V.height,Je+Zt)),Ge.includes("n")){let dt=Math.max(V.height,Je-Zt);Tt=Tt+(Je-dt),Je=dt;}Z({width:Ze,height:Je}),Ne({x:Mt,y:Tt});},k=Q=>{J.current&&r(Q.clientX,Q.clientY);},B=Q=>{J.current&&(Q.preventDefault(),r(Q.touches[0].clientX,Q.touches[0].clientY));},K=()=>{J.current=false,document.body.style.cursor="",document.body.style.userSelect="";};return window.addEventListener("mousemove",k),window.addEventListener("mouseup",K),window.addEventListener("touchmove",B,{passive:false}),window.addEventListener("touchend",K),()=>{window.removeEventListener("mousemove",k),window.removeEventListener("mouseup",K),window.removeEventListener("touchmove",B),window.removeEventListener("touchend",K);}},[V]);let a=br.useCallback(()=>{s?(re&&(Ne(re.pos),Z(re.size)),A(false)):(he({pos:j,size:te}),A(true));},[s,j,te,re]),T=br.useCallback(()=>{Y?ne(false):(s&&(A(false),re&&(Ne(re.pos),Z(re.size))),ne(true),P?.());},[Y,s,re,P]);br.useEffect(()=>{if(!ae||Y)return;let r=k=>{if(!(!Ue.current?.contains(document.activeElement)&&document.activeElement!==Ue.current)){if(k.key==="Escape"&&(R(null),M(new Set)),k.ctrlKey&&k.key==="a"){k.preventDefault();let B=new Set(ee.map((K,Q)=>Q));M(B);}k.key==="Delete"&&b.size>0&&l&&(k.preventDefault(),He(true));}};return window.addEventListener("keydown",r),()=>window.removeEventListener("keydown",r)},[ae,Y,ee,b,l]);let W={"--fe-accent":n};if(Y)return jsxRuntime.jsx("div",{className:o("fixed z-100 cursor-pointer transition-all duration-300",v==="right"?"right-0 top-1/2 -translate-y-1/2":"left-0 top-1/2 -translate-y-1/2"),style:W,onClick:()=>ne(false),title:`Restore ${t}`,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:t})]})});if(!ae)return null;let i=s?be.w:Math.min(te.width,be.w-8),F=s?be.h:Math.min(te.height,be.h-8),oe=s?0:it(j.x,0,Math.max(0,be.w-i)),Pe=s?0:it(j.y,0,Math.max(0,be.h-40)),Ct=i<500;return jsxRuntime.jsxs("div",{ref:Ue,className:o("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]",s&&"rounded-none",O),style:{...W,left:oe,top:Pe,width:i,height:F,transition:s?"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:Qe,onTouchStart:ct,onDoubleClick:a,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:t}),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:()=>me(r=>r==="list"?"grid":"list"),title:$==="list"?"Grid view":"List view",children:$==="list"?jsxRuntime.jsx(lucideReact.LayoutGrid,{className:"h-3.5 w-3.5"}):jsxRuntime.jsx(lucideReact.LayoutList,{className:"h-3.5 w-3.5"})}),d&&jsxRuntime.jsx("button",{className:"fe-btn",onClick:T,title:"Dock to edge",children:jsxRuntime.jsx(lucideReact.Minus,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:"fe-btn",onClick:a,title:s?"Restore":"Maximize",children:s?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:()=>{m?.(),Fe(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:()=>w?.(".."),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:X==="navigate"?{color:"var(--fe-accent)",background:"color-mix(in srgb, var(--fe-accent) 15%, transparent)"}:void 0,onClick:()=>ye(r=>r==="search"?"navigate":"search"),title:X==="search"?"Switch to path navigation":"Switch to file search",children:X==="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:q,onChange:r=>ve(r.target.value),onKeyDown:r=>{r.key==="Enter"&&q.trim()&&X==="navigate"&&(N?N(q.trim()):w?.(q.trim()));},placeholder:X==="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:[ee.length," item",ee.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:r=>{r.target===r.currentTarget&&(M(new Set),R(null));},children:ee.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"})]}):$==="list"?jsxRuntime.jsx("div",{className:"space-y-px",children:ee.map((r,k)=>{let B=jt(r),K=b.has(k),Q=r.extension||bt(r.name);return jsxRuntime.jsxs("div",{className:o("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",K?"bg-(--fe-accent)/15 text-(--fe-text-strong)":"hover:bg-(--fe-surface-hover) hover:text-(--fe-text-strong)"),style:K?{boxShadow:"inset 2px 0 0 var(--fe-accent)"}:void 0,onClick:Me=>De(k,Me),onDoubleClick:()=>qe(k),children:[jsxRuntime.jsx(B,{className:o("h-4 w-4 shrink-0",r.type==="directory"?"text-(--fe-accent)":"text-(--fe-text-muted)")}),jsxRuntime.jsx("span",{className:"flex-1 truncate text-xs font-medium",children:r.name}),Q&&r.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:Q}),r.size!=null&&jsxRuntime.jsx("span",{className:"shrink-0 font-mono text-[10px] text-(--fe-text-muted)",children:yr(r.size)}),r.modifiedAt&&jsxRuntime.jsx("span",{className:"hidden shrink-0 font-mono text-[10px] text-(--fe-text-muted) lg:inline",children:$t(r.modifiedAt)})]},r.path+k)})}):jsxRuntime.jsx("div",{className:"grid grid-cols-[repeat(auto-fill,minmax(90px,1fr))] gap-1.5 p-1",children:ee.map((r,k)=>{let B=jt(r),K=b.has(k),Q=r.extension||bt(r.name);return jsxRuntime.jsxs("div",{className:o("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",K?"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:Me=>De(k,Me),onDoubleClick:()=>qe(k),children:[jsxRuntime.jsx(B,{className:o("h-7 w-7",r.type==="directory"?"text-(--fe-accent)":"text-(--fe-text-muted)")}),jsxRuntime.jsx("span",{className:"w-full truncate text-[10px] font-medium leading-tight",children:r.name}),Q&&r.type==="file"&&jsxRuntime.jsx("span",{className:"font-mono text-[8px] uppercase text-(--fe-text-muted)",children:Q})]},r.path+k)})})}),jsxRuntime.jsx("div",{className:o("overflow-hidden transition-[width,opacity] duration-300 ease-out",Ct?o("absolute right-0 top-0 bottom-0 z-10",D?"w-44 opacity-100":"w-0 opacity-0 pointer-events-none"):o("shrink-0",D?"w-56":"w-0")),children:D&&jsxRuntime.jsxs("div",{className:o("flex h-full flex-col p-4",Ct?"fe-panel-narrow w-44":"fe-panel w-56 border-l border-(--fe-border)"),children:[Ct&&jsxRuntime.jsx("button",{className:"fe-btn mb-2 self-end",onClick:()=>{R(null),M(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:[br__default.default.createElement(jt(D),{className:o("h-10 w-10 mb-2",D.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:D.name})]}),jsxRuntime.jsxs("div",{className:"space-y-2.5 text-[10px]",children:[jsxRuntime.jsx(lt,{label:"Type",value:D.type==="directory"?"Directory":D.mimeType||D.extension||bt(D.name)||"File"}),D.size!=null&&jsxRuntime.jsx(lt,{label:"Size",value:yr(D.size)}),jsxRuntime.jsx(lt,{label:"Path",value:D.path,mono:true}),D.extension&&jsxRuntime.jsx(lt,{label:"Extension",value:D.extension}),D.modifiedAt&&jsxRuntime.jsx(lt,{label:"Modified",value:$t(D.modifiedAt)}),D.createdAt&&jsxRuntime.jsx(lt,{label:"Created",value:$t(D.createdAt)})]}),jsxRuntime.jsxs("div",{className:"mt-auto flex flex-col gap-1.5",children:[D.type==="file"&&h&&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:()=>h(D),children:[jsxRuntime.jsx(lucideReact.ArrowUp,{className:"h-3 w-3 rotate-45"}),"Open"]}),E?.map(r=>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:()=>r.onClick(D),children:[r.icon&&br__default.default.createElement(r.icon,{className:"h-3 w-3"}),r.label]},r.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:[ee.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"})]})]}),z&&!s&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"absolute top-0 left-4 right-4 h-3 cursor-ns-resize",onMouseDown:r=>ce("n",r),onTouchStart:r=>xe("n",r)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 left-4 right-4 h-3 cursor-ns-resize",onMouseDown:r=>ce("s",r),onTouchStart:r=>xe("s",r)}),jsxRuntime.jsx("div",{className:"absolute top-4 left-0 bottom-4 w-3 cursor-ew-resize",onMouseDown:r=>ce("w",r),onTouchStart:r=>xe("w",r)}),jsxRuntime.jsx("div",{className:"absolute top-4 right-0 bottom-4 w-3 cursor-ew-resize",onMouseDown:r=>ce("e",r),onTouchStart:r=>xe("e",r)}),jsxRuntime.jsx("div",{className:"absolute top-0 left-0 h-6 w-6 cursor-nwse-resize",onMouseDown:r=>ce("nw",r),onTouchStart:r=>xe("nw",r)}),jsxRuntime.jsx("div",{className:"absolute top-0 right-0 h-6 w-6 cursor-nesw-resize",onMouseDown:r=>ce("ne",r),onTouchStart:r=>xe("ne",r)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 left-0 h-6 w-6 cursor-nesw-resize",onMouseDown:r=>ce("sw",r),onTouchStart:r=>xe("sw",r)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 right-0 h-6 w-6 cursor-nwse-resize",onMouseDown:r=>ce("se",r),onTouchStart:r=>xe("se",r)})]}),jsxRuntime.jsx("style",{children:`
|
|
22
|
+
`})]});return jsxRuntime.jsx("div",{className:v(E&&"fixed inset-0 z-100 flex items-center justify-center p-8",E&&(fe?"animate-[cp-cinema-out_0.5s_ease-in_both]":"animate-[cp-cinema-in_0.5s_ease-out_both]")),onClick:E?T=>{T.target===T.currentTarget&&re();}:void 0,children:jsxRuntime.jsx("div",{className:v(E&&"w-full",E&&!ne&&"max-w-5xl"),children:_e})})}var tn=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 xt=[];function hi(e){xt.push(e);}function gi(e){let t=xt.indexOf(e);t!==-1&&xt.splice(t,1);}function nn(e){return xt.length>0&&xt[xt.length-1]===e}function bi(e){let t=xt.indexOf(e);return t!==-1?t:xt.length}var io=Yr.createContext(null);function lo({open:e,onOpenChange:t,modal:r=true,closeOnOutsideClick:n=false,children:o}){let a=Yr.useId();return Yr.useEffect(()=>{if(e)return hi(a),()=>gi(a)},[e,a]),Yr.useEffect(()=>{if(!e||!r)return;let s=l=>{l.key==="Escape"&&nn(a)&&t(false);};return document.addEventListener("keydown",s),()=>document.removeEventListener("keydown",s)},[e,r,t,a]),Yr.useEffect(()=>{if(!e||!r)return;let s=document.body.style.overflow;return document.body.style.overflow="hidden",()=>{document.body.style.overflow=s;}},[e,r]),e?jsxRuntime.jsx(io.Provider,{value:{id:a,onOpenChange:t,modal:r,closeOnOutsideClick:n},children:reactDom.createPortal(o,document.body)}):null}function co({size:e,position:t="center",className:r,children:n,...o}){let a=Yr.useContext(io);if(!a)return null;let l=200+bi(a.id)*10,i=()=>{a.closeOnOutsideClick&&nn(a.id)&&a.onOpenChange(false);},d=t==="bottom";return a.modal?jsxRuntime.jsx("div",{className:v("animate-fade-in fixed inset-0 bg-black/50",d?"flex items-end justify-center":"flex items-center justify-center p-4"),style:{zIndex:l},onClick:i,children:jsxRuntime.jsx("div",{className:v(tn({size:e}),d?"animate-slide-in-bottom w-full rounded-b-none rounded-t-(--dialog-sheet-radius) max-h-[85vh] overflow-y-auto":"animate-scale-in",r),role:"dialog","aria-modal":"true",onClick:m=>m.stopPropagation(),...o,children:n})}):jsxRuntime.jsx("div",{className:v("fixed inset-0 flex items-center justify-center p-4",a.closeOnOutsideClick?"pointer-events-auto":"pointer-events-none"),style:{zIndex:l},onClick:a.closeOnOutsideClick&&nn(a.id)?()=>a.onOpenChange(false):void 0,children:jsxRuntime.jsx("div",{className:v(tn({size:e}),"animate-scale-in pointer-events-auto shadow-2xl",r),role:"dialog",onClick:a.closeOnOutsideClick?m=>m.stopPropagation():void 0,...o,children:n})})}function uo({className:e,...t}){return jsxRuntime.jsx("div",{className:v("mb-4 space-y-1",e),...t})}function po({className:e,...t}){return jsxRuntime.jsx("h2",{className:v("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",e),...t})}function mo({className:e,...t}){return jsxRuntime.jsx("p",{className:v("text-primary-500 dark:text-primary-400 text-sm",e),...t})}function fo({className:e,...t}){return jsxRuntime.jsx("div",{className:v("mt-6 flex justify-end gap-2",e),...t})}var ho=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"}});var go=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"}}),bo=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"}}),vo=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"}});var yo=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"}});var xo=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 Pt({intent:e,size:t,className:r,...n}){return jsxRuntime.jsx("button",{className:v(ho({intent:e,size:t}),r),...n})}function wr(e){let t=e.lastIndexOf(".");return t>0?e.slice(t).toLowerCase():""}function Co(e){return e==null?"\u2014":e<1024?`${e} B`:e<1024*1024?`${(e/1024).toFixed(1)} KB`:e<1024*1024*1024?`${(e/(1024*1024)).toFixed(1)} MB`:`${(e/(1024*1024*1024)).toFixed(2)} GB`}function ln(e){return e?(typeof e=="string"?new Date(e):e).toLocaleDateString(void 0,{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"}):"\u2014"}var Di={".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 cn(e){if(e.type==="directory")return lucideReact.Folder;let t=e.extension||wr(e.name);return Di[t]||lucideReact.File}function Kt(e,t,r){return Math.max(t,Math.min(r,e))}function So(e){return e<480?"xs":e<640?"sm":e<1024?"md":"lg"}function To(e,t){if(e<480)return {size:{width:e-16,height:t-48},pos:{x:8,y:24}};if(e<640){let o=e-24,a=Math.min(t-64,540);return {size:{width:o,height:a},pos:{x:12,y:32}}}if(e<1024){let o=Math.min(640,e-32),a=Math.min(480,t-64);return {size:{width:o,height:a},pos:{x:Math.max(0,Math.round((e-o)/2)),y:Math.max(0,Math.round((t-a)/2))}}}let r=720,n=520;return {size:{width:r,height:n},pos:{x:Math.max(0,Math.round((e-r)/2)),y:Math.max(0,Math.round((t-n)/2))}}}function dn({files:e,title:t="File Explorer",accent:r="#8b5cf6",defaultView:n="list",initialPosition:o,initialSize:a,dockable:s=false,dockSide:l="right",visible:i=true,onFileOpen:d,onSelectionChange:m,onNavigate:u,onDelete:p,onClose:c,onMinimize:h,onPathSubmit:f,defaultInputMode:g="search",actions:b,resizable:w=true,minSize:C={width:400,height:300},className:x}){let[M,F]=Yr.useState(n),[P,L]=Yr.useState(new Set),[H,R]=Yr.useState(null),[y,_]=Yr.useState(false),[X,z]=Yr.useState(false),[Y,ge]=Yr.useState(""),[E,ye]=Yr.useState(g),[fe,Ne]=Yr.useState(i),[ne,Te]=Yr.useState(false),[K,Ee]=Yr.useState({w:window.innerWidth,h:window.innerHeight}),We=To(window.innerWidth,window.innerHeight),[O,ae]=Yr.useState(o??We.pos),[le,te]=Yr.useState(a??We.size),[be,Se]=Yr.useState(null),De=Yr.useRef(false),J=Yr.useRef({x:0,y:0}),at=Yr.useRef(null),ce=Yr.useRef(false),Pe=Yr.useRef({x:0,y:0,w:0,h:0,px:0,py:0}),G=Yr.useRef(false),he=Yr.useRef(y);Yr.useEffect(()=>{he.current=y;},[y]);let ke=i!==void 0?i:fe,Ze=Yr.useMemo(()=>{let k=e.filter(se=>se.type==="directory"),j=e.filter(se=>se.type==="file");return k.sort((se,ie)=>se.name.localeCompare(ie.name)),j.sort((se,ie)=>se.name.localeCompare(ie.name)),[...k,...j]},[e]),xe=Yr.useMemo(()=>{if(E!=="search"||!Y.trim())return Ze;let k=Y.toLowerCase();return Ze.filter(j=>j.name.toLowerCase().includes(k))},[Ze,Y,E]),re=H!=null?xe[H]:null;Yr.useEffect(()=>{let k=So(window.innerWidth),j=()=>{let se=window.innerWidth,ie=window.innerHeight;if(Ee({w:se,h:ie}),he.current)return;let ve=So(se);if(ve!==k&&!G.current&&!a){let qe=To(se,ie);te(qe.size),ae(qe.pos);}k=ve;};return window.addEventListener("resize",j),()=>window.removeEventListener("resize",j)},[a]);let Ye=Yr.useCallback((k,j)=>{L(se=>{let ie=new Set(se);return j.ctrlKey||j.metaKey?ie.has(k)?ie.delete(k):ie.add(k):(ie.clear(),ie.add(k)),ie}),R(k);},[]);Yr.useEffect(()=>{if(!m)return;let k=Array.from(P).map(j=>xe[j]).filter(Boolean);m(k);},[P]);let ct=Yr.useCallback(k=>{let j=xe[k];j&&(j.type==="directory"?u?.(j.path):d?.(j));},[xe,d,u]),it=Yr.useCallback(k=>{y||k.target.closest("button")||(G.current=true,De.current=true,J.current={x:k.clientX-O.x,y:k.clientY-O.y},k.preventDefault());},[O,y]),St=Yr.useCallback(k=>{if(y||k.target.closest("button"))return;G.current=true;let j=k.touches[0];De.current=true,J.current={x:j.clientX-O.x,y:j.clientY-O.y};},[O,y]);Yr.useEffect(()=>{let k=ie=>{if(!De.current)return;let ve=window.innerWidth-100,qe=window.innerHeight-40;ae({x:Kt(ie.clientX-J.current.x,0,ve),y:Kt(ie.clientY-J.current.y,0,qe)});},j=ie=>{if(!De.current)return;ie.preventDefault();let ve=ie.touches[0],qe=window.innerWidth-100,dt=window.innerHeight-40;ae({x:Kt(ve.clientX-J.current.x,0,qe),y:Kt(ve.clientY-J.current.y,0,dt)});},se=()=>{De.current=false,ce.current=false,document.body.style.cursor="",document.body.style.userSelect="";};return window.addEventListener("mousemove",k),window.addEventListener("mouseup",se),window.addEventListener("touchmove",j,{passive:false}),window.addEventListener("touchend",se),()=>{window.removeEventListener("mousemove",k),window.removeEventListener("mouseup",se),window.removeEventListener("touchmove",j),window.removeEventListener("touchend",se);}},[]);let Ae=Yr.useCallback((k,j)=>{y||(j.preventDefault(),j.stopPropagation(),G.current=true,ce.current=k,Pe.current={x:j.clientX,y:j.clientY,w:le.width,h:le.height,px:O.x,py:O.y},document.body.style.cursor=k==="e"||k==="w"?"ew-resize":k==="n"||k==="s"?"ns-resize":k==="nw"||k==="se"?"nwse-resize":"nesw-resize",document.body.style.userSelect="none");},[y,le,O]),_e=Yr.useCallback((k,j)=>{if(y)return;j.preventDefault(),j.stopPropagation(),G.current=true;let se=j.touches[0];ce.current=k,Pe.current={x:se.clientX,y:se.clientY,w:le.width,h:le.height,px:O.x,py:O.y},document.body.style.userSelect="none";},[y,le,O]);Yr.useEffect(()=>{let k=(ve,qe)=>{let dt=ce.current;if(!dt)return;let hr=ve-Pe.current.x,N=qe-Pe.current.y,{w:ut,h:bt,px:er,py:Ht}=Pe.current;if(dt.includes("e")&&(ut=Math.max(C.width,ut+hr)),dt.includes("w")){let Tt=Math.max(C.width,ut-hr);er=er+(ut-Tt),ut=Tt;}if(dt.includes("s")&&(bt=Math.max(C.height,bt+N)),dt.includes("n")){let Tt=Math.max(C.height,bt-N);Ht=Ht+(bt-Tt),bt=Tt;}te({width:ut,height:bt}),ae({x:er,y:Ht});},j=ve=>{ce.current&&k(ve.clientX,ve.clientY);},se=ve=>{ce.current&&(ve.preventDefault(),k(ve.touches[0].clientX,ve.touches[0].clientY));},ie=()=>{ce.current=false,document.body.style.cursor="",document.body.style.userSelect="";};return window.addEventListener("mousemove",j),window.addEventListener("mouseup",ie),window.addEventListener("touchmove",se,{passive:false}),window.addEventListener("touchend",ie),()=>{window.removeEventListener("mousemove",j),window.removeEventListener("mouseup",ie),window.removeEventListener("touchmove",se),window.removeEventListener("touchend",ie);}},[C]);let T=Yr.useCallback(()=>{y?(be&&(ae(be.pos),te(be.size)),_(false)):(Se({pos:O,size:le}),_(true));},[y,O,le,be]),q=Yr.useCallback(()=>{X?z(false):(y&&(_(false),be&&(ae(be.pos),te(be.size))),z(true),h?.());},[X,y,be,h]);Yr.useEffect(()=>{if(!ke||X)return;let k=j=>{if(!(!at.current?.contains(document.activeElement)&&document.activeElement!==at.current)){if(j.key==="Escape"&&(R(null),L(new Set)),j.ctrlKey&&j.key==="a"){j.preventDefault();let se=new Set(xe.map((ie,ve)=>ve));L(se);}j.key==="Delete"&&P.size>0&&p&&(j.preventDefault(),Te(true));}};return window.addEventListener("keydown",k),()=>window.removeEventListener("keydown",k)},[ke,X,xe,P,p]);let de={"--fe-accent":r};if(X)return jsxRuntime.jsx("div",{className:v("fixed z-100 cursor-pointer transition-all duration-300",l==="right"?"right-0 top-1/2 -translate-y-1/2":"left-0 top-1/2 -translate-y-1/2"),style:de,onClick:()=>z(false),title:`Restore ${t}`,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:t})]})});if(!ke)return null;let A=y?K.w:Math.min(le.width,K.w-8),oe=y?K.h:Math.min(le.height,K.h-8),Re=y?0:Kt(O.x,0,Math.max(0,K.w-A)),et=y?0:Kt(O.y,0,Math.max(0,K.h-40)),_t=A<500;return jsxRuntime.jsxs("div",{ref:at,className:v("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]",y&&"rounded-none",x),style:{...de,left:Re,top:et,width:A,height:oe,transition:y?"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:it,onTouchStart:St,onDoubleClick:T,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:t}),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:()=>F(k=>k==="list"?"grid":"list"),title:M==="list"?"Grid view":"List view",children:M==="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:q,title:"Dock to edge",children:jsxRuntime.jsx(lucideReact.Minus,{className:"h-3.5 w-3.5"})}),jsxRuntime.jsx("button",{className:"fe-btn",onClick:T,title:y?"Restore":"Maximize",children:y?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:()=>{c?.(),Ne(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:()=>u?.(".."),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:E==="navigate"?{color:"var(--fe-accent)",background:"color-mix(in srgb, var(--fe-accent) 15%, transparent)"}:void 0,onClick:()=>ye(k=>k==="search"?"navigate":"search"),title:E==="search"?"Switch to path navigation":"Switch to file search",children:E==="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:Y,onChange:k=>ge(k.target.value),onKeyDown:k=>{k.key==="Enter"&&Y.trim()&&E==="navigate"&&(f?f(Y.trim()):u?.(Y.trim()));},placeholder:E==="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:[xe.length," item",xe.length!==1?"s":"",P.size>0&&` \xB7 ${P.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:k=>{k.target===k.currentTarget&&(L(new Set),R(null));},children:xe.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"})]}):M==="list"?jsxRuntime.jsx("div",{className:"space-y-px",children:xe.map((k,j)=>{let se=cn(k),ie=P.has(j),ve=k.extension||wr(k.name);return jsxRuntime.jsxs("div",{className:v("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",ie?"bg-(--fe-accent)/15 text-(--fe-text-strong)":"hover:bg-(--fe-surface-hover) hover:text-(--fe-text-strong)"),style:ie?{boxShadow:"inset 2px 0 0 var(--fe-accent)"}:void 0,onClick:qe=>Ye(j,qe),onDoubleClick:()=>ct(j),children:[jsxRuntime.jsx(se,{className:v("h-4 w-4 shrink-0",k.type==="directory"?"text-(--fe-accent)":"text-(--fe-text-muted)")}),jsxRuntime.jsx("span",{className:"flex-1 truncate text-xs font-medium",children:k.name}),ve&&k.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:ve}),k.size!=null&&jsxRuntime.jsx("span",{className:"shrink-0 font-mono text-[10px] text-(--fe-text-muted)",children:Co(k.size)}),k.modifiedAt&&jsxRuntime.jsx("span",{className:"hidden shrink-0 font-mono text-[10px] text-(--fe-text-muted) lg:inline",children:ln(k.modifiedAt)})]},k.path+j)})}):jsxRuntime.jsx("div",{className:"grid grid-cols-[repeat(auto-fill,minmax(90px,1fr))] gap-1.5 p-1",children:xe.map((k,j)=>{let se=cn(k),ie=P.has(j),ve=k.extension||wr(k.name);return jsxRuntime.jsxs("div",{className:v("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",ie?"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:qe=>Ye(j,qe),onDoubleClick:()=>ct(j),children:[jsxRuntime.jsx(se,{className:v("h-7 w-7",k.type==="directory"?"text-(--fe-accent)":"text-(--fe-text-muted)")}),jsxRuntime.jsx("span",{className:"w-full truncate text-[10px] font-medium leading-tight",children:k.name}),ve&&k.type==="file"&&jsxRuntime.jsx("span",{className:"font-mono text-[8px] uppercase text-(--fe-text-muted)",children:ve})]},k.path+j)})})}),jsxRuntime.jsx("div",{className:v("overflow-hidden transition-[width,opacity] duration-300 ease-out",_t?v("absolute right-0 top-0 bottom-0 z-10",re?"w-44 opacity-100":"w-0 opacity-0 pointer-events-none"):v("shrink-0",re?"w-56":"w-0")),children:re&&jsxRuntime.jsxs("div",{className:v("flex h-full flex-col p-4",_t?"fe-panel-narrow w-44":"fe-panel w-56 border-l border-(--fe-border)"),children:[_t&&jsxRuntime.jsx("button",{className:"fe-btn mb-2 self-end",onClick:()=>{R(null),L(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:[Yr__default.default.createElement(cn(re),{className:v("h-10 w-10 mb-2",re.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:re.name})]}),jsxRuntime.jsxs("div",{className:"space-y-2.5 text-[10px]",children:[jsxRuntime.jsx(Wt,{label:"Type",value:re.type==="directory"?"Directory":re.mimeType||re.extension||wr(re.name)||"File"}),re.size!=null&&jsxRuntime.jsx(Wt,{label:"Size",value:Co(re.size)}),jsxRuntime.jsx(Wt,{label:"Path",value:re.path,mono:true}),re.extension&&jsxRuntime.jsx(Wt,{label:"Extension",value:re.extension}),re.modifiedAt&&jsxRuntime.jsx(Wt,{label:"Modified",value:ln(re.modifiedAt)}),re.createdAt&&jsxRuntime.jsx(Wt,{label:"Created",value:ln(re.createdAt)})]}),jsxRuntime.jsxs("div",{className:"mt-auto flex flex-col gap-1.5",children:[re.type==="file"&&d&&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:()=>d(re),children:[jsxRuntime.jsx(lucideReact.ArrowUp,{className:"h-3 w-3 rotate-45"}),"Open"]}),b?.map(k=>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:()=>k.onClick(re),children:[k.icon&&Yr__default.default.createElement(k.icon,{className:"h-3 w-3"}),k.label]},k.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:[xe.length," items"]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-2",children:[P.size>0&&jsxRuntime.jsxs("span",{className:"text-(--fe-accent)/70",children:[P.size," selected"]}),jsxRuntime.jsx("span",{className:"opacity-50",children:"Ctrl+Click multi-select \xB7 Esc clear"})]})]}),w&&!y&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"absolute top-0 left-4 right-4 h-3 cursor-ns-resize",onMouseDown:k=>Ae("n",k),onTouchStart:k=>_e("n",k)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 left-4 right-4 h-3 cursor-ns-resize",onMouseDown:k=>Ae("s",k),onTouchStart:k=>_e("s",k)}),jsxRuntime.jsx("div",{className:"absolute top-4 left-0 bottom-4 w-3 cursor-ew-resize",onMouseDown:k=>Ae("w",k),onTouchStart:k=>_e("w",k)}),jsxRuntime.jsx("div",{className:"absolute top-4 right-0 bottom-4 w-3 cursor-ew-resize",onMouseDown:k=>Ae("e",k),onTouchStart:k=>_e("e",k)}),jsxRuntime.jsx("div",{className:"absolute top-0 left-0 h-6 w-6 cursor-nwse-resize",onMouseDown:k=>Ae("nw",k),onTouchStart:k=>_e("nw",k)}),jsxRuntime.jsx("div",{className:"absolute top-0 right-0 h-6 w-6 cursor-nesw-resize",onMouseDown:k=>Ae("ne",k),onTouchStart:k=>_e("ne",k)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 left-0 h-6 w-6 cursor-nesw-resize",onMouseDown:k=>Ae("sw",k),onTouchStart:k=>_e("sw",k)}),jsxRuntime.jsx("div",{className:"absolute bottom-0 right-0 h-6 w-6 cursor-nwse-resize",onMouseDown:k=>Ae("se",k),onTouchStart:k=>_e("se",k)})]}),jsxRuntime.jsx("style",{children:`
|
|
23
23
|
.fe-window {
|
|
24
24
|
background: var(--fe-bg);
|
|
25
25
|
box-shadow: var(--fe-shadow);
|
|
@@ -80,4 +80,48 @@
|
|
|
80
80
|
from { opacity: 0; transform: translateX(-4px); }
|
|
81
81
|
to { opacity: 1; transform: translateX(0); }
|
|
82
82
|
}
|
|
83
|
-
`}),jsxRuntime.jsx(cr,{open:pe,onOpenChange:He,children:jsxRuntime.jsxs(dr,{size:"sm",children:[jsxRuntime.jsxs(ur,{children:[jsxRuntime.jsxs(mr,{children:[jsxRuntime.jsx(lucideReact.AlertTriangle,{className:"text-danger-500"}),"Confirm Deletion"]}),jsxRuntime.jsxs(pr,{children:[b.size===1?`Are you sure you want to delete "${ee[Array.from(b)[0]]?.name}"?`:`Are you sure you want to delete ${b.size} selected items?`," ","This action cannot be undone."]})]}),jsxRuntime.jsxs(fr,{children:[jsxRuntime.jsx(Ft,{intent:"ghost",onClick:()=>He(false),children:"Cancel"}),jsxRuntime.jsxs(Ft,{intent:"danger",onClick:()=>{let r=Array.from(b).map(k=>ee[k]).filter(Boolean);l?.(r),M(new Set),R(null),He(false);},children:[jsxRuntime.jsx(lucideReact.Trash2,{className:"h-4 w-4"}),"Delete"]})]})]})})]})}function lt({label:e,value:t,mono:n}){return jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"mb-0.5 font-semibold uppercase tracking-wider text-(--fe-text-muted)",children:e}),jsxRuntime.jsx("div",{className:o("text-(--fe-text) break-all leading-snug",n&&"font-mono text-[9px]"),children:t})]})}function ma(e,t){let n=t.getBoundingClientRect(),u=Math.max(n.width,n.height)*1.2,f=e.clientX-n.left,c=e.clientY-n.top,d=document.createElement("span");d.className="masonry-ripple",d.style.width=`${u}px`,d.style.height=`${u}px`,d.style.left=`${f}px`,d.style.top=`${c}px`,t.appendChild(d),d.addEventListener("animationend",()=>d.remove());}function Yt({columns:e,columnWidth:t=240,gap:n=16,items:u,onItemClick:f,className:c,style:d,children:v,...y}){let h=br.useRef(null),L=br.useRef([]),[w,l]=br.useState(()=>e??1),[m,P]=br.useState([]),[N,H]=br.useState(0),E=u?u.map((b,M)=>({key:b.key??M,node:b.content})):br__default.default.Children.toArray(v).map((b,M)=>({key:b.key??M,node:b})),z=E.length,V=br.useCallback(b=>e??Math.max(1,Math.floor((b+n)/(t+n))),[e,t,n]),O=br.useCallback(()=>{let b=h.current;if(!b)return;let M=b.clientWidth,_=V(M);l(_);let R=(M-(_-1)*n)/_,s=new Array(_).fill(0),A=[];for(let ne=0;ne<z;ne++){let q=L.current[ne],ve=q?q.offsetHeight:0,X=0;for(let ye=1;ye<_;ye++)s[ye]<s[X]&&(X=ye);A.push({top:s[X],left:X*(R+n),width:R}),s[X]+=ve+n;}let Y=Math.max(0,...s)-(z?n:0);P(A),H(Y);},[z,V,n]);br.useEffect(()=>{let b=h.current;if(!b)return;let M=new ResizeObserver(()=>O());return M.observe(b),()=>M.disconnect()},[O]),br.useEffect(()=>{let b=requestAnimationFrame(O);return ()=>cancelAnimationFrame(b)},[O]),br.useEffect(()=>{let b=new ResizeObserver(()=>O());return L.current.forEach(M=>{M&&b.observe(M);}),()=>b.disconnect()},[z,w,O]);let $=br.useCallback((b,M)=>{let _=b.currentTarget;ma(b,_),f?.(u?.[M],M);},[f,u]),me=b=>{if(!u)return false;let M=u[b];return !!(M.title||M.description||M.actions)};return jsxRuntime.jsx("div",{ref:h,className:o("relative",c),style:{...d,height:N},...y,children:E.map((b,M)=>jsxRuntime.jsxs("div",{ref:_=>{L.current[M]=_;},className:"masonry-item",role:"button",tabIndex:0,onClick:_=>$(_,M),onKeyDown:_=>{(_.key==="Enter"||_.key===" ")&&(_.preventDefault(),f?.(u?.[M],M));},style:{position:"absolute",top:m[M]?.top??0,left:m[M]?.left??0,width:m[M]?.width??"100%"},children:[b.node,me(M)&&jsxRuntime.jsxs("div",{className:"masonry-item-overlay",children:[u[M].title&&jsxRuntime.jsx("p",{className:"masonry-item-overlay-title",children:u[M].title}),u[M].description&&jsxRuntime.jsx("p",{className:"masonry-item-overlay-desc",children:u[M].description}),u[M].actions&&jsxRuntime.jsx("div",{className:"masonry-item-overlay-actions",children:u[M].actions})]})]},b.key))})}function wt({text:e="",mode:t="typewriter",speed:n=40,cursor:u=true,cursorChar:f="\u258B",thinking:c=false,streaming:d=false,delay:v=0,onComplete:y,as:h="span",className:L}){let[w,l]=br.useState(t==="instant"?e:""),[m,P]=br.useState(false),[N,H]=br.useState(t==="instant"),[E,z]=br.useState(false),V=br.useRef(0),O=br.useRef(y);O.current=y;let $=br.useRef(e);$.current=e,br.useEffect(()=>{if(t!=="typewriter")return;if(l(""),H(false),z(false),P(false),!e){H(true);return}let R=Math.max(10,1e3/n),s=0,A,Y=()=>{P(true),A=setInterval(()=>{let q=$.current;s++,l(q.slice(0,s)),s>=q.length&&(clearInterval(A),P(false),H(true),O.current?.());},R);},ne;return v>0?ne=setTimeout(Y,v):Y(),()=>{clearTimeout(ne),clearInterval(A);}},[e,t]),br.useEffect(()=>{if(t!=="stream")return;if(e.length===0){V.current=0,l(""),P(false),H(false),z(false);return}if(e.length<=V.current)return;let R=Math.max(10,1e3/n),s=V.current;P(true),H(false),z(false);let A=setInterval(()=>{s++,V.current=s,l($.current.slice(0,s)),s>=$.current.length&&(clearInterval(A),P(false),O.current?.());},R);return ()=>clearInterval(A)},[e,t]),br.useEffect(()=>{t==="instant"&&(l(e),P(false),H(true));},[e,t]);let me=br.useRef(d);br.useEffect(()=>{let R=me.current;if(me.current=d,R&&!d&&!m&&t==="stream"){z(true);let s=setTimeout(()=>{z(false),H(true);},650);return ()=>clearTimeout(s)}},[d,m,t]);let b=u&&(c||m||E||t==="stream"&&d&&!N||t==="typewriter"&&!N),M=c?"tw-cursor--blink":m?"tw-cursor--solid":E?"tw-cursor--out":"tw-cursor--blink";return jsxRuntime.jsxs(h,{className:o(L),children:[c&&!w&&jsxRuntime.jsx("span",{"aria-hidden":"true",children:"\u200B"}),w,b&&jsxRuntime.jsx("span",{className:o("tw-cursor",M),"aria-hidden":"true",children:f})]})}function kt(e){return e.toLowerCase().replace(/\s+/g," ").trim()}function fa(e,t){if(!t)return true;let n=kt(t);return kt(e.label).includes(n)||(e.description?kt(e.description).includes(n):false)||(e.keywords?e.keywords.some(u=>kt(u).includes(n)):false)}function ga(e){let t=new Map;for(let n of e){let u=n.group??"";t.has(u)||t.set(u,[]),t.get(u).push(n);}return Array.from(t.entries()).map(([n,u])=>({label:n,items:u}))}function Lr(e,t,n,u){let[f,c]=br.useState(""),[d,v]=br.useState(0);br.useEffect(()=>{t&&(c(""),v(0));},[t]);let y=br.useMemo(()=>e.filter(l=>!l.disabled&&fa(l,f)),[e,f]),h=br.useMemo(()=>ga(y),[y]);br.useEffect(()=>{v(l=>Math.min(l,Math.max(0,y.length-1)));},[y.length]);let L=br.useCallback(()=>{let l=y[d];l&&(l.onSelect(),n(false));},[y,d,n]),w=br.useCallback(l=>{switch(l.key){case "ArrowDown":l.preventDefault(),v(m=>(m+1)%Math.max(1,y.length));break;case "ArrowUp":l.preventDefault(),v(m=>(m-1+Math.max(1,y.length))%Math.max(1,y.length));break;case "Enter":l.preventDefault(),L();break;case "Escape":l.preventDefault(),n(false);break}},[y.length,L,n]);return br.useEffect(()=>{if(!u)return;function l(m){(m.metaKey||m.ctrlKey)&&m.key==="k"&&(m.preventDefault(),n(!t));}return window.addEventListener("keydown",l),()=>window.removeEventListener("keydown",l)},[u,t,n]),{query:f,setQuery:c,groups:h,filtered:y,activeIndex:d,setActiveIndex:v,handleKeyDown:w}}function Nt({open:e,onOpenChange:t,commands:n,placeholder:u="Type a command or search\u2026",hotkey:f=true,maxItems:c=8,className:d}){let v=br.useRef(null),y=br.useRef(null),{query:h,setQuery:L,groups:w,filtered:l,activeIndex:m,setActiveIndex:P,handleKeyDown:N}=Lr(n,e,t,f);if(br.useEffect(()=>{if(e){let E=setTimeout(()=>v.current?.focus(),40);return ()=>clearTimeout(E)}},[e]),br.useEffect(()=>{y.current?.querySelector("[data-active='true']")?.scrollIntoView({block:"nearest"});},[m]),!e)return null;let H=0;return reactDom.createPortal(jsxRuntime.jsx("div",{className:"cmd-backdrop fixed inset-0 z-50 flex items-start justify-center pt-[15vh]",onClick:()=>t(false),role:"presentation",children:jsxRuntime.jsxs("div",{className:o("cmd-panel relative flex w-full max-w-lg flex-col overflow-hidden rounded-xl","border border-primary-200 bg-white shadow-2xl","dark:border-primary-700 dark:bg-primary-900",d),onClick:E=>E.stopPropagation(),onKeyDown:N,role:"dialog","aria-label":"Command palette","aria-modal":"true",children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-3 border-b border-primary-100 px-4 dark:border-primary-700",children:[jsxRuntime.jsx(lucideReact.Search,{className:"h-4 w-4 shrink-0 text-secondary-400","aria-hidden":"true"}),jsxRuntime.jsx("input",{ref:v,value:h,onChange:E=>L(E.target.value),placeholder:u,className:"flex-1 bg-transparent py-3.5 text-sm text-primary-900 outline-none placeholder:text-secondary-400 dark:text-primary-50","aria-label":"Search commands","aria-controls":"cmd-results","aria-autocomplete":"list","aria-activedescendant":l[m]?`cmd-item-${l[m].id}`:void 0,spellCheck:false,autoComplete:"off"}),jsxRuntime.jsx("kbd",{className:"hidden shrink-0 rounded border border-primary-200 px-1.5 py-0.5 text-xs text-secondary-400 dark:border-primary-600 sm:block",children:"esc"})]}),jsxRuntime.jsx("div",{id:"cmd-results",ref:y,className:"overflow-y-auto py-2",style:{maxHeight:`${c*2.75}rem`},role:"listbox","aria-label":"Commands",children:l.length===0?jsxRuntime.jsxs("div",{className:"flex flex-col items-center gap-2 py-8 text-sm text-secondary-400",children:[jsxRuntime.jsx(lucideReact.Command,{className:"h-8 w-8 opacity-30"}),jsxRuntime.jsx("span",{children:"No commands found"})]}):w.map(E=>jsxRuntime.jsxs("div",{className:"mb-1 last:mb-0",children:[E.label&&jsxRuntime.jsx("p",{className:"px-4 pb-1 pt-2 text-xs font-semibold uppercase tracking-wide text-secondary-400 dark:text-secondary-500",children:E.label}),E.items.map(z=>{let V=H++,O=V===m;return jsxRuntime.jsxs("button",{id:`cmd-item-${z.id}`,"data-active":O,role:"option","aria-selected":O,className:o("cmd-item group flex w-full items-center gap-3 px-4 py-2.5 text-left text-sm",O?"bg-primary-100 text-primary-900 dark:bg-primary-800 dark:text-primary-50":"text-primary-700 hover:bg-primary-50 dark:text-primary-300 dark:hover:bg-primary-800/50"),onMouseEnter:()=>P(V),onClick:()=>{z.onSelect(),t(false);},children:[z.icon&&jsxRuntime.jsx("span",{className:o("flex h-7 w-7 shrink-0 items-center justify-center rounded-md border text-xs",O?"border-primary-300 bg-white text-primary-700 dark:border-primary-600 dark:bg-primary-700 dark:text-primary-200":"border-primary-200 bg-primary-50 text-primary-500 dark:border-primary-700 dark:bg-primary-800 dark:text-primary-400"),children:z.icon}),jsxRuntime.jsxs("span",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("span",{className:"block truncate font-medium",children:z.label}),z.description&&jsxRuntime.jsx("span",{className:"block truncate text-xs text-secondary-400 dark:text-secondary-500",children:z.description})]}),z.shortcut&&jsxRuntime.jsx("span",{className:"flex shrink-0 items-center gap-0.5",children:z.shortcut.map(($,me)=>jsxRuntime.jsx("kbd",{className:"rounded border border-primary-200 px-1.5 py-0.5 text-xs text-secondary-500 dark:border-primary-700 dark:text-secondary-400",children:$},me))})]},z.id)})]},E.label||"_default"))}),l.length>0&&jsxRuntime.jsxs("div",{className:"flex items-center justify-between border-t border-primary-100 px-4 py-2 dark:border-primary-700",children:[jsxRuntime.jsxs("span",{className:"text-xs text-secondary-400",children:[l.length," result",l.length!==1?"s":""]}),jsxRuntime.jsxs("span",{className:"flex items-center gap-3 text-xs text-secondary-400",children:[jsxRuntime.jsxs("span",{className:"flex items-center gap-1",children:[jsxRuntime.jsx("kbd",{className:"rounded border border-primary-200 px-1 dark:border-primary-700",children:"\u2191"}),jsxRuntime.jsx("kbd",{className:"rounded border border-primary-200 px-1 dark:border-primary-700",children:"\u2193"}),"Navigate"]}),jsxRuntime.jsxs("span",{className:"flex items-center gap-1",children:[jsxRuntime.jsx("kbd",{className:"rounded border border-primary-200 px-1 dark:border-primary-700",children:"\u21B5"}),"Select"]})]})]})]})}),document.body)}var Ar={complete:"bg-success-500 border-success-500 text-white dark:bg-success-600 dark:border-success-600",active:"bg-primary-500 border-primary-500 text-white dark:bg-primary-400 dark:border-primary-400",error:"bg-danger-500 border-danger-500 text-white dark:bg-danger-600 dark:border-danger-600",pending:"bg-white border-primary-300 text-secondary-400 dark:bg-primary-800 dark:border-primary-600"},Ir={complete:"shadow-[0_0_0_4px_theme(colors.success.100)] dark:shadow-[0_0_0_4px_theme(colors.success.900/30)]",active:"shadow-[0_0_0_4px_theme(colors.primary.100)] dark:shadow-[0_0_0_4px_theme(colors.primary.800/50)] animate-pulse",error:"shadow-[0_0_0_4px_theme(colors.danger.100)] dark:shadow-[0_0_0_4px_theme(colors.danger.900/30)]",pending:""};function Fr({status:e,icon:t}){return t?jsxRuntime.jsx(jsxRuntime.Fragment,{children:t}):e==="complete"?jsxRuntime.jsx(lucideReact.Check,{className:"h-3 w-3"}):e==="error"?jsxRuntime.jsx(lucideReact.AlertCircle,{className:"h-3 w-3"}):e==="active"?jsxRuntime.jsx(lucideReact.Dot,{className:"h-4 w-4"}):jsxRuntime.jsx(lucideReact.Clock,{className:"h-3 w-3"})}function Hr({images:e,title:t}){let n=e.slice(0,4),u=e.length>4?e.length-4:0,f=(c,d,v)=>jsxRuntime.jsxs("a",{href:c,target:"_blank",rel:"noopener noreferrer",className:o("relative block overflow-hidden",v),onClick:y=>y.stopPropagation(),children:[jsxRuntime.jsx("img",{src:c,alt:`${t} ${d+1}`,className:"h-full w-full object-cover transition-transform duration-300 hover:scale-105"}),d===n.length-1&&u>0&&jsxRuntime.jsx("div",{className:"absolute inset-0 flex items-center justify-center bg-black/60",children:jsxRuntime.jsxs("span",{className:"text-sm font-semibold text-white",children:["+",u]})})]},d);return n.length===0?null:n.length===1?jsxRuntime.jsx("div",{className:"mt-2.5 h-36 overflow-hidden rounded-xl",children:f(n[0],0,"h-full")}):n.length===2?jsxRuntime.jsx("div",{className:"mt-2.5 grid h-28 grid-cols-2 gap-0.5 overflow-hidden rounded-xl",children:n.map((c,d)=>f(c,d))}):n.length===3?jsxRuntime.jsxs("div",{className:"mt-2.5 grid h-36 grid-cols-2 grid-rows-2 gap-0.5 overflow-hidden rounded-xl",children:[f(n[0],0,"row-span-2"),f(n[1],1),f(n[2],2)]}):jsxRuntime.jsx("div",{className:"mt-2.5 grid h-44 grid-cols-2 grid-rows-2 gap-0.5 overflow-hidden rounded-xl",children:n.map((c,d)=>f(c,d))})}function Vr({actions:e}){let t=e.filter(d=>d.variant!=="primary"),n=e.filter(d=>d.variant==="primary"),u="inline-flex items-center gap-1.5 rounded-lg px-2.5 py-1 text-xs font-medium text-secondary-500 transition-colors hover:bg-secondary-100/80 hover:text-secondary-700 dark:text-secondary-400 dark:hover:bg-primary-800/60 dark:hover:text-secondary-200",f="inline-flex items-center gap-1.5 rounded-lg border border-primary-200/70 bg-primary-50/80 px-3 py-1 text-xs font-semibold text-primary-700 transition-colors hover:bg-primary-100 dark:border-primary-600/60 dark:bg-primary-800/60 dark:text-primary-300 dark:hover:bg-primary-700/60",c=(d,v,y)=>d.href?jsxRuntime.jsxs("a",{href:d.href,target:"_blank",rel:"noopener noreferrer",className:y,onClick:h=>h.stopPropagation(),children:[d.icon,d.label]},v):jsxRuntime.jsxs("button",{type:"button",onClick:d.onClick,className:y,children:[d.icon,d.label]},v);return jsxRuntime.jsxs("div",{className:"mt-3 flex items-center gap-1 border-t border-primary-100/50 pt-2.5 dark:border-primary-700/40",children:[t.map((d,v)=>c(d,v,u)),n.length>0&&jsxRuntime.jsx("span",{className:"flex-1"}),n.map((d,v)=>c(d,v,f))]})}function Or({item:e,isActive:t,animated:n,visible:u,orientation:f}){let c=e.status??"pending",d={complete:"bg-gradient-to-br from-white to-success-50/40 dark:from-primary-900 dark:to-success-900/10",active:"bg-gradient-to-br from-white to-primary-50/60 dark:from-primary-900 dark:to-primary-800/40",error:"bg-gradient-to-br from-white to-danger-50/40 dark:from-primary-900 dark:to-danger-900/10",pending:"bg-white dark:bg-primary-900"}[c],v={complete:"border-success-200/70 dark:border-success-800/50",active:"border-primary-300/80 dark:border-primary-600/70",error:"border-danger-200/70 dark:border-danger-800/50",pending:"border-primary-200/60 dark:border-primary-700/50"}[c],y=t?"shadow-lg shadow-primary-300/30 dark:shadow-primary-500/20":c==="complete"?"shadow-md shadow-success-300/20 dark:shadow-success-400/10":c==="error"?"shadow-md shadow-danger-300/20 dark:shadow-danger-400/10":"shadow-sm shadow-primary-100/50 dark:shadow-black/20",h=c==="complete"?"conic-gradient(from 30deg, transparent 0%, var(--tl-glow-complete-1) 18%, var(--tl-glow-complete-2) 30%, var(--tl-holo-cyan) 44%, transparent 60%)":c==="error"?"conic-gradient(from 150deg, transparent 0%, var(--tl-glow-error-1) 18%, var(--tl-glow-error-2) 32%, var(--tl-glow-error-3) 44%, transparent 58%)":null,L={complete:"bg-success-100 text-success-700 dark:bg-success-900/40 dark:text-success-300",active:"bg-primary-100 text-primary-700 dark:bg-primary-800/60 dark:text-primary-300",error:"bg-danger-100 text-danger-700 dark:bg-danger-900/40 dark:text-danger-300",pending:"bg-secondary-100 text-secondary-600 dark:bg-primary-800/50 dark:text-secondary-400"}[c];return jsxRuntime.jsxs("div",{className:o("relative isolate",n&&"transition-all duration-700",n?u?"opacity-100 translate-y-0":f==="vertical"?"opacity-0 translate-y-6":"opacity-0 translate-x-6":"",f==="horizontal"?"w-56 shrink-0":"flex-1",e.className),children:[!t&&h&&jsxRuntime.jsx("div",{className:"pointer-events-none absolute animate-[tl-glow-pulse_5s_ease-in-out_infinite]",style:{inset:"-6px",borderRadius:"1.5rem",zIndex:-1,background:h,filter:"blur(14px)",opacity:.22},"aria-hidden":true}),t&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"pointer-events-none absolute",style:{inset:"-7px",borderRadius:"1.5rem",zIndex:-1,background:"conic-gradient(from var(--tl-angle, 0deg) at 50% 50%, var(--tl-holo-base) 0%, var(--tl-holo-indigo) 18%, var(--tl-holo-violet) 30%, var(--tl-holo-cyan) 45%, var(--tl-holo-mid) 62%, var(--tl-holo-base) 100%)",filter:"blur(10px)",animation:"tl-breathe 2.8s ease-in-out infinite, tl-holo-spin 9s linear infinite"},"aria-hidden":true}),jsxRuntime.jsx("div",{className:"pointer-events-none absolute",style:{inset:"-1.5px",borderRadius:"1.0625rem",zIndex:-1,padding:"1.5px",background:"conic-gradient(from var(--tl-angle, 0deg) at 50% 50%, transparent 0deg, var(--tl-holo-indigo) 55deg, var(--tl-holo-violet) 85deg, var(--tl-holo-cyan) 115deg, transparent 175deg, transparent 360deg)",WebkitMask:"linear-gradient(white 0 0) content-box, linear-gradient(white 0 0)",WebkitMaskComposite:"xor",maskComposite:"exclude",animation:"tl-holo-spin 5s linear infinite"},"aria-hidden":true})]}),jsxRuntime.jsx("div",{className:o("relative overflow-hidden rounded-2xl border backdrop-blur-[2px]",t?"border-transparent":o("border",v),d,y),children:e.imagePosition==="left"&&e.image?jsxRuntime.jsxs("div",{className:"flex min-h-[8rem]",children:[jsxRuntime.jsx("a",{href:e.image,target:"_blank",rel:"noopener noreferrer",className:"w-28 shrink-0 overflow-hidden",onClick:l=>l.stopPropagation(),"aria-label":e.title,children:jsxRuntime.jsx("img",{src:e.image,alt:e.title,className:"h-full w-full object-cover transition-transform duration-500 hover:scale-105"})}),jsxRuntime.jsxs("div",{className:"flex flex-1 flex-col p-4",children:[e.date&&jsxRuntime.jsx("span",{className:o("mb-2 inline-flex items-center gap-1 rounded-md px-2 py-0.5 text-[0.65rem] font-semibold tracking-wide",L),children:e.date}),jsxRuntime.jsx("h3",{className:o("text-sm font-semibold leading-snug",t?"text-primary-900 dark:text-white":"text-primary-800 dark:text-primary-100"),children:e.title}),e.description&&jsxRuntime.jsx("p",{className:"mt-1 text-xs leading-relaxed text-secondary-500 dark:text-secondary-400",children:e.description}),e.images&&e.images.length>0&&jsxRuntime.jsx(Hr,{images:e.images,title:e.title}),e.actions&&e.actions.length>0&&jsxRuntime.jsx(Vr,{actions:e.actions})]})]}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[e.image&&jsxRuntime.jsx("div",{className:"overflow-hidden",children:jsxRuntime.jsx("img",{src:e.image,alt:e.title,className:"h-32 w-full object-cover transition-transform duration-500 hover:scale-105"})}),e.svg&&!e.image&&jsxRuntime.jsx("div",{className:"flex items-center justify-center bg-primary-50/60 p-4 dark:bg-primary-800/40",children:e.svg}),jsxRuntime.jsxs("div",{className:o("p-4",(e.image||e.svg)&&"pt-3"),children:[e.date&&jsxRuntime.jsx("span",{className:o("mb-2.5 inline-flex items-center gap-1 rounded-md px-2 py-0.5 text-[0.65rem] font-semibold tracking-wide",L),children:e.date}),jsxRuntime.jsx("h3",{className:o("text-sm font-semibold leading-snug",t?"text-primary-900 dark:text-white":"text-primary-800 dark:text-primary-100"),children:e.title}),e.description&&jsxRuntime.jsx("p",{className:"mt-1 text-xs leading-relaxed text-secondary-500 dark:text-secondary-400",children:e.description}),e.images&&e.images.length>0&&jsxRuntime.jsx(Hr,{images:e.images,title:e.title}),e.actions&&e.actions.length>0&&jsxRuntime.jsx(Vr,{actions:e.actions})]})]})})]})}function qt({items:e,orientation:t="vertical",activeIndex:n,animated:u=true,lineStyle:f="solid",className:c}){let d=br.useRef(null),v=br.useRef([]),[y,h]=br.useState(new Set);br.useEffect(()=>{if(!u){h(new Set(e.map((l,m)=>m)));return}let w=new IntersectionObserver(l=>{h(m=>{let P=new Set(m);return l.forEach(N=>{let H=Number(N.target.dataset.idx);N.isIntersecting&&P.add(H);}),P});},{threshold:.15});return v.current.forEach(l=>l&&w.observe(l)),()=>w.disconnect()},[e,u]),br.useEffect(()=>{if(n==null)return;let w=v.current[n];w&&w.scrollIntoView({behavior:"smooth",block:"center",inline:"center"});},[n]);let L=f==="dashed"?"border-dashed":"";return t==="vertical"?jsxRuntime.jsxs("div",{ref:d,className:o("relative",c),children:[jsxRuntime.jsx("div",{className:"absolute left-5 top-0 h-full w-px bg-primary-200 dark:bg-primary-700"}),jsxRuntime.jsx("div",{className:"space-y-6",children:e.map((w,l)=>{let m=w.status??"pending",P=l===n;return jsxRuntime.jsxs("div",{ref:N=>{v.current[l]=N;},"data-idx":l,className:"relative flex gap-4",children:[jsxRuntime.jsx("div",{className:"relative z-10 flex shrink-0 flex-col items-center",children:jsxRuntime.jsx("div",{className:o("flex h-10 w-10 items-center justify-center rounded-full border-2 transition-all duration-300 [&_svg]:shrink-0",Ar[m],P&&Ir[m]),children:jsxRuntime.jsx(Fr,{status:m,icon:w.icon})})}),jsxRuntime.jsx(Or,{item:w,isActive:P,animated:u,visible:y.has(l),orientation:"vertical"})]},w.id??l)})})]}):jsxRuntime.jsx("div",{ref:d,className:o("relative overflow-x-auto pb-4",c),children:jsxRuntime.jsx("div",{className:"flex min-w-max gap-6 px-4",children:e.map((w,l)=>{let m=w.status??"pending",P=l===n,N=l===e.length-1;return jsxRuntime.jsxs("div",{ref:H=>{v.current[l]=H;},"data-idx":l,className:"relative flex flex-col items-center gap-3",children:[jsxRuntime.jsxs("div",{className:"flex items-center",children:[jsxRuntime.jsx("div",{className:o("flex h-10 w-10 items-center justify-center rounded-full border-2 transition-all duration-300 z-10 [&_svg]:shrink-0",Ar[m],P&&Ir[m]),children:jsxRuntime.jsx(Fr,{status:m,icon:w.icon})}),!N&&jsxRuntime.jsx("div",{className:o("h-px w-28 border-t-2",L,m==="complete"?"border-success-400":"border-primary-200 dark:border-primary-700")})]}),jsxRuntime.jsx(Or,{item:w,isActive:P,animated:u,visible:y.has(l),orientation:"horizontal"})]},w.id??l)})})})}var Ca={FilmReel:Pt,MiniPlayer:Rt,CinePlayer:zt,FileExplorer:Bt,Masonry:Yt,TypewriterText:wt,CommandPalette:Nt,Timeline:qt},Ss=Ca;exports.CinePlayer=zt;exports.CommandPalette=Nt;exports.Extras=Ca;exports.FileExplorer=Bt;exports.FilmReel=Pt;exports.Masonry=Yt;exports.MiniPlayer=Rt;exports.Timeline=qt;exports.TypewriterText=wt;exports.default=Ss;
|
|
83
|
+
`}),jsxRuntime.jsx(lo,{open:ne,onOpenChange:Te,children:jsxRuntime.jsxs(co,{size:"sm",children:[jsxRuntime.jsxs(uo,{children:[jsxRuntime.jsxs(po,{children:[jsxRuntime.jsx(lucideReact.AlertTriangle,{className:"text-danger-500"}),"Confirm Deletion"]}),jsxRuntime.jsxs(mo,{children:[P.size===1?`Are you sure you want to delete "${xe[Array.from(P)[0]]?.name}"?`:`Are you sure you want to delete ${P.size} selected items?`," ","This action cannot be undone."]})]}),jsxRuntime.jsxs(fo,{children:[jsxRuntime.jsx(Pt,{intent:"ghost",onClick:()=>Te(false),children:"Cancel"}),jsxRuntime.jsxs(Pt,{intent:"danger",onClick:()=>{let k=Array.from(P).map(j=>xe[j]).filter(Boolean);p?.(k),L(new Set),R(null),Te(false);},children:[jsxRuntime.jsx(lucideReact.Trash2,{className:"h-4 w-4"}),"Delete"]})]})]})})]})}function Wt({label:e,value:t,mono:r}){return jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"mb-0.5 font-semibold uppercase tracking-wider text-(--fe-text-muted)",children:e}),jsxRuntime.jsx("div",{className:v("text-(--fe-text) break-all leading-snug",r&&"font-mono text-[9px]"),children:t})]})}function Li(e,t){let r=t.getBoundingClientRect(),n=Math.max(r.width,r.height)*1.2,o=e.clientX-r.left,a=e.clientY-r.top,s=document.createElement("span");s.className="masonry-ripple",s.style.width=`${n}px`,s.style.height=`${n}px`,s.style.left=`${o}px`,s.style.top=`${a}px`,t.appendChild(s),s.addEventListener("animationend",()=>s.remove());}function fn({columns:e,columnWidth:t=240,gap:r=16,items:n,onItemClick:o,className:a,style:s,children:l,...i}){let d=Yr.useRef(null),m=Yr.useRef([]),[u,p]=Yr.useState(()=>e??1),[c,h]=Yr.useState([]),[f,g]=Yr.useState(0),b=n?n.map((P,L)=>({key:P.key??L,node:P.content})):Yr__default.default.Children.toArray(l).map((P,L)=>({key:P.key??L,node:P})),w=b.length,C=Yr.useCallback(P=>e??Math.max(1,Math.floor((P+r)/(t+r))),[e,t,r]),x=Yr.useCallback(()=>{let P=d.current;if(!P)return;let L=P.clientWidth,H=C(L);p(H);let R=(L-(H-1)*r)/H,y=new Array(H).fill(0),_=[];for(let z=0;z<w;z++){let Y=m.current[z],ge=Y?Y.offsetHeight:0,E=0;for(let ye=1;ye<H;ye++)y[ye]<y[E]&&(E=ye);_.push({top:y[E],left:E*(R+r),width:R}),y[E]+=ge+r;}let X=Math.max(0,...y)-(w?r:0);h(_),g(X);},[w,C,r]);Yr.useEffect(()=>{let P=d.current;if(!P)return;let L=new ResizeObserver(()=>x());return L.observe(P),()=>L.disconnect()},[x]),Yr.useEffect(()=>{let P=requestAnimationFrame(x);return ()=>cancelAnimationFrame(P)},[x]),Yr.useEffect(()=>{let P=new ResizeObserver(()=>x());return m.current.forEach(L=>{L&&P.observe(L);}),()=>P.disconnect()},[w,u,x]);let M=Yr.useCallback((P,L)=>{let H=P.currentTarget;Li(P,H),o?.(n?.[L],L);},[o,n]),F=P=>{if(!n)return false;let L=n[P];return !!(L.title||L.description||L.actions)};return jsxRuntime.jsx("div",{ref:d,className:v("relative",a),style:{...s,height:f},...i,children:b.map((P,L)=>jsxRuntime.jsxs("div",{ref:H=>{m.current[L]=H;},className:"masonry-item",role:"button",tabIndex:0,onClick:H=>M(H,L),onKeyDown:H=>{(H.key==="Enter"||H.key===" ")&&(H.preventDefault(),o?.(n?.[L],L));},style:{position:"absolute",top:c[L]?.top??0,left:c[L]?.left??0,width:c[L]?.width??"100%"},children:[P.node,F(L)&&jsxRuntime.jsxs("div",{className:"masonry-item-overlay",children:[n[L].title&&jsxRuntime.jsx("p",{className:"masonry-item-overlay-title",children:n[L].title}),n[L].description&&jsxRuntime.jsx("p",{className:"masonry-item-overlay-desc",children:n[L].description}),n[L].actions&&jsxRuntime.jsx("div",{className:"masonry-item-overlay-actions",children:n[L].actions})]})]},P.key))})}function Sr({text:e="",mode:t="typewriter",speed:r=40,cursor:n=true,cursorChar:o="\u258B",thinking:a=false,streaming:s=false,delay:l=0,onComplete:i,as:d="span",className:m}){let[u,p]=Yr.useState(t==="instant"?e:""),[c,h]=Yr.useState(false),[f,g]=Yr.useState(t==="instant"),[b,w]=Yr.useState(false),C=Yr.useRef(0),x=Yr.useRef(i);x.current=i;let M=Yr.useRef(e);M.current=e,Yr.useEffect(()=>{if(t!=="typewriter")return;if(p(""),g(false),w(false),h(false),!e){g(true);return}let R=Math.max(10,1e3/r),y=0,_,X=()=>{h(true),_=setInterval(()=>{let Y=M.current;y++,p(Y.slice(0,y)),y>=Y.length&&(clearInterval(_),h(false),g(true),x.current?.());},R);},z;return l>0?z=setTimeout(X,l):X(),()=>{clearTimeout(z),clearInterval(_);}},[e,t]),Yr.useEffect(()=>{if(t!=="stream")return;if(e.length===0){C.current=0,p(""),h(false),g(false),w(false);return}if(e.length<=C.current)return;let R=Math.max(10,1e3/r),y=C.current;h(true),g(false),w(false);let _=setInterval(()=>{y++,C.current=y,p(M.current.slice(0,y)),y>=M.current.length&&(clearInterval(_),h(false),x.current?.());},R);return ()=>clearInterval(_)},[e,t]),Yr.useEffect(()=>{t==="instant"&&(p(e),h(false),g(true));},[e,t]);let F=Yr.useRef(s);Yr.useEffect(()=>{let R=F.current;if(F.current=s,R&&!s&&!c&&t==="stream"){w(true);let y=setTimeout(()=>{w(false),g(true);},650);return ()=>clearTimeout(y)}},[s,c,t]);let P=n&&(a||c||b||t==="stream"&&s&&!f||t==="typewriter"&&!f),L=a?"tw-cursor--blink":c?"tw-cursor--solid":b?"tw-cursor--out":"tw-cursor--blink";return jsxRuntime.jsxs(d,{className:v(m),children:[a&&!u&&jsxRuntime.jsx("span",{"aria-hidden":"true",children:"\u200B"}),u,P&&jsxRuntime.jsx("span",{className:v("tw-cursor",L),"aria-hidden":"true",children:o})]})}function Tr(e){return e.toLowerCase().replace(/\s+/g," ").trim()}function _i(e,t){if(!t)return true;let r=Tr(t);return Tr(e.label).includes(r)||(e.description?Tr(e.description).includes(r):false)||(e.keywords?e.keywords.some(n=>Tr(n).includes(r)):false)}function Hi(e){let t=new Map;for(let r of e){let n=r.group??"";t.has(n)||t.set(n,[]),t.get(n).push(r);}return Array.from(t.entries()).map(([r,n])=>({label:r,items:n}))}function Io(e,t,r,n){let[o,a]=Yr.useState(""),[s,l]=Yr.useState(0);Yr.useEffect(()=>{t&&(a(""),l(0));},[t]);let i=Yr.useMemo(()=>e.filter(p=>!p.disabled&&_i(p,o)),[e,o]),d=Yr.useMemo(()=>Hi(i),[i]);Yr.useEffect(()=>{l(p=>Math.min(p,Math.max(0,i.length-1)));},[i.length]);let m=Yr.useCallback(()=>{let p=i[s];p&&(p.onSelect(),r(false));},[i,s,r]),u=Yr.useCallback(p=>{switch(p.key){case "ArrowDown":p.preventDefault(),l(c=>(c+1)%Math.max(1,i.length));break;case "ArrowUp":p.preventDefault(),l(c=>(c-1+Math.max(1,i.length))%Math.max(1,i.length));break;case "Enter":p.preventDefault(),m();break;case "Escape":p.preventDefault(),r(false);break}},[i.length,m,r]);return Yr.useEffect(()=>{if(!n)return;function p(c){(c.metaKey||c.ctrlKey)&&c.key==="k"&&(c.preventDefault(),r(!t));}return window.addEventListener("keydown",p),()=>window.removeEventListener("keydown",p)},[n,t,r]),{query:o,setQuery:a,groups:d,filtered:i,activeIndex:s,setActiveIndex:l,handleKeyDown:u}}function Er({open:e,onOpenChange:t,commands:r,placeholder:n="Type a command or search\u2026",hotkey:o=true,maxItems:a=8,className:s}){let l=Yr.useRef(null),i=Yr.useRef(null),{query:d,setQuery:m,groups:u,filtered:p,activeIndex:c,setActiveIndex:h,handleKeyDown:f}=Io(r,e,t,o);if(Yr.useEffect(()=>{if(e){let b=setTimeout(()=>l.current?.focus(),40);return ()=>clearTimeout(b)}},[e]),Yr.useEffect(()=>{i.current?.querySelector("[data-active='true']")?.scrollIntoView({block:"nearest"});},[c]),!e)return null;let g=0;return reactDom.createPortal(jsxRuntime.jsx("div",{className:"cmd-backdrop fixed inset-0 z-50 flex items-start justify-center pt-[15vh]",onClick:()=>t(false),role:"presentation",children:jsxRuntime.jsxs("div",{className:v("cmd-panel relative flex w-full max-w-lg flex-col overflow-hidden rounded-xl","border border-primary-200 bg-white shadow-2xl","dark:border-primary-700 dark:bg-primary-900",s),onClick:b=>b.stopPropagation(),onKeyDown:f,role:"dialog","aria-label":"Command palette","aria-modal":"true",children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-3 border-b border-primary-100 px-4 dark:border-primary-700",children:[jsxRuntime.jsx(lucideReact.Search,{className:"h-4 w-4 shrink-0 text-secondary-400","aria-hidden":"true"}),jsxRuntime.jsx("input",{ref:l,value:d,onChange:b=>m(b.target.value),placeholder:n,className:"flex-1 bg-transparent py-3.5 text-sm text-primary-900 outline-none placeholder:text-secondary-400 dark:text-primary-50","aria-label":"Search commands","aria-controls":"cmd-results","aria-autocomplete":"list","aria-activedescendant":p[c]?`cmd-item-${p[c].id}`:void 0,spellCheck:false,autoComplete:"off"}),jsxRuntime.jsx("kbd",{className:"hidden shrink-0 rounded border border-primary-200 px-1.5 py-0.5 text-xs text-secondary-400 dark:border-primary-600 sm:block",children:"esc"})]}),jsxRuntime.jsx("div",{id:"cmd-results",ref:i,className:"overflow-y-auto py-2",style:{maxHeight:`${a*2.75}rem`},role:"listbox","aria-label":"Commands",children:p.length===0?jsxRuntime.jsxs("div",{className:"flex flex-col items-center gap-2 py-8 text-sm text-secondary-400",children:[jsxRuntime.jsx(lucideReact.Command,{className:"h-8 w-8 opacity-30"}),jsxRuntime.jsx("span",{children:"No commands found"})]}):u.map(b=>jsxRuntime.jsxs("div",{className:"mb-1 last:mb-0",children:[b.label&&jsxRuntime.jsx("p",{className:"px-4 pb-1 pt-2 text-xs font-semibold uppercase tracking-wide text-secondary-400 dark:text-secondary-500",children:b.label}),b.items.map(w=>{let C=g++,x=C===c;return jsxRuntime.jsxs("button",{id:`cmd-item-${w.id}`,"data-active":x,role:"option","aria-selected":x,className:v("cmd-item group flex w-full items-center gap-3 px-4 py-2.5 text-left text-sm",x?"bg-primary-100 text-primary-900 dark:bg-primary-800 dark:text-primary-50":"text-primary-700 hover:bg-primary-50 dark:text-primary-300 dark:hover:bg-primary-800/50"),onMouseEnter:()=>h(C),onClick:()=>{w.onSelect(),t(false);},children:[w.icon&&jsxRuntime.jsx("span",{className:v("flex h-7 w-7 shrink-0 items-center justify-center rounded-md border text-xs",x?"border-primary-300 bg-white text-primary-700 dark:border-primary-600 dark:bg-primary-700 dark:text-primary-200":"border-primary-200 bg-primary-50 text-primary-500 dark:border-primary-700 dark:bg-primary-800 dark:text-primary-400"),children:w.icon}),jsxRuntime.jsxs("span",{className:"min-w-0 flex-1",children:[jsxRuntime.jsx("span",{className:"block truncate font-medium",children:w.label}),w.description&&jsxRuntime.jsx("span",{className:"block truncate text-xs text-secondary-400 dark:text-secondary-500",children:w.description})]}),w.shortcut&&jsxRuntime.jsx("span",{className:"flex shrink-0 items-center gap-0.5",children:w.shortcut.map((M,F)=>jsxRuntime.jsx("kbd",{className:"rounded border border-primary-200 px-1.5 py-0.5 text-xs text-secondary-500 dark:border-primary-700 dark:text-secondary-400",children:M},F))})]},w.id)})]},b.label||"_default"))}),p.length>0&&jsxRuntime.jsxs("div",{className:"flex items-center justify-between border-t border-primary-100 px-4 py-2 dark:border-primary-700",children:[jsxRuntime.jsxs("span",{className:"text-xs text-secondary-400",children:[p.length," result",p.length!==1?"s":""]}),jsxRuntime.jsxs("span",{className:"flex items-center gap-3 text-xs text-secondary-400",children:[jsxRuntime.jsxs("span",{className:"flex items-center gap-1",children:[jsxRuntime.jsx("kbd",{className:"rounded border border-primary-200 px-1 dark:border-primary-700",children:"\u2191"}),jsxRuntime.jsx("kbd",{className:"rounded border border-primary-200 px-1 dark:border-primary-700",children:"\u2193"}),"Navigate"]}),jsxRuntime.jsxs("span",{className:"flex items-center gap-1",children:[jsxRuntime.jsx("kbd",{className:"rounded border border-primary-200 px-1 dark:border-primary-700",children:"\u21B5"}),"Select"]})]})]})]})}),document.body)}var $o={complete:"bg-success-500 border-success-500 text-white dark:bg-success-600 dark:border-success-600",active:"bg-primary-500 border-primary-500 text-white dark:bg-primary-400 dark:border-primary-400",error:"bg-danger-500 border-danger-500 text-white dark:bg-danger-600 dark:border-danger-600",pending:"bg-white border-primary-300 text-secondary-400 dark:bg-primary-800 dark:border-primary-600"},Bo={complete:"shadow-[0_0_0_4px_theme(colors.success.100)] dark:shadow-[0_0_0_4px_theme(colors.success.900/30)]",active:"shadow-[0_0_0_4px_theme(colors.primary.100)] dark:shadow-[0_0_0_4px_theme(colors.primary.800/50)] animate-pulse",error:"shadow-[0_0_0_4px_theme(colors.danger.100)] dark:shadow-[0_0_0_4px_theme(colors.danger.900/30)]",pending:""};function Vo({status:e,icon:t}){return t?jsxRuntime.jsx(jsxRuntime.Fragment,{children:t}):e==="complete"?jsxRuntime.jsx(lucideReact.Check,{className:"h-3 w-3"}):e==="error"?jsxRuntime.jsx(lucideReact.AlertCircle,{className:"h-3 w-3"}):e==="active"?jsxRuntime.jsx(lucideReact.Dot,{className:"h-4 w-4"}):jsxRuntime.jsx(lucideReact.Clock,{className:"h-3 w-3"})}function jo({images:e,title:t}){let r=e.slice(0,4),n=e.length>4?e.length-4:0,o=(a,s,l)=>jsxRuntime.jsxs("a",{href:a,target:"_blank",rel:"noopener noreferrer",className:v("relative block overflow-hidden",l),onClick:i=>i.stopPropagation(),children:[jsxRuntime.jsx("img",{src:a,alt:`${t} ${s+1}`,className:"h-full w-full object-cover transition-transform duration-300 hover:scale-105"}),s===r.length-1&&n>0&&jsxRuntime.jsx("div",{className:"absolute inset-0 flex items-center justify-center bg-black/60",children:jsxRuntime.jsxs("span",{className:"text-sm font-semibold text-white",children:["+",n]})})]},s);return r.length===0?null:r.length===1?jsxRuntime.jsx("div",{className:"mt-2.5 h-36 overflow-hidden rounded-xl",children:o(r[0],0,"h-full")}):r.length===2?jsxRuntime.jsx("div",{className:"mt-2.5 grid h-28 grid-cols-2 gap-0.5 overflow-hidden rounded-xl",children:r.map((a,s)=>o(a,s))}):r.length===3?jsxRuntime.jsxs("div",{className:"mt-2.5 grid h-36 grid-cols-2 grid-rows-2 gap-0.5 overflow-hidden rounded-xl",children:[o(r[0],0,"row-span-2"),o(r[1],1),o(r[2],2)]}):jsxRuntime.jsx("div",{className:"mt-2.5 grid h-44 grid-cols-2 grid-rows-2 gap-0.5 overflow-hidden rounded-xl",children:r.map((a,s)=>o(a,s))})}function Uo({actions:e}){let t=e.filter(s=>s.variant!=="primary"),r=e.filter(s=>s.variant==="primary"),n="inline-flex items-center gap-1.5 rounded-lg px-2.5 py-1 text-xs font-medium text-secondary-500 transition-colors hover:bg-secondary-100/80 hover:text-secondary-700 dark:text-secondary-400 dark:hover:bg-primary-800/60 dark:hover:text-secondary-200",o="inline-flex items-center gap-1.5 rounded-lg border border-primary-200/70 bg-primary-50/80 px-3 py-1 text-xs font-semibold text-primary-700 transition-colors hover:bg-primary-100 dark:border-primary-600/60 dark:bg-primary-800/60 dark:text-primary-300 dark:hover:bg-primary-700/60",a=(s,l,i)=>s.href?jsxRuntime.jsxs("a",{href:s.href,target:"_blank",rel:"noopener noreferrer",className:i,onClick:d=>d.stopPropagation(),children:[s.icon,s.label]},l):jsxRuntime.jsxs("button",{type:"button",onClick:s.onClick,className:i,children:[s.icon,s.label]},l);return jsxRuntime.jsxs("div",{className:"mt-3 flex items-center gap-1 border-t border-primary-100/50 pt-2.5 dark:border-primary-700/40",children:[t.map((s,l)=>a(s,l,n)),r.length>0&&jsxRuntime.jsx("span",{className:"flex-1"}),r.map((s,l)=>a(s,l,o))]})}function Ko({item:e,isActive:t,animated:r,visible:n,orientation:o}){let a=e.status??"pending",s={complete:"bg-gradient-to-br from-white to-success-50/40 dark:from-primary-900 dark:to-success-900/10",active:"bg-gradient-to-br from-white to-primary-50/60 dark:from-primary-900 dark:to-primary-800/40",error:"bg-gradient-to-br from-white to-danger-50/40 dark:from-primary-900 dark:to-danger-900/10",pending:"bg-white dark:bg-primary-900"}[a],l={complete:"border-success-200/70 dark:border-success-800/50",active:"border-primary-300/80 dark:border-primary-600/70",error:"border-danger-200/70 dark:border-danger-800/50",pending:"border-primary-200/60 dark:border-primary-700/50"}[a],i=t?"shadow-lg shadow-primary-300/30 dark:shadow-primary-500/20":a==="complete"?"shadow-md shadow-success-300/20 dark:shadow-success-400/10":a==="error"?"shadow-md shadow-danger-300/20 dark:shadow-danger-400/10":"shadow-sm shadow-primary-100/50 dark:shadow-black/20",d=a==="complete"?"conic-gradient(from 30deg, transparent 0%, var(--tl-glow-complete-1) 18%, var(--tl-glow-complete-2) 30%, var(--tl-holo-cyan) 44%, transparent 60%)":a==="error"?"conic-gradient(from 150deg, transparent 0%, var(--tl-glow-error-1) 18%, var(--tl-glow-error-2) 32%, var(--tl-glow-error-3) 44%, transparent 58%)":null,m={complete:"bg-success-100 text-success-700 dark:bg-success-900/40 dark:text-success-300",active:"bg-primary-100 text-primary-700 dark:bg-primary-800/60 dark:text-primary-300",error:"bg-danger-100 text-danger-700 dark:bg-danger-900/40 dark:text-danger-300",pending:"bg-secondary-100 text-secondary-600 dark:bg-primary-800/50 dark:text-secondary-400"}[a];return jsxRuntime.jsxs("div",{className:v("relative isolate",r&&"transition-all duration-700",r?n?"opacity-100 translate-y-0":o==="vertical"?"opacity-0 translate-y-6":"opacity-0 translate-x-6":"",o==="horizontal"?"w-56 shrink-0":"flex-1",e.className),children:[!t&&d&&jsxRuntime.jsx("div",{className:"pointer-events-none absolute animate-[tl-glow-pulse_5s_ease-in-out_infinite]",style:{inset:"-6px",borderRadius:"1.5rem",zIndex:-1,background:d,filter:"blur(14px)",opacity:.22},"aria-hidden":true}),t&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"pointer-events-none absolute",style:{inset:"-7px",borderRadius:"1.5rem",zIndex:-1,background:"conic-gradient(from var(--tl-angle, 0deg) at 50% 50%, var(--tl-holo-base) 0%, var(--tl-holo-indigo) 18%, var(--tl-holo-violet) 30%, var(--tl-holo-cyan) 45%, var(--tl-holo-mid) 62%, var(--tl-holo-base) 100%)",filter:"blur(10px)",animation:"tl-breathe 2.8s ease-in-out infinite, tl-holo-spin 9s linear infinite"},"aria-hidden":true}),jsxRuntime.jsx("div",{className:"pointer-events-none absolute",style:{inset:"-1.5px",borderRadius:"1.0625rem",zIndex:-1,padding:"1.5px",background:"conic-gradient(from var(--tl-angle, 0deg) at 50% 50%, transparent 0deg, var(--tl-holo-indigo) 55deg, var(--tl-holo-violet) 85deg, var(--tl-holo-cyan) 115deg, transparent 175deg, transparent 360deg)",WebkitMask:"linear-gradient(white 0 0) content-box, linear-gradient(white 0 0)",WebkitMaskComposite:"xor",maskComposite:"exclude",animation:"tl-holo-spin 5s linear infinite"},"aria-hidden":true})]}),jsxRuntime.jsx("div",{className:v("relative overflow-hidden rounded-2xl border backdrop-blur-[2px]",t?"border-transparent":v("border",l),s,i),children:e.imagePosition==="left"&&e.image?jsxRuntime.jsxs("div",{className:"flex min-h-[8rem]",children:[jsxRuntime.jsx("a",{href:e.image,target:"_blank",rel:"noopener noreferrer",className:"w-28 shrink-0 overflow-hidden",onClick:p=>p.stopPropagation(),"aria-label":e.title,children:jsxRuntime.jsx("img",{src:e.image,alt:e.title,className:"h-full w-full object-cover transition-transform duration-500 hover:scale-105"})}),jsxRuntime.jsxs("div",{className:"flex flex-1 flex-col p-4",children:[e.date&&jsxRuntime.jsx("span",{className:v("mb-2 inline-flex items-center gap-1 rounded-md px-2 py-0.5 text-[0.65rem] font-semibold tracking-wide",m),children:e.date}),jsxRuntime.jsx("h3",{className:v("text-sm font-semibold leading-snug",t?"text-primary-900 dark:text-white":"text-primary-800 dark:text-primary-100"),children:e.title}),e.description&&jsxRuntime.jsx("p",{className:"mt-1 text-xs leading-relaxed text-secondary-500 dark:text-secondary-400",children:e.description}),e.images&&e.images.length>0&&jsxRuntime.jsx(jo,{images:e.images,title:e.title}),e.actions&&e.actions.length>0&&jsxRuntime.jsx(Uo,{actions:e.actions})]})]}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[e.image&&jsxRuntime.jsx("div",{className:"overflow-hidden",children:jsxRuntime.jsx("img",{src:e.image,alt:e.title,className:"h-32 w-full object-cover transition-transform duration-500 hover:scale-105"})}),e.svg&&!e.image&&jsxRuntime.jsx("div",{className:"flex items-center justify-center bg-primary-50/60 p-4 dark:bg-primary-800/40",children:e.svg}),jsxRuntime.jsxs("div",{className:v("p-4",(e.image||e.svg)&&"pt-3"),children:[e.date&&jsxRuntime.jsx("span",{className:v("mb-2.5 inline-flex items-center gap-1 rounded-md px-2 py-0.5 text-[0.65rem] font-semibold tracking-wide",m),children:e.date}),jsxRuntime.jsx("h3",{className:v("text-sm font-semibold leading-snug",t?"text-primary-900 dark:text-white":"text-primary-800 dark:text-primary-100"),children:e.title}),e.description&&jsxRuntime.jsx("p",{className:"mt-1 text-xs leading-relaxed text-secondary-500 dark:text-secondary-400",children:e.description}),e.images&&e.images.length>0&&jsxRuntime.jsx(jo,{images:e.images,title:e.title}),e.actions&&e.actions.length>0&&jsxRuntime.jsx(Uo,{actions:e.actions})]})]})})]})}function bn({items:e,orientation:t="vertical",activeIndex:r,animated:n=true,lineStyle:o="solid",className:a}){let s=Yr.useRef(null),l=Yr.useRef([]),[i,d]=Yr.useState(new Set);Yr.useEffect(()=>{if(!n){d(new Set(e.map((p,c)=>c)));return}let u=new IntersectionObserver(p=>{d(c=>{let h=new Set(c);return p.forEach(f=>{let g=Number(f.target.dataset.idx);f.isIntersecting&&h.add(g);}),h});},{threshold:.15});return l.current.forEach(p=>p&&u.observe(p)),()=>u.disconnect()},[e,n]),Yr.useEffect(()=>{if(r==null)return;let u=l.current[r];u&&u.scrollIntoView({behavior:"smooth",block:"center",inline:"center"});},[r]);let m=o==="dashed"?"border-dashed":"";return t==="vertical"?jsxRuntime.jsxs("div",{ref:s,className:v("relative",a),children:[jsxRuntime.jsx("div",{className:"absolute left-5 top-0 h-full w-px bg-primary-200 dark:bg-primary-700"}),jsxRuntime.jsx("div",{className:"space-y-6",children:e.map((u,p)=>{let c=u.status??"pending",h=p===r;return jsxRuntime.jsxs("div",{ref:f=>{l.current[p]=f;},"data-idx":p,className:"relative flex gap-4",children:[jsxRuntime.jsx("div",{className:"relative z-10 flex shrink-0 flex-col items-center",children:jsxRuntime.jsx("div",{className:v("flex h-10 w-10 items-center justify-center rounded-full border-2 transition-all duration-300 [&_svg]:shrink-0",$o[c],h&&Bo[c]),children:jsxRuntime.jsx(Vo,{status:c,icon:u.icon})})}),jsxRuntime.jsx(Ko,{item:u,isActive:h,animated:n,visible:i.has(p),orientation:"vertical"})]},u.id??p)})})]}):jsxRuntime.jsx("div",{ref:s,className:v("relative overflow-x-auto pb-4",a),children:jsxRuntime.jsx("div",{className:"flex min-w-max gap-6 px-4",children:e.map((u,p)=>{let c=u.status??"pending",h=p===r,f=p===e.length-1;return jsxRuntime.jsxs("div",{ref:g=>{l.current[p]=g;},"data-idx":p,className:"relative flex flex-col items-center gap-3",children:[jsxRuntime.jsxs("div",{className:"flex items-center",children:[jsxRuntime.jsx("div",{className:v("flex h-10 w-10 items-center justify-center rounded-full border-2 transition-all duration-300 z-10 [&_svg]:shrink-0",$o[c],h&&Bo[c]),children:jsxRuntime.jsx(Vo,{status:c,icon:u.icon})}),!f&&jsxRuntime.jsx("div",{className:v("h-px w-28 border-t-2",m,c==="complete"?"border-success-400":"border-primary-200 dark:border-primary-700")})]}),jsxRuntime.jsx(Ko,{item:u,isActive:h,animated:n,visible:i.has(p),orientation:"horizontal"})]},u.id??p)})})})}function rr(e="en-US",t="long"){return Array.from({length:12},(r,n)=>new Intl.DateTimeFormat(e,{month:t}).format(new Date(2e3,n,1)))}function Wo(e="en-US",t="narrow"){let r=new Date(2e3,0,2);return Array.from({length:7},(n,o)=>{let a=new Date(r);return a.setDate(r.getDate()+o),new Intl.DateTimeFormat(e,{weekday:t}).format(a)})}function Yo(e,t=true,r=true){return e==="date"?"YYYY-MM-DD":e==="time"?t?r?"HH:mm:ss":"HH:mm":r?"hh:mm:ss A":"hh:mm A":t?r?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD HH:mm":r?"YYYY-MM-DD hh:mm:ss A":"YYYY-MM-DD hh:mm A"}function Wi(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function qo(e,t,r="en-US"){let n=e.getHours(),o=rr(r,"long"),a=rr(r,"short"),s={YYYY:String(e.getFullYear()),YY:String(e.getFullYear()).slice(-2),MMMM:o[e.getMonth()],MMM:a[e.getMonth()],MM:String(e.getMonth()+1).padStart(2,"0"),M:String(e.getMonth()+1),DD:String(e.getDate()).padStart(2,"0"),D:String(e.getDate()),HH:String(n).padStart(2,"0"),H:String(n),hh:String(n%12||12).padStart(2,"0"),h:String(n%12||12),mm:String(e.getMinutes()).padStart(2,"0"),ss:String(e.getSeconds()).padStart(2,"0"),A:n<12?"AM":"PM",a:n<12?"am":"pm"},l=Object.keys(s).sort((d,m)=>m.length-d.length),i=new RegExp(l.map(Wi).join("|"),"g");return t.replace(i,d=>s[d]??d)}function Yt(e,t){return new Date(e,t+1,0).getDate()}function Xo(e,t){let r=new Date(e,t,1).getDay(),n=Yt(e,t),o=Yt(e,t-1),a=[];for(let l=r-1;l>=0;l--)a.push({date:new Date(e,t-1,o-l),thisMonth:false});for(let l=1;l<=n;l++)a.push({date:new Date(e,t,l),thisMonth:true});let s=42-a.length;for(let l=1;l<=s;l++)a.push({date:new Date(e,t+1,l),thisMonth:false});return a}function qt(e){return new Date(e.getFullYear(),e.getMonth(),e.getDate())}function vn(e,t){return qt(e).getTime()===qt(t).getTime()}function Go(e,t){return qt(e)<qt(t)}function Jo(e,t){return qt(e)>qt(t)}function Pr(e,t,r){return t&&e<t?new Date(t):r&&e>r?new Date(r):e}function Qo(e,t,r,n){let o=new Date(e),s=t*(n==="future"?1:-1);switch(r){case "day":o.setDate(o.getDate()+s);break;case "week":o.setDate(o.getDate()+s*7);break;case "month":o.setMonth(o.getMonth()+s);break;case "year":o.setFullYear(o.getFullYear()+s);break}return o}function Zo(e,t=200){let r=e-Math.floor(t/2);return Array.from({length:t},(n,o)=>r+o)}function ea(e){let{value:t,defaultValue:r,onChange:n,mode:o="datetime",minDate:a,maxDate:s,use24Hour:l=true,showSeconds:i=true,locale:d="en-US",format:m,onOpen:u,onClose:p}=e,c=t!==void 0,[h,f]=Yr.useState(r??null),g=c?t??null:h,[b,w]=Yr.useState(false),[C,x]=Yr.useState(()=>g??new Date),[M,F]=Yr.useState("drum"),[P,L]=Yr.useState(()=>(g??new Date).getFullYear()),[H,R]=Yr.useState(()=>(g??new Date).getMonth()),[y,_]=Yr.useState(1),[X,z]=Yr.useState("day"),[Y,ge]=Yr.useState("future"),E=m??Yo(o,l,i),ye=g?qo(g,E,d):"",fe=Yr.useCallback(()=>{let O=g??new Date;x(new Date(O)),L(O.getFullYear()),R(O.getMonth()),F("drum"),w(true),u?.();},[g,u]),Ne=Yr.useCallback(()=>{w(false),p?.();},[p]),ne=Yr.useCallback(()=>{let O=Pr(C,a,s);c||f(O),n?.(O),Ne();},[C,a,s,c,n,Ne]),Te=Yr.useCallback(()=>{c||f(null),n?.(null),Ne();},[c,n,Ne]),K=Yr.useCallback((O,ae)=>{x(le=>{let te=new Date(le);switch(O){case "year":te.setFullYear(ae);break;case "month":{te.setMonth(ae);let be=Yt(te.getFullYear(),ae);te.getDate()>be&&te.setDate(be);break}case "day":te.setDate(ae);break;case "hour":te.setHours(ae);break;case "minute":te.setMinutes(ae);break;case "second":te.setSeconds(ae);break}return Pr(te,a,s)});},[a,s]),Ee=Yr.useCallback(()=>{let O=Pr(Qo(new Date,y,X,Y),a,s);x(O),L(O.getFullYear()),R(O.getMonth());},[y,X,Y,a,s]),We=Yr.useCallback(O=>{let ae=H+O,le=P;ae<0&&(ae=11,le--),ae>11&&(ae=0,le++),R(ae),L(le);},[H,P]);return {isOpen:b,displayValue:ye,workingDate:C,view:M,calYear:P,calMonth:H,offsetAmount:y,offsetUnit:X,offsetDirection:Y,mode:o,use24Hour:l,showSeconds:i,locale:d,minDate:a,maxDate:s,openPicker:fe,closePicker:Ne,confirm:ne,clear:Te,updateField:K,setView:F,setCalYear:L,setCalMonth:R,setOffsetAmount:_,setOffsetUnit:z,setOffsetDirection:ge,applyQuickOffset:Ee,navigateCalendar:We}}var or=40;function na(e,t,r=true){let n=Yr.useRef(t);n.current=t,Yr.useEffect(()=>{if(!r)return;function o(a){let s=a.target;e.some(i=>i.current?.contains(s))||n.current();}return document.addEventListener("mousedown",o),()=>document.removeEventListener("mousedown",o)},[e,r]);}function oa(e,t,r){let n=Yr.useRef(false),o=Yr.useRef(void 0),a=Yr.useRef(r);a.current=r;let s=Yr.useRef(t);s.current=t;let l=Yr.useCallback((d,m="smooth")=>{let u=e.current;if(!u)return;let p=d*or;Math.abs(u.scrollTop-p)<2&&m!=="instant"||(m==="instant"?u.scrollTop=p:u.scrollTo({top:p,behavior:m}));},[e]),i=Yr.useCallback(()=>{e.current&&(n.current=true,clearTimeout(o.current),o.current=setTimeout(()=>{n.current=false;let m=e.current;if(!m)return;let u=Math.round(m.scrollTop/or),p=Math.max(0,Math.min(s.current-1,u)),c=p*or;Math.abs(m.scrollTop-c)>1&&m.scrollTo({top:c,behavior:"smooth"}),a.current(p);},120));},[e]);return {scrollToIndex:l,handleScroll:i,isScrollingRef:n}}function aa(e,t,r){Yr.useEffect(()=>{if(!r)return;function n(){let a=e.current,s=t.current;if(!a||!s)return;if(window.innerWidth<=640){s.style.top="",s.style.left="";return}let l=a.getBoundingClientRect(),i=window.innerHeight,d=window.innerWidth,m=s.offsetHeight||460,u=s.offsetWidth||340,p=l.bottom+8,c=l.left;p+m>i-16&&(p=Math.max(16,l.top-m-8)),c+u>d-16&&(c=Math.max(16,d-u-16)),c<16&&(c=16),s.style.top=`${Math.round(p)}px`,s.style.left=`${Math.round(c)}px`;}let o=setTimeout(n,0);return window.addEventListener("resize",n),window.addEventListener("scroll",n,true),()=>{clearTimeout(o),window.removeEventListener("resize",n),window.removeEventListener("scroll",n,true);}},[r,e,t]);}function Mt({items:e,selectedValue:t,onSelect:r,label:n}){let o=Yr.useRef(null),a=Yr.useRef(t),s=Yr.useRef(false),{scrollToIndex:l,handleScroll:i}=oa(o,e.length,d=>{let m=e[d];m&&(s.current=true,r(m.value),setTimeout(()=>{s.current=false;},200));});return Yr.useEffect(()=>{let d=o.current;if(!d)return;let m=e.findIndex(u=>u.value===t);m>=0&&(d.scrollTop=m*or);},[]),Yr.useEffect(()=>{if(a.current!==t&&(a.current=t,!s.current)){let d=e.findIndex(m=>m.value===t);d>=0&&l(d,"smooth");}},[t,e,l]),jsxRuntime.jsxs("div",{className:"dtp-column",role:"group","aria-label":n,children:[jsxRuntime.jsx("div",{className:"dtp-column-highlight","aria-hidden":"true"}),jsxRuntime.jsx("div",{ref:o,className:"dtp-column-list",onScroll:i,role:"listbox","aria-label":n,children:e.map(d=>jsxRuntime.jsx("div",{className:v("dtp-item",d.value===t&&"dtp-item--selected"),onClick:()=>{let m=e.findIndex(u=>u.value===d.value);m>=0&&l(m,"smooth"),r(d.value);},role:"option","aria-selected":d.value===t,children:d.label},d.value))}),jsxRuntime.jsx("div",{className:"dtp-fade-top","aria-hidden":"true"}),jsxRuntime.jsx("div",{className:"dtp-fade-bottom","aria-hidden":"true"})]})}function Qi({year:e,month:t,selectedDate:r,today:n,minDate:o,maxDate:a,locale:s,onSelectDay:l,onPrev:i,onNext:d}){let m=Wo(s,"narrow"),u=rr(s,"long"),p=Xo(e,t);return jsxRuntime.jsxs("div",{className:"dtp-calendar",children:[jsxRuntime.jsxs("div",{className:"dtp-cal-nav",children:[jsxRuntime.jsx("button",{type:"button",className:"dtp-cal-nav-btn",onClick:i,"aria-label":"Previous month",children:jsxRuntime.jsx(lucideReact.ChevronLeft,{className:"h-4 w-4"})}),jsxRuntime.jsxs("span",{className:"dtp-cal-title",children:[u[t]," ",e]}),jsxRuntime.jsx("button",{type:"button",className:"dtp-cal-nav-btn",onClick:d,"aria-label":"Next month",children:jsxRuntime.jsx(lucideReact.ChevronRight,{className:"h-4 w-4"})})]}),jsxRuntime.jsx("div",{className:"dtp-cal-weekdays",role:"row",children:m.map((c,h)=>jsxRuntime.jsx("div",{className:"dtp-cal-weekday",role:"columnheader","aria-label":c,children:c},h))}),jsxRuntime.jsx("div",{className:"dtp-cal-days",role:"grid",children:p.map(({date:c,thisMonth:h},f)=>{let g=vn(c,r),b=vn(c,n),w=o!=null&&Go(c,o)||a!=null&&Jo(c,a);return jsxRuntime.jsx("button",{type:"button",role:"gridcell",className:v("dtp-cal-day",!h&&"dtp-cal-day--other",g&&"dtp-cal-day--selected",b&&!g&&"dtp-cal-day--today",w&&"dtp-cal-day--disabled"),onClick:()=>!w&&l(c),disabled:w,"aria-current":b?"date":void 0,"aria-selected":g,"aria-disabled":w,children:c.getDate()},f)})})]})}function Zi({amount:e,unit:t,direction:r,onAmountChange:n,onUnitChange:o,onDirectionChange:a,onApply:s,locale:l}){let i=l.startsWith("zh"),d=[{value:"day",label:i?"\u5929":"Day"},{value:"week",label:i?"\u5468":"Week"},{value:"month",label:i?"\u6708":"Month"},{value:"year",label:i?"\u5E74":"Year"}],m=[{value:"future",label:i?"\u4EE5\u540E":"from now"},{value:"past",label:i?"\u4EE5\u524D":"before now"}];return jsxRuntime.jsxs("div",{className:"dtp-quick-offset","aria-label":i?"\u5FEB\u901F\u504F\u79FB":"Quick offset",children:[jsxRuntime.jsx("input",{type:"number",className:"dtp-offset-input",value:e,min:1,max:9999,"aria-label":i?"\u504F\u79FB\u6570\u91CF":"Offset amount",onChange:u=>{let p=parseInt(u.target.value,10);!isNaN(p)&&p>=1&&n(p);}}),jsxRuntime.jsx("select",{className:"dtp-offset-select",value:t,"aria-label":i?"\u504F\u79FB\u5355\u4F4D":"Offset unit",onChange:u=>o(u.target.value),children:d.map(u=>jsxRuntime.jsx("option",{value:u.value,children:u.label},u.value))}),jsxRuntime.jsx("select",{className:"dtp-offset-select",value:r,"aria-label":i?"\u504F\u79FB\u65B9\u5411":"Offset direction",onChange:u=>a(u.target.value),children:m.map(u=>jsxRuntime.jsx("option",{value:u.value,children:u.label},u.value))}),jsxRuntime.jsx("button",{type:"button",className:"dtp-offset-apply",onClick:s,children:i?"\u5E94\u7528":"Apply"})]})}function Rr({className:e,popupClassName:t,triggerClassName:r,disabled:n=false,placeholder:o,...a}){let{isOpen:s,displayValue:l,workingDate:i,view:d,calYear:m,calMonth:u,offsetAmount:p,offsetUnit:c,offsetDirection:h,mode:f,use24Hour:g,showSeconds:b,locale:w,minDate:C,maxDate:x,openPicker:M,closePicker:F,confirm:P,clear:L,updateField:H,setView:R,setCalYear:y,setCalMonth:_,setOffsetAmount:X,setOffsetUnit:z,setOffsetDirection:Y,applyQuickOffset:ge,navigateCalendar:E}=ea({...a}),ye=Yr.useRef(null),fe=Yr.useRef(null),Ne=new Date;na([ye,fe],F,s),aa(ye,fe,s);let ne=w.startsWith("zh"),Te={cancel:ne?"\u53D6\u6D88":"Cancel",confirm:ne?"\u786E\u5B9A":"Confirm",calendarView:ne?"\u65E5\u5386":"Calendar",scrollView:ne?"\u6EDA\u8F6E":"Scroll",placeholder:o??(ne?"\u9009\u62E9\u65E5\u671F\u65F6\u95F4":"Select date / time")},K=f==="date"||f==="datetime",Ee=f==="time"||f==="datetime",We=Zo(i.getFullYear(),200).map(G=>({label:String(G),value:G})),O=rr(w,"short").map((G,he)=>({label:G,value:he})),ae=Yt(i.getFullYear(),i.getMonth()),le=Array.from({length:ae},(G,he)=>({label:String(he+1).padStart(2,"0"),value:he+1})),te=Array.from({length:24},(G,he)=>({label:String(he).padStart(2,"0"),value:he})),be=Array.from({length:12},(G,he)=>({label:String(he===0?12:he).padStart(2,"0"),value:he})),Se=[{label:"AM",value:0},{label:"PM",value:1}],De=Array.from({length:60},(G,he)=>({label:String(he).padStart(2,"0"),value:he})),J=i.getHours(),at=J%12,ce=J<12?0:1,Pe=Ee&&!K?lucideReact.Clock:lucideReact.Calendar;return jsxRuntime.jsxs("div",{className:v("dtp-root",e),children:[jsxRuntime.jsxs("div",{className:"dtp-trigger-wrap",children:[jsxRuntime.jsxs("button",{ref:ye,type:"button",className:v("dtp-trigger",l&&"dtp-trigger--has-clear",n&&"dtp-trigger--disabled",r),onClick:()=>!n&&(s?F():M()),disabled:n,"aria-haspopup":"dialog","aria-expanded":s,children:[jsxRuntime.jsx(Pe,{className:"dtp-trigger-icon","aria-hidden":"true"}),jsxRuntime.jsx("span",{className:v("dtp-trigger-text",!l&&"dtp-trigger-placeholder"),children:l||Te.placeholder})]}),l&&jsxRuntime.jsx("button",{type:"button",className:"dtp-trigger-clear","aria-label":ne?"\u6E05\u9664":"Clear value",onClick:()=>!n&&L(),children:jsxRuntime.jsx(lucideReact.X,{className:"h-3.5 w-3.5"})})]}),s&&reactDom.createPortal(jsxRuntime.jsxs("div",{ref:fe,className:v("dtp-panel",t),role:"dialog","aria-modal":"true","aria-label":ne?"\u65E5\u671F\u65F6\u95F4\u9009\u62E9\u5668":"Date time picker",children:[jsxRuntime.jsxs("div",{className:"dtp-panel-header",children:[jsxRuntime.jsx("span",{className:"dtp-panel-preview",children:l||Te.placeholder}),jsxRuntime.jsx("div",{className:"dtp-panel-actions",children:K&&jsxRuntime.jsx("button",{type:"button",className:v("dtp-view-btn",d==="calendar"&&"dtp-view-btn--active"),"aria-pressed":d==="calendar",title:d==="calendar"?Te.scrollView:Te.calendarView,onClick:()=>{d!=="calendar"&&(y(i.getFullYear()),_(i.getMonth())),R(d==="calendar"?"drum":"calendar");},children:jsxRuntime.jsx(lucideReact.Calendar,{className:"h-4 w-4"})})})]}),jsxRuntime.jsx("div",{className:"dtp-panel-body",children:d==="drum"?jsxRuntime.jsxs("div",{className:"dtp-drum",children:[K&&jsxRuntime.jsxs("div",{className:"dtp-drum-date",children:[jsxRuntime.jsx(Mt,{label:ne?"\u5E74":"Year",items:We,selectedValue:i.getFullYear(),onSelect:G=>H("year",G)}),jsxRuntime.jsx(Mt,{label:ne?"\u6708":"Month",items:O,selectedValue:i.getMonth(),onSelect:G=>H("month",G)}),jsxRuntime.jsx(Mt,{label:ne?"\u65E5":"Day",items:le,selectedValue:i.getDate(),onSelect:G=>H("day",G)})]}),K&&Ee&&jsxRuntime.jsx("div",{className:"dtp-drum-sep","aria-hidden":"true"}),Ee&&jsxRuntime.jsxs("div",{className:"dtp-drum-time",children:[g?jsxRuntime.jsx(Mt,{label:ne?"\u65F6":"Hour",items:te,selectedValue:J,onSelect:G=>H("hour",G)}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(Mt,{label:ne?"\u65F6":"Hour",items:be,selectedValue:at,onSelect:G=>{H("hour",ce===1?G+12:G);}}),jsxRuntime.jsx(Mt,{label:"AM/PM",items:Se,selectedValue:ce,onSelect:G=>{H("hour",at+(G===1?12:0));}})]}),jsxRuntime.jsx(Mt,{label:ne?"\u5206":"Min",items:De,selectedValue:i.getMinutes(),onSelect:G=>H("minute",G)}),b&&jsxRuntime.jsx(Mt,{label:ne?"\u79D2":"Sec",items:De,selectedValue:i.getSeconds(),onSelect:G=>H("second",G)})]})]}):jsxRuntime.jsx(Qi,{year:m,month:u,selectedDate:i,today:Ne,minDate:C,maxDate:x,locale:w,onSelectDay:G=>{H("year",G.getFullYear()),H("month",G.getMonth()),H("day",G.getDate()),R("drum");},onPrev:()=>E(-1),onNext:()=>E(1)})}),K&&jsxRuntime.jsx("div",{className:"dtp-panel-offset",children:jsxRuntime.jsx(Zi,{amount:p,unit:c,direction:h,onAmountChange:X,onUnitChange:z,onDirectionChange:Y,onApply:ge,locale:w})}),jsxRuntime.jsxs("div",{className:"dtp-panel-footer",children:[jsxRuntime.jsx("button",{type:"button",className:"dtp-btn-cancel",onClick:F,children:Te.cancel}),jsxRuntime.jsx("button",{type:"button",className:"dtp-btn-confirm",onClick:P,children:Te.confirm})]})]}),document.body)]})}var tl={sm:{wrapper:"h-7 text-xs",prefix:"px-2 text-xs [&_svg]:h-3 [&_svg]:w-3",input:"px-2 text-xs",icon:"px-1.5 [&_svg]:h-3 [&_svg]:w-3"},md:{wrapper:"h-9 text-sm",prefix:"px-3 text-sm [&_svg]:h-4 [&_svg]:w-4",input:"px-3 py-2 text-sm",icon:"px-2 [&_svg]:h-4 [&_svg]:w-4"},lg:{wrapper:"h-11 text-base",prefix:"px-4 text-base [&_svg]:h-5 [&_svg]:w-5",input:"px-4 py-2.5 text-base",icon:"px-2.5 [&_svg]:h-5 [&_svg]:w-5"}},rl={default:"border-secondary-300 focus-within:border-primary-500 focus-within:ring-2 focus-within:ring-primary-500/20 dark:border-secondary-600",error:"border-danger-400 focus-within:border-danger-500 focus-within:ring-2 focus-within:ring-danger-500/20"};function At({state:e="default",inputSize:t="md",className:r,prefix:n,suffix:o,action:a,...s}){if(!n&&!o&&!a)return jsxRuntime.jsx("input",{className:v(go({state:e,size:t}),r),...s});let l=tl[t??"md"],i=rl[e??"default"];return jsxRuntime.jsxs("div",{className:v("flex w-full items-center overflow-hidden rounded-md border bg-white transition-colors dark:bg-secondary-900",l.wrapper,i,r),children:[n&&jsxRuntime.jsx("span",{className:v("flex shrink-0 items-center gap-1.5 self-stretch border-r border-secondary-300 bg-secondary-50 font-medium text-secondary-600 dark:border-secondary-600 dark:bg-secondary-800 dark:text-secondary-300",l.prefix),children:n}),jsxRuntime.jsx("input",{className:v("min-w-0 flex-1 bg-transparent text-secondary-900 placeholder:text-secondary-400 focus:outline-none dark:text-secondary-100 dark:placeholder:text-secondary-600",l.input,n&&"pl-2"),...s}),o&&jsxRuntime.jsx("span",{className:v("flex shrink-0 items-center text-secondary-400 dark:text-secondary-500",l.icon),children:o}),a&&jsxRuntime.jsx("button",{type:"button",onClick:a.onClick,"aria-label":a["aria-label"]??"Action",className:v("flex shrink-0 items-center text-secondary-500 transition-colors hover:text-primary-600 dark:text-secondary-400 dark:hover:text-primary-400",l.icon),children:a.icon})]})}function zt({intent:e,size:t,className:r,...n}){return jsxRuntime.jsx("label",{className:v(bo({intent:e,size:t}),r),...n})}var ll={sm:"h-3 w-3",md:"h-3.5 w-3.5",lg:"h-4 w-4"};function la({checked:e,defaultChecked:t=false,indeterminate:r=false,onCheckedChange:n,intent:o,size:a,label:s,id:l,className:i,disabled:d,...m}){let u=Yr.useId(),p=l??u,c=a??"md",[h,f]=Yr.useState(t),g=e??h,b=Yr.useCallback(C=>{let x=C.target.checked;e===void 0&&f(x),n?.(x);},[e,n]),w=g||r;return jsxRuntime.jsxs("label",{htmlFor:p,className:v("inline-flex cursor-pointer items-center gap-2 select-none",d&&"pointer-events-none opacity-50",i),children:[jsxRuntime.jsx("input",{...m,id:p,type:"checkbox",className:"sr-only",checked:g,disabled:d,onChange:b}),jsxRuntime.jsx("span",{className:v(vo({intent:o,size:a,checked:w?"on":"off"})),children:jsxRuntime.jsx("svg",{viewBox:"0 0 16 16",fill:"none",className:v("text-white transition-all duration-200",ll[c],w?"scale-100 opacity-100":"scale-0 opacity-0"),children:r?jsxRuntime.jsx("line",{x1:"3",y1:"8",x2:"13",y2:"8",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round"}):jsxRuntime.jsx("path",{d:"M3.5 8.5L6.5 11.5L12.5 4.5",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})}),s&&jsxRuntime.jsx("span",{className:"text-sm text-primary-700 dark:text-primary-300",children:s})]})}var ca=classVarianceAuthority.cva("w-full rounded-md font-mono text-center transition-all focus:outline-none focus:ring-2 disabled:pointer-events-none disabled:opacity-50",{variants:{size:{sm:"h-9 w-9 text-sm",md:"h-12 w-12 text-base",lg:"h-14 w-14 text-lg"},variant:{outline:"border border-secondary-300 bg-transparent focus:border-primary-500 focus:ring-primary-500/20 dark:border-secondary-600 dark:bg-transparent dark:focus:border-primary-400",filled:"border border-transparent bg-secondary-100 focus:border-primary-500 focus:ring-primary-500/20 dark:bg-secondary-800 dark:focus:border-primary-400",underline:"rounded-none border-0 border-b-2 border-secondary-300 bg-transparent px-0 focus:border-primary-500 focus:ring-0 dark:border-secondary-600 dark:focus:border-primary-400"},invalid:{true:"border-danger-400 focus:border-danger-500 focus:ring-danger-500/20",false:""}},defaultVariants:{size:"md",variant:"outline",invalid:false}});classVarianceAuthority.cva("w-full",{variants:{intent:{default:"",card:"rounded-(--form-radius) border border-primary-200 bg-white p-6 shadow-sm dark:border-primary-700 dark:bg-primary-900",inset:"rounded-(--form-radius) bg-primary-50 p-6 dark:bg-primary-800/50"},size:{sm:"",md:"",lg:""}},defaultVariants:{intent:"default",size:"md"}});classVarianceAuthority.cva("flex w-full",{variants:{layout:{stacked:"flex-col gap-1.5",inline:"flex-row items-start gap-(--form-item-gap-md)"},size:{sm:"",md:"",lg:""}},defaultVariants:{layout:"stacked",size:"md"}});classVarianceAuthority.cva("mt-1 flex items-center gap-1 text-xs [&_svg]:h-3.5 [&_svg]:w-3.5 [&_svg]:shrink-0",{variants:{status:{error:"text-danger-600 dark:text-danger-400",warning:"text-warning-600 dark:text-warning-400",success:"text-success-600 dark:text-success-400",hint:"text-primary-400 dark:text-primary-500"}},defaultVariants:{status:"hint"}});function yn({length:e=6,value:t,defaultValue:r="",onChange:n,onComplete:o,size:a="md",variant:s="outline",disabled:l=false,readOnly:i=false,autoFocus:d=false,alphanumeric:m=false,mask:u=false,invalid:p=false,className:c}){let h=t!==void 0,[f,g]=Yr.useState(()=>{let R=(r??"").slice(0,e);return Array.from({length:e},(y,_)=>R[_]??"")}),b=h?Array.from({length:e},(R,y)=>(t??"")[y]??""):f,w=Yr.useRef([]),C=Yr.useRef([]);Yr.useEffect(()=>{d&&w.current[0]&&w.current[0].focus();},[d]);let x=Yr.useCallback(R=>{h||g(R);let y=R.join("");n?.(y),R.every(_=>_!=="")&&R.length===e&&o?.(y);},[h,n,o,e]),M=R=>{let y=w.current[R];y&&(y.classList.remove("otp-pop"),clearTimeout(C.current[R]),y.offsetWidth,y.classList.add("otp-pop"),C.current[R]=window.setTimeout(()=>y.classList.remove("otp-pop"),200));},F=Yr.useCallback((R,y)=>{let _=m?/[a-zA-Z0-9]/g:/[0-9]/g,X=y.match(_)??[];if(X.length===0)return;let z=X[X.length-1],Y=[...b];Y[R]=z,x(Y),M(R),R<e-1&&w.current[R+1]?.focus();},[b,e,m,x]),P=Yr.useCallback((R,y)=>{if(y.key==="Backspace"){if(y.preventDefault(),b[R]){let _=[...b];_[R]="",x(_);}else if(R>0){w.current[R-1]?.focus();let _=[...b];_[R-1]="",x(_);}}else if(y.key==="ArrowLeft")y.preventDefault(),R>0&&w.current[R-1]?.focus();else if(y.key==="ArrowRight")y.preventDefault(),R<e-1&&w.current[R+1]?.focus();else if(y.key==="Delete"){y.preventDefault();let _=[...b];_[R]="",x(_);}},[b,e,x]),L=Yr.useCallback((R,y)=>{y.preventDefault();let _=y.clipboardData.getData("text"),X=m?/[a-zA-Z0-9]/g:/[0-9]/g,z=_.match(X)??[],Y=[...b],ge=R;for(let fe=0;fe<z.length&&R+fe<e;fe++)Y[R+fe]=z[fe],ge=R+fe;x(Y);let E=Y.findIndex((fe,Ne)=>Ne>ge&&fe===""),ye=E!==-1?E:Math.min(ge+1,e-1);w.current[ye]?.focus();},[b,e,m,x]),H=Yr.useCallback(R=>{R.target.select();},[]);return jsxRuntime.jsx("div",{role:"group","aria-label":"OTP Input",className:v("inline-flex gap-2",c),children:Array.from({length:e},(R,y)=>jsxRuntime.jsx("input",{ref:_=>{w.current[y]=_;},type:u?"password":"text",inputMode:m?"text":"numeric",pattern:m?"[a-zA-Z0-9]":"[0-9]",maxLength:2,value:b[y],disabled:l,readOnly:i,autoComplete:"one-time-code","aria-label":`Digit ${y+1} of ${e}`,className:v(ca({size:a,variant:s,invalid:p||void 0}),"text-secondary-900 dark:text-secondary-100"),onChange:_=>F(y,_.target.value),onKeyDown:_=>P(y,_),onPaste:_=>L(y,_),onFocus:H},y))})}function wn({size:e="sm",variant:t="default",className:r,children:n,...o}){return jsxRuntime.jsx("kbd",{className:v(xo({size:e,variant:t}),r),...o,children:n})}function kn({separator:e="+",className:t,children:r}){let n=Yr__default.default.Children.toArray(r);return jsxRuntime.jsx("span",{className:v("inline-flex items-center gap-1",t),children:n.map((o,a)=>jsxRuntime.jsxs(Yr__default.default.Fragment,{children:[o,a<n.length-1&&jsxRuntime.jsx("span",{className:"select-none text-xs text-secondary-400 dark:text-secondary-500","aria-hidden":true,children:e})]},a))})}var ml={login:"Welcome back",register:"Create account",otp:"Verify your identity",forgot:"Reset password"},fl={login:"Sign in to your account to continue",register:"Fill in the details to get started",otp:"Enter the 6-digit code sent to your email",forgot:"We'll send a reset link to your email"};function zr({mode:e,onModeChange:t,onLogin:r,onRegister:n,onOTPComplete:o,onForgotPassword:a,logo:s,title:l,subtitle:i,socialLogins:d,showRememberMe:m=true,isLoading:u=false,error:p,className:c,style:h}){let[f,g]=Yr.useState("login"),b=e!==void 0,w=b?e:f,C=Yr.useCallback(K=>{b||g(K),t?.(K);},[b,t]),[x,M]=Yr.useState(""),[F,P]=Yr.useState(""),[L,H]=Yr.useState(false),[R,y]=Yr.useState(""),[_,X]=Yr.useState(""),[z,Y]=Yr.useState(""),[ge,E]=Yr.useState(""),ye=Yr.useCallback(async K=>{K.preventDefault(),await r?.(x,F,L);},[x,F,L,r]),fe=Yr.useCallback(async K=>{K.preventDefault(),await n?.(R,_,z);},[R,_,z,n]),Ne=Yr.useCallback(async K=>{K.preventDefault(),await a?.(ge);},[ge,a]),ne=l??ml[w],Te=i??fl[w];return jsxRuntime.jsxs("div",{className:v("w-full max-w-sm rounded-2xl border border-primary-200 bg-white/90 p-8 shadow-xl backdrop-blur-md","dark:border-primary-700 dark:bg-primary-900/90",c),style:h,children:[s&&jsxRuntime.jsx("div",{className:"mb-6 flex justify-center",children:s}),jsxRuntime.jsxs("div",{className:"mb-6 text-center",children:[jsxRuntime.jsx("h2",{className:"text-xl font-bold text-primary-900 dark:text-primary-50",children:ne}),jsxRuntime.jsx("p",{className:"mt-1 text-sm text-secondary-500 dark:text-secondary-400",children:Te})]}),d&&d.length>0&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"mb-4 flex flex-col gap-2",children:d.map((K,Ee)=>jsxRuntime.jsxs("button",{type:"button",onClick:K.onClick,disabled:u,className:v("flex w-full items-center justify-center gap-2 rounded-lg border border-secondary-300 px-4 py-2 text-sm font-medium","text-secondary-700 transition-colors hover:bg-secondary-50","dark:border-secondary-600 dark:text-secondary-300 dark:hover:bg-secondary-800","disabled:opacity-50 disabled:cursor-not-allowed","[&_svg]:h-4 [&_svg]:w-4"),children:[K.icon,K.label]},Ee))}),jsxRuntime.jsxs("div",{className:"relative mb-4 flex items-center",children:[jsxRuntime.jsx("div",{className:"flex-1 border-t border-secondary-200 dark:border-secondary-700"}),jsxRuntime.jsx("span",{className:"mx-3 text-xs text-secondary-400 dark:text-secondary-500",children:"or continue with"}),jsxRuntime.jsx("div",{className:"flex-1 border-t border-secondary-200 dark:border-secondary-700"})]})]}),jsxRuntime.jsxs("div",{className:"login-panel-slide-enter",children:[w==="login"&&jsxRuntime.jsxs("form",{onSubmit:ye,className:"space-y-4",children:[jsxRuntime.jsxs("div",{className:"space-y-1.5",children:[jsxRuntime.jsx(zt,{htmlFor:"lp-email",children:"Email"}),jsxRuntime.jsx(At,{id:"lp-email",type:"email",placeholder:"you@example.com",value:x,onChange:K=>M(K.target.value),disabled:u,required:true})]}),jsxRuntime.jsxs("div",{className:"space-y-1.5",children:[jsxRuntime.jsx(zt,{htmlFor:"lp-password",children:"Password"}),jsxRuntime.jsx(At,{id:"lp-password",type:"password",placeholder:"\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022",value:F,onChange:K=>P(K.target.value),disabled:u,required:true})]}),m&&jsxRuntime.jsxs("div",{className:"flex items-center justify-between",children:[jsxRuntime.jsx(la,{checked:L,onCheckedChange:K=>H(!!K),label:"Remember me",disabled:u}),jsxRuntime.jsx("button",{type:"button",className:"text-xs text-primary-500 hover:underline dark:text-primary-400",onClick:()=>C("forgot"),children:"Forgot password?"})]}),p&&jsxRuntime.jsx("p",{className:"rounded-md bg-danger-50 p-2.5 text-sm text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",children:p}),jsxRuntime.jsx(Pt,{type:"submit",className:"w-full",disabled:u,children:u?jsxRuntime.jsx("span",{className:"inline-block h-4 w-4 animate-spin rounded-full border-2 border-current border-t-transparent"}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:["Sign in"," ",jsxRuntime.jsx(kn,{className:"ml-1 opacity-60",children:jsxRuntime.jsx(wn,{size:"xs",children:"\u23CE"})})]})}),jsxRuntime.jsxs("p",{className:"text-center text-sm text-secondary-500 dark:text-secondary-400",children:["Don't have an account?"," ",jsxRuntime.jsx("button",{type:"button",className:"font-medium text-primary-500 hover:underline dark:text-primary-400",onClick:()=>C("register"),children:"Register"})]})]}),w==="register"&&jsxRuntime.jsxs("form",{onSubmit:fe,className:"space-y-4",children:[jsxRuntime.jsxs("div",{className:"space-y-1.5",children:[jsxRuntime.jsx(zt,{htmlFor:"lp-name",children:"Full name"}),jsxRuntime.jsx(At,{id:"lp-name",type:"text",placeholder:"Jane Doe",value:R,onChange:K=>y(K.target.value),disabled:u,required:true})]}),jsxRuntime.jsxs("div",{className:"space-y-1.5",children:[jsxRuntime.jsx(zt,{htmlFor:"lp-reg-email",children:"Email"}),jsxRuntime.jsx(At,{id:"lp-reg-email",type:"email",placeholder:"you@example.com",value:_,onChange:K=>X(K.target.value),disabled:u,required:true})]}),jsxRuntime.jsxs("div",{className:"space-y-1.5",children:[jsxRuntime.jsx(zt,{htmlFor:"lp-reg-password",children:"Password"}),jsxRuntime.jsx(At,{id:"lp-reg-password",type:"password",placeholder:"\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022",value:z,onChange:K=>Y(K.target.value),disabled:u,required:true})]}),p&&jsxRuntime.jsx("p",{className:"rounded-md bg-danger-50 p-2.5 text-sm text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",children:p}),jsxRuntime.jsx(Pt,{type:"submit",className:"w-full",disabled:u,children:u?jsxRuntime.jsx("span",{className:"inline-block h-4 w-4 animate-spin rounded-full border-2 border-current border-t-transparent"}):"Create account"}),jsxRuntime.jsxs("p",{className:"text-center text-sm text-secondary-500 dark:text-secondary-400",children:["Already have an account?"," ",jsxRuntime.jsx("button",{type:"button",className:"font-medium text-primary-500 hover:underline dark:text-primary-400",onClick:()=>C("login"),children:"Sign in"})]})]}),w==="otp"&&jsxRuntime.jsxs("div",{className:"space-y-6",children:[jsxRuntime.jsx("div",{className:"flex justify-center",children:jsxRuntime.jsx(yn,{length:6,size:"md",onComplete:async K=>{await o?.(K);},autoFocus:true})}),p&&jsxRuntime.jsx("p",{className:"rounded-md bg-danger-50 p-2.5 text-center text-sm text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",children:p}),jsxRuntime.jsx("p",{className:"text-center text-sm text-secondary-500 dark:text-secondary-400",children:jsxRuntime.jsx("button",{type:"button",className:"font-medium text-primary-500 hover:underline dark:text-primary-400",onClick:()=>C("login"),children:"\u2190 Back to login"})})]}),w==="forgot"&&jsxRuntime.jsxs("form",{onSubmit:Ne,className:"space-y-4",children:[jsxRuntime.jsxs("div",{className:"space-y-1.5",children:[jsxRuntime.jsx(zt,{htmlFor:"lp-forgot-email",children:"Email address"}),jsxRuntime.jsx(At,{id:"lp-forgot-email",type:"email",placeholder:"you@example.com",value:ge,onChange:K=>E(K.target.value),disabled:u,required:true})]}),p&&jsxRuntime.jsx("p",{className:"rounded-md bg-danger-50 p-2.5 text-sm text-danger-600 dark:bg-danger-900/30 dark:text-danger-400",children:p}),jsxRuntime.jsx(Pt,{type:"submit",className:"w-full",disabled:u,children:u?jsxRuntime.jsx("span",{className:"inline-block h-4 w-4 animate-spin rounded-full border-2 border-current border-t-transparent"}):"Send reset link"}),jsxRuntime.jsx("p",{className:"text-center text-sm text-secondary-500 dark:text-secondary-400",children:jsxRuntime.jsx("button",{type:"button",className:"font-medium text-primary-500 hover:underline dark:text-primary-400",onClick:()=>C("login"),children:"\u2190 Back to login"})})]})]},w)]})}function fa({item:e,mode:t}){return e.separator?jsxRuntime.jsx("div",{className:"mx-1 h-10 w-px self-center bg-primary-200 dark:bg-primary-700","aria-hidden":true}):jsxRuntime.jsxs("button",{type:"button",title:e.title??e.label,disabled:e.disabled,onClick:e.onClick,"aria-pressed":e.active,className:v("relative flex shrink-0 items-center justify-center gap-1.5 rounded-lg px-2.5 py-1.5 text-xs font-medium transition-all duration-150 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-400","disabled:cursor-not-allowed disabled:opacity-40",e.active?"bg-primary-100 text-primary-700 shadow-inner dark:bg-primary-800 dark:text-primary-200":"text-primary-700 hover:bg-primary-50 active:bg-primary-100 dark:text-primary-300 dark:hover:bg-primary-800",t==="full"?"min-w-[3.5rem] flex-col gap-0.5 py-2":"","[&_svg]:shrink-0",t==="full"?"[&_svg]:h-5 [&_svg]:w-5":"[&_svg]:h-4 [&_svg]:w-4"),children:[e.icon&&jsxRuntime.jsx("span",{children:e.icon}),t!=="icons"&&jsxRuntime.jsx("span",{className:v(t==="full"?"text-[0.6rem] leading-tight":""),children:e.label})]})}function vl({group:e,mode:t,disabled:r=false}){return jsxRuntime.jsxs("div",{className:v("flex shrink-0 flex-col items-stretch",r&&"opacity-50"),children:[jsxRuntime.jsx("div",{className:"flex items-center gap-0.5 px-1",children:e.items.map(n=>jsxRuntime.jsx(fa,{item:r?{...n,disabled:true}:n,mode:t},n.key))}),t==="full"&&jsxRuntime.jsx("div",{className:"mt-1 border-t border-primary-100 px-2 pt-0.5 text-center dark:border-primary-800",children:jsxRuntime.jsx("span",{className:"text-[0.55rem] text-secondary-400 dark:text-secondary-500",children:e.label})})]})}function ha({tabs:e,defaultTab:t,activeTab:r,onTabChange:n,mode:o,onModeChange:a,sticky:s=false,className:l}){let i=e.filter(x=>!x.hidden),[d,m]=Yr.useState(t??i[0]?.key??""),[u,p]=Yr.useState(o??"full"),[c,h]=Yr.useState(true),f=r??d,g=o??u,b=x=>{if(!i.find(F=>F.key===x)?.disabled){if(x===f&&g!=="icons"){h(F=>!F);return}m(x),n?.(x),h(true);}},C=i.find(x=>x.key===f)??i[0];return jsxRuntime.jsxs("div",{className:v("select-none border-b border-primary-200 bg-white dark:border-primary-700 dark:bg-primary-900",s&&"sticky top-0 z-30",l),children:[jsxRuntime.jsxs("div",{className:"flex items-center border-b border-primary-100 dark:border-primary-800",children:[jsxRuntime.jsx("div",{className:"flex flex-1 items-end overflow-x-auto",children:i.map(x=>jsxRuntime.jsxs("button",{type:"button",disabled:x.disabled,onClick:()=>b(x.key),className:v("flex shrink-0 items-center gap-1.5 border-b-2 px-4 py-2 text-sm font-medium transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-400 [&_svg]:h-4 [&_svg]:w-4",x.disabled?"cursor-not-allowed border-transparent text-secondary-300 opacity-50 dark:text-secondary-600":x.key===f&&c?"border-primary-500 text-primary-700 dark:border-primary-400 dark:text-primary-200":"border-transparent text-secondary-500 hover:border-primary-300 hover:text-primary-600 dark:text-secondary-400 dark:hover:text-primary-300"),children:[x.icon,x.label]},x.key))}),jsxRuntime.jsx("button",{type:"button",title:c?"Collapse ribbon":"Expand ribbon",onClick:()=>h(x=>!x),className:"ml-auto mr-2 rounded-md p-1.5 text-secondary-400 transition-colors hover:bg-primary-50 hover:text-primary-600 dark:hover:bg-primary-800 dark:hover:text-primary-300",children:c?jsxRuntime.jsx(lucideReact.ChevronUp,{className:"h-4 w-4"}):jsxRuntime.jsx(lucideReact.ChevronDown,{className:"h-4 w-4"})})]}),c&&C&&g!=="icons"&&jsxRuntime.jsx("div",{className:"flex items-stretch gap-1 overflow-x-auto px-2 py-1.5",children:C.groups.map((x,M)=>jsxRuntime.jsxs(Yr__default.default.Fragment,{children:[M>0&&jsxRuntime.jsx("div",{className:"mx-1 h-auto w-px self-stretch bg-primary-100 dark:bg-primary-800"}),jsxRuntime.jsx(vl,{group:x,mode:g,disabled:x.disabled||C.disabled})]},x.key))}),g==="icons"&&c&&C&&jsxRuntime.jsx("div",{className:"flex items-center gap-0.5 overflow-x-auto px-2 py-1",children:C.groups.flatMap(x=>x.items.map(M=>jsxRuntime.jsx(fa,{item:x.disabled||C.disabled?{...M,disabled:true}:M,mode:"icons"},M.key)))})]})}var kl={sm:{trackFixed:"h-5 w-9",trackH:"h-5 min-w-9",thumb:"h-3.5 w-3.5",thumbTop:"top-[3px]",thumbOff:"left-[2px]",thumbOn:"left-[calc(100%-16px)]",pad:"pl-[6px] pr-[18px]",contentLeft:"left-[6px]",contentRight:"right-[6px]",icon:"text-[10px] [&_svg]:h-3 [&_svg]:w-3"},md:{trackFixed:"h-6 w-11",trackH:"h-6 min-w-11",thumb:"h-4.5 w-4.5",thumbTop:"top-[3px]",thumbOff:"left-[2px]",thumbOn:"left-[calc(100%-20px)]",pad:"pl-[7px] pr-[23px]",contentLeft:"left-[7px]",contentRight:"right-[7px]",icon:"text-xs [&_svg]:h-3.5 [&_svg]:w-3.5"},lg:{trackFixed:"h-7 w-14",trackH:"h-7 min-w-14",thumb:"h-5.5 w-5.5",thumbTop:"top-[3px]",thumbOff:"left-[3px]",thumbOn:"left-[calc(100%-25px)]",pad:"pl-[8px] pr-[28px]",contentLeft:"left-[8px]",contentRight:"right-[8px]",icon:"text-sm [&_svg]:h-4 [&_svg]:w-4"}},Ml={primary:"text-primary-100",secondary:"text-secondary-100",danger:"text-danger-100",warning:"text-warning-100",success:"text-success-100"};function Ir({checked:e,defaultChecked:t=false,onCheckedChange:r,checkedContent:n,uncheckedContent:o,intent:a,size:s,label:l,id:i,className:d,disabled:m,...u}){let p=Yr.useId(),c=i??p,h=s??"md",f=a??"primary",g=kl[h],b=n!=null||o!=null,[w,C]=Yr.useState(t),x=e??w,M=Yr.useCallback(F=>{let P=F.target.checked;e===void 0&&C(P),r?.(P);},[e,r]);return jsxRuntime.jsxs("label",{htmlFor:c,className:v("inline-flex cursor-pointer items-center gap-2",m&&"pointer-events-none opacity-50",d),children:[jsxRuntime.jsx("input",{...u,id:c,type:"checkbox",role:"switch",className:"sr-only",checked:x,disabled:m,onChange:M,"aria-checked":x}),jsxRuntime.jsxs("span",{className:v("relative inline-flex shrink-0 items-center rounded-full transition-colors duration-200",b?g.trackH:g.trackFixed,yo({intent:a,size:s,checked:x?"on":"off"})),children:[b?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs("span",{className:v("pointer-events-none invisible inline-grid",g.icon),children:[jsxRuntime.jsx("span",{className:v("[grid-area:1/1] whitespace-nowrap",g.pad),children:n}),jsxRuntime.jsx("span",{className:v("[grid-area:1/1] whitespace-nowrap",g.pad),children:o})]}),jsxRuntime.jsx("span",{className:v("absolute top-1/2 -translate-y-1/2 whitespace-nowrap font-medium leading-none transition-opacity duration-200",g.contentLeft,g.icon,Ml[f],x?"opacity-100":"opacity-0"),children:n}),jsxRuntime.jsx("span",{className:v("absolute top-1/2 -translate-y-1/2 whitespace-nowrap font-medium leading-none transition-opacity duration-200",g.contentRight,g.icon,"text-primary-400 dark:text-primary-500",x?"opacity-0":"opacity-100"),children:o})]}):null,jsxRuntime.jsx("span",{className:v("pointer-events-none absolute rounded-full bg-white shadow-sm transition-[left] duration-200 ease-in-out",g.thumb,g.thumbTop,x?g.thumbOn:g.thumbOff)})]}),l&&jsxRuntime.jsx("span",{className:"select-none text-sm text-primary-700 dark:text-primary-300",children:l})]})}var Cl=Object.defineProperty,Dn=(e,t)=>{for(var r in t)Cl(e,r,{get:t[r],enumerable:true});};function Ur(e){let{state:t,transaction:r}=e,{selection:n}=r,{doc:o}=r,{storedMarks:a}=r;return {...t,apply:t.apply.bind(t),applyTransaction:t.applyTransaction.bind(t),plugins:t.plugins,schema:t.schema,reconfigure:t.reconfigure.bind(t),toJSON:t.toJSON.bind(t),get storedMarks(){return a},get selection(){return n},get doc(){return o},get tr(){return n=r.selection,o=r.doc,a=r.storedMarks,r}}}var An=class{constructor(e){this.editor=e.editor,this.rawCommands=this.editor.extensionManager.commands,this.customState=e.state;}get hasCustomState(){return !!this.customState}get state(){return this.customState||this.editor.state}get commands(){let{rawCommands:e,editor:t,state:r}=this,{view:n}=t,{tr:o}=r,a=this.buildProps(o);return Object.fromEntries(Object.entries(e).map(([s,l])=>[s,(...d)=>{let m=l(...d)(a);return !o.getMeta("preventDispatch")&&!this.hasCustomState&&n.dispatch(o),m}]))}get chain(){return ()=>this.createChain()}get can(){return ()=>this.createCan()}createChain(e,t=true){let{rawCommands:r,editor:n,state:o}=this,{view:a}=n,s=[],l=!!e,i=e||o.tr,d=()=>(!l&&t&&!i.getMeta("preventDispatch")&&!this.hasCustomState&&a.dispatch(i),s.every(u=>u===true)),m={...Object.fromEntries(Object.entries(r).map(([u,p])=>[u,(...h)=>{let f=this.buildProps(i,t),g=p(...h)(f);return s.push(g),m}])),run:d};return m}createCan(e){let{rawCommands:t,state:r}=this,n=false,o=e||r.tr,a=this.buildProps(o,n);return {...Object.fromEntries(Object.entries(t).map(([l,i])=>[l,(...d)=>i(...d)({...a,dispatch:void 0})])),chain:()=>this.createChain(o,n)}}buildProps(e,t=true){let{rawCommands:r,editor:n,state:o}=this,{view:a}=n,s={tr:e,editor:n,view:a,state:Ur({state:o,transaction:e}),dispatch:t?()=>{}:void 0,chain:()=>this.createChain(e,t),can:()=>this.createCan(e),get commands(){return Object.fromEntries(Object.entries(r).map(([l,i])=>[l,(...d)=>i(...d)(s)]))}};return s}},Ra={};Dn(Ra,{blur:()=>Sl,clearContent:()=>Tl,clearNodes:()=>Pl,command:()=>Rl,createParagraphNear:()=>Al,cut:()=>Ll,deleteCurrentNode:()=>Il,deleteNode:()=>_l,deleteRange:()=>Hl,deleteSelection:()=>Fl,enter:()=>$l,exitCode:()=>Vl,extendMarkRange:()=>Ul,first:()=>Kl,focus:()=>Xl,forEach:()=>Gl,insertContent:()=>Jl,insertContentAt:()=>sc,joinBackward:()=>mc,joinDown:()=>pc,joinForward:()=>fc,joinItemBackward:()=>gc,joinItemForward:()=>vc,joinTextblockBackward:()=>xc,joinTextblockForward:()=>kc,joinUp:()=>uc,keyboardShortcut:()=>Nc,lift:()=>Sc,liftEmptyBlock:()=>Ec,liftListItem:()=>Rc,newlineInCode:()=>Ac,resetAttributes:()=>zc,scrollIntoView:()=>Lc,selectAll:()=>_c,selectNodeBackward:()=>Oc,selectNodeForward:()=>$c,selectParentNode:()=>Vc,selectTextblockEnd:()=>Uc,selectTextblockStart:()=>Wc,setContent:()=>qc,setMark:()=>gd,setMeta:()=>bd,setNode:()=>vd,setNodeSelection:()=>xd,setTextDirection:()=>wd,setTextSelection:()=>kd,sinkListItem:()=>Nd,splitBlock:()=>Td,splitListItem:()=>Dd,toggleList:()=>Ad,toggleMark:()=>zd,toggleNode:()=>Ld,toggleWrap:()=>Id,undoInputRule:()=>_d,unsetAllMarks:()=>Hd,unsetMark:()=>Od,unsetTextDirection:()=>Fd,updateAttributes:()=>$d,wrapIn:()=>Vd,wrapInList:()=>Ud});var Sl=()=>({editor:e,view:t})=>(requestAnimationFrame(()=>{var r;e.isDestroyed||(t.dom.blur(),(r=window?.getSelection())==null||r.removeAllRanges());}),true),Tl=(e=true)=>({commands:t})=>t.setContent("",{emitUpdate:e}),Pl=()=>({state:e,tr:t,dispatch:r})=>{let{selection:n}=t,{ranges:o}=n;return r&&o.forEach(({$from:a,$to:s})=>{e.doc.nodesBetween(a.pos,s.pos,(l,i)=>{if(l.type.isText)return;let{doc:d,mapping:m}=t,u=d.resolve(m.map(i)),p=d.resolve(m.map(i+l.nodeSize)),c=u.blockRange(p);if(!c)return;let h=transform.liftTarget(c);if(l.type.isTextblock){let{defaultType:f}=u.parent.contentMatchAt(u.index());t.setNodeMarkup(c.start,f);}(h||h===0)&&t.lift(c,h);});}),true},Rl=e=>t=>e(t),Al=()=>({state:e,dispatch:t})=>commands.createParagraphNear(e,t),Ll=(e,t)=>({editor:r,tr:n})=>{let{state:o}=r,a=o.doc.slice(e.from,e.to);n.deleteRange(e.from,e.to);let s=n.mapping.map(t);return n.insert(s,a.content),n.setSelection(new state.TextSelection(n.doc.resolve(Math.max(s-1,0)))),true},Il=()=>({tr:e,dispatch:t})=>{let{selection:r}=e,n=r.$anchor.node();if(n.content.size>0)return false;let o=e.selection.$anchor;for(let a=o.depth;a>0;a-=1)if(o.node(a).type===n.type){if(t){let l=o.before(a),i=o.after(a);e.delete(l,i).scrollIntoView();}return true}return false};function Ve(e,t){if(typeof e=="string"){if(!t.nodes[e])throw Error(`There is no node type named '${e}'. Maybe you forgot to add the extension?`);return t.nodes[e]}return e}var _l=e=>({tr:t,state:r,dispatch:n})=>{let o=Ve(e,r.schema),a=t.selection.$anchor;for(let s=a.depth;s>0;s-=1)if(a.node(s).type===o){if(n){let i=a.before(s),d=a.after(s);t.delete(i,d).scrollIntoView();}return true}return false},Hl=e=>({tr:t,dispatch:r})=>{let{from:n,to:o}=e;return r&&t.delete(n,o),true},Fl=()=>({state:e,dispatch:t})=>commands.deleteSelection(e,t),$l=()=>({commands:e})=>e.keyboardShortcut("Enter"),Vl=()=>({state:e,dispatch:t})=>commands.exitCode(e,t);function zn(e){return Object.prototype.toString.call(e)==="[object RegExp]"}function Br(e,t,r={strict:true}){let n=Object.keys(t);return n.length?n.every(o=>r.strict?t[o]===e[o]:zn(t[o])?t[o].test(e[o]):t[o]===e[o]):true}function Da(e,t,r={}){return e.find(n=>n.type===t&&Br(Object.fromEntries(Object.keys(r).map(o=>[o,n.attrs[o]])),r))}function ga(e,t,r={}){return !!Da(e,t,r)}function Aa(e,t,r){var n;if(!e||!t)return;let o=e.parent.childAfter(e.parentOffset);if((!o.node||!o.node.marks.some(m=>m.type===t))&&(o=e.parent.childBefore(e.parentOffset)),!o.node||!o.node.marks.some(m=>m.type===t)||(r=r||((n=o.node.marks[0])==null?void 0:n.attrs),!Da([...o.node.marks],t,r)))return;let s=o.index,l=e.start()+o.offset,i=s+1,d=l+o.node.nodeSize;for(;s>0&&ga([...e.parent.child(s-1).marks],t,r);)s-=1,l-=e.parent.child(s).nodeSize;for(;i<e.parent.childCount&&ga([...e.parent.child(i).marks],t,r);)d+=e.parent.child(i).nodeSize,i+=1;return {from:l,to:d}}function ht(e,t){if(typeof e=="string"){if(!t.marks[e])throw Error(`There is no mark type named '${e}'. Maybe you forgot to add the extension?`);return t.marks[e]}return e}var Ul=(e,t={})=>({tr:r,state:n,dispatch:o})=>{let a=ht(e,n.schema),{doc:s,selection:l}=r,{$from:i,from:d,to:m}=l;if(o){let u=Aa(i,a,t);if(u&&u.from<=d&&u.to>=m){let p=state.TextSelection.create(s,u.from,u.to);r.setSelection(p);}}return true},Kl=e=>t=>{let r=typeof e=="function"?e(t):e;for(let n=0;n<r.length;n+=1)if(r[n](t))return true;return false};function za(e){return e instanceof state.TextSelection}function It(e=0,t=0,r=0){return Math.min(Math.max(e,t),r)}function Yl(e,t=null){if(!t)return null;let r=state.Selection.atStart(e),n=state.Selection.atEnd(e);if(t==="start"||t===true)return r;if(t==="end")return n;let o=r.from,a=n.to;return t==="all"?state.TextSelection.create(e,It(0,o,a),It(e.content.size,o,a)):state.TextSelection.create(e,It(t,o,a),It(t,o,a))}function ya(){return navigator.platform==="Android"||/android/i.test(navigator.userAgent)}function Vr(){return ["iPad Simulator","iPhone Simulator","iPod Simulator","iPad","iPhone","iPod"].includes(navigator.platform)||navigator.userAgent.includes("Mac")&&"ontouchend"in document}function ql(){return typeof navigator<"u"?/^((?!chrome|android).)*safari/i.test(navigator.userAgent):false}var Xl=(e=null,t={})=>({editor:r,view:n,tr:o,dispatch:a})=>{t={scrollIntoView:true,...t};let s=()=>{(Vr()||ya())&&n.dom.focus(),ql()&&!Vr()&&!ya()&&n.dom.focus({preventScroll:true}),requestAnimationFrame(()=>{r.isDestroyed||(n.focus(),t?.scrollIntoView&&r.commands.scrollIntoView());});};try{if(n.hasFocus()&&e===null||e===!1)return !0}catch{return false}if(a&&e===null&&!za(r.state.selection))return s(),true;let l=Yl(o.doc,e)||r.state.selection,i=r.state.selection.eq(l);return a&&(i||o.setSelection(l),i&&o.storedMarks&&o.setStoredMarks(o.storedMarks),s()),true},Gl=(e,t)=>r=>e.every((n,o)=>t(n,{...r,index:o})),Jl=(e,t)=>({tr:r,commands:n})=>n.insertContentAt({from:r.selection.from,to:r.selection.to},e,t),La=e=>{let t=e.childNodes;for(let r=t.length-1;r>=0;r-=1){let n=t[r];n.nodeType===3&&n.nodeValue&&/^(\n\s\s|\n)$/.test(n.nodeValue)?e.removeChild(n):n.nodeType===1&&La(n);}return e};function _r(e){if(typeof window>"u")throw new Error("[tiptap error]: there is no window object available, so this function cannot be used");let t=`<body>${e}</body>`,r=new window.DOMParser().parseFromString(t,"text/html").body;return La(r)}function dr(e,t,r){if(e instanceof model.Node||e instanceof model.Fragment)return e;r={slice:true,parseOptions:{},...r};let n=typeof e=="object"&&e!==null,o=typeof e=="string";if(n)try{if(Array.isArray(e)&&e.length>0)return model.Fragment.fromArray(e.map(l=>t.nodeFromJSON(l)));let s=t.nodeFromJSON(e);return r.errorOnInvalidContent&&s.check(),s}catch(a){if(r.errorOnInvalidContent)throw new Error("[tiptap error]: Invalid JSON content",{cause:a});return console.warn("[tiptap warn]: Invalid content.","Passed value:",e,"Error:",a),dr("",t,r)}if(o){if(r.errorOnInvalidContent){let s=false,l="",i=new model.Schema({topNode:t.spec.topNode,marks:t.spec.marks,nodes:t.spec.nodes.append({__tiptap__private__unknown__catch__all__node:{content:"inline*",group:"block",parseDOM:[{tag:"*",getAttrs:d=>(s=true,l=typeof d=="string"?d:d.outerHTML,null)}]}})});if(r.slice?model.DOMParser.fromSchema(i).parseSlice(_r(e),r.parseOptions):model.DOMParser.fromSchema(i).parse(_r(e),r.parseOptions),r.errorOnInvalidContent&&s)throw new Error("[tiptap error]: Invalid HTML content",{cause:new Error(`Invalid element found: ${l}`)})}let a=model.DOMParser.fromSchema(t);return r.slice?a.parseSlice(_r(e),r.parseOptions).content:a.parse(_r(e),r.parseOptions)}return dr("",t,r)}function oc(e,t,r){let n=e.steps.length-1;if(n<t)return;let o=e.steps[n];if(!(o instanceof transform.ReplaceStep||o instanceof transform.ReplaceAroundStep))return;let a=e.mapping.maps[n],s=0;a.forEach((l,i,d,m)=>{s===0&&(s=m);}),e.setSelection(state.Selection.near(e.doc.resolve(s),r));}var ac=e=>!("type"in e),sc=(e,t,r)=>({tr:n,dispatch:o,editor:a})=>{var s;if(o){r={parseOptions:a.options.parseOptions,updateSelection:true,applyInputRules:false,applyPasteRules:false,...r};let l,i=g=>{a.emit("contentError",{editor:a,error:g,disableCollaboration:()=>{"collaboration"in a.storage&&typeof a.storage.collaboration=="object"&&a.storage.collaboration&&(a.storage.collaboration.isDisabled=true);}});},d={preserveWhitespace:"full",...r.parseOptions};if(!r.errorOnInvalidContent&&!a.options.enableContentCheck&&a.options.emitContentError)try{dr(t,a.schema,{parseOptions:d,errorOnInvalidContent:!0});}catch(g){i(g);}try{l=dr(t,a.schema,{parseOptions:d,errorOnInvalidContent:(s=r.errorOnInvalidContent)!=null?s:a.options.enableContentCheck});}catch(g){return i(g),false}let{from:m,to:u}=typeof e=="number"?{from:e,to:e}:{from:e.from,to:e.to},p=true,c=true;if((ac(l)?l:[l]).forEach(g=>{g.check(),p=p?g.isText&&g.marks.length===0:false,c=c?g.isBlock:false;}),m===u&&c){let{parent:g}=n.doc.resolve(m);g.isTextblock&&!g.type.spec.code&&!g.childCount&&(m-=1,u+=1);}let f;if(p){if(Array.isArray(t))f=t.map(g=>g.text||"").join("");else if(t instanceof model.Fragment){let g="";t.forEach(b=>{b.text&&(g+=b.text);}),f=g;}else typeof t=="object"&&t&&t.text?f=t.text:f=t;n.insertText(f,m,u);}else {f=l;let g=n.doc.resolve(m),b=g.node(),w=g.parentOffset===0,C=b.isText||b.isTextblock,x=b.content.size>0;w&&C&&x&&(m=Math.max(0,m-1)),n.replaceWith(m,u,f);}r.updateSelection&&oc(n,n.steps.length-1,-1),r.applyInputRules&&n.setMeta("applyInputRules",{from:m,text:f}),r.applyPasteRules&&n.setMeta("applyPasteRules",{from:m,text:f});}return true},uc=()=>({state:e,dispatch:t})=>commands.joinUp(e,t),pc=()=>({state:e,dispatch:t})=>commands.joinDown(e,t),mc=()=>({state:e,dispatch:t})=>commands.joinBackward(e,t),fc=()=>({state:e,dispatch:t})=>commands.joinForward(e,t),gc=()=>({state:e,dispatch:t,tr:r})=>{try{let n=transform.joinPoint(e.doc,e.selection.$from.pos,-1);return n==null?!1:(r.join(n,2),t&&t(r),!0)}catch{return false}},vc=()=>({state:e,dispatch:t,tr:r})=>{try{let n=transform.joinPoint(e.doc,e.selection.$from.pos,1);return n==null?!1:(r.join(n,2),t&&t(r),!0)}catch{return false}},xc=()=>({state:e,dispatch:t})=>commands.joinTextblockBackward(e,t),kc=()=>({state:e,dispatch:t})=>commands.joinTextblockForward(e,t);function Ia(){return typeof navigator<"u"?/Mac/.test(navigator.platform):false}function Mc(e){let t=e.split(/-(?!$)/),r=t[t.length-1];r==="Space"&&(r=" ");let n,o,a,s;for(let l=0;l<t.length-1;l+=1){let i=t[l];if(/^(cmd|meta|m)$/i.test(i))s=true;else if(/^a(lt)?$/i.test(i))n=true;else if(/^(c|ctrl|control)$/i.test(i))o=true;else if(/^s(hift)?$/i.test(i))a=true;else if(/^mod$/i.test(i))Vr()||Ia()?s=true:o=true;else throw new Error(`Unrecognized modifier name: ${i}`)}return n&&(r=`Alt-${r}`),o&&(r=`Ctrl-${r}`),s&&(r=`Meta-${r}`),a&&(r=`Shift-${r}`),r}var Nc=e=>({editor:t,view:r,tr:n,dispatch:o})=>{let a=Mc(e).split(/-(?!$)/),s=a.find(d=>!["Alt","Ctrl","Meta","Shift"].includes(d)),l=new KeyboardEvent("keydown",{key:s==="Space"?" ":s,altKey:a.includes("Alt"),ctrlKey:a.includes("Ctrl"),metaKey:a.includes("Meta"),shiftKey:a.includes("Shift"),bubbles:true,cancelable:true}),i=t.captureTransaction(()=>{r.someProp("handleKeyDown",d=>d(r,l));});return i?.steps.forEach(d=>{let m=d.map(n.mapping);m&&o&&n.maybeStep(m);}),true};function Ln(e,t,r={}){let{from:n,to:o,empty:a}=e.selection,s=t?Ve(t,e.schema):null,l=[];e.doc.nodesBetween(n,o,(u,p)=>{if(u.isText)return;let c=Math.max(n,p),h=Math.min(o,p+u.nodeSize);l.push({node:u,from:c,to:h});});let i=o-n,d=l.filter(u=>s?s.name===u.node.type.name:true).filter(u=>Br(u.node.attrs,r,{strict:false}));return a?!!d.length:d.reduce((u,p)=>u+p.to-p.from,0)>=i}var Sc=(e,t={})=>({state:r,dispatch:n})=>{let o=Ve(e,r.schema);return Ln(r,o,t)?commands.lift(r,n):false},Ec=()=>({state:e,dispatch:t})=>commands.liftEmptyBlock(e,t),Rc=e=>({state:t,dispatch:r})=>{let n=Ve(e,t.schema);return schemaList.liftListItem(n)(t,r)},Ac=()=>({state:e,dispatch:t})=>commands.newlineInCode(e,t);function _a(e,t){return t.nodes[e]?"node":t.marks[e]?"mark":null}function wa(e,t){let r=typeof t=="string"?[t]:t;return Object.keys(e).reduce((n,o)=>(r.includes(o)||(n[o]=e[o]),n),{})}var zc=(e,t)=>({tr:r,state:n,dispatch:o})=>{let a=null,s=null,l=_a(typeof e=="string"?e:e.name,n.schema);if(!l)return false;l==="node"&&(a=Ve(e,n.schema)),l==="mark"&&(s=ht(e,n.schema));let i=false;return r.selection.ranges.forEach(d=>{n.doc.nodesBetween(d.$from.pos,d.$to.pos,(m,u)=>{a&&a===m.type&&(i=true,o&&r.setNodeMarkup(u,void 0,wa(m.attrs,t))),s&&m.marks.length&&m.marks.forEach(p=>{s===p.type&&(i=true,o&&r.addMark(u,u+m.nodeSize,s.create(wa(p.attrs,t))));});});}),i},Lc=()=>({tr:e,dispatch:t})=>(t&&e.scrollIntoView(),true),_c=()=>({tr:e,dispatch:t})=>{if(t){let r=new state.AllSelection(e.doc);e.setSelection(r);}return true},Oc=()=>({state:e,dispatch:t})=>commands.selectNodeBackward(e,t),$c=()=>({state:e,dispatch:t})=>commands.selectNodeForward(e,t),Vc=()=>({state:e,dispatch:t})=>commands.selectParentNode(e,t),Uc=()=>({state:e,dispatch:t})=>commands.selectTextblockEnd(e,t),Wc=()=>({state:e,dispatch:t})=>commands.selectTextblockStart(e,t);function Yc(e,t,r={},n={}){return dr(e,t,{slice:false,parseOptions:r,errorOnInvalidContent:n.errorOnInvalidContent})}var qc=(e,{errorOnInvalidContent:t,emitUpdate:r=true,parseOptions:n={}}={})=>({editor:o,tr:a,dispatch:s,commands:l})=>{let{doc:i}=a;if(n.preserveWhitespace!=="full"){let d=Yc(e,o.schema,n,{errorOnInvalidContent:t??o.options.enableContentCheck});return s&&a.replaceWith(0,i.content.size,d).setMeta("preventUpdate",!r),true}return s&&a.setMeta("preventUpdate",!r),l.insertContentAt({from:0,to:i.content.size},e,{parseOptions:n,errorOnInvalidContent:t??o.options.enableContentCheck})};function Xc(e,t){let r=ht(t,e.schema),{from:n,to:o,empty:a}=e.selection,s=[];a?(e.storedMarks&&s.push(...e.storedMarks),s.push(...e.selection.$head.marks())):e.doc.nodesBetween(n,o,i=>{s.push(...i.marks);});let l=s.find(i=>i.type.name===r.name);return l?{...l.attrs}:{}}function Jc(e,t){let r=new transform.Transform(e);return t.forEach(n=>{n.steps.forEach(o=>{r.step(o);});}),r}function Qc(e){for(let t=0;t<e.edgeCount;t+=1){let{type:r}=e.edge(t);if(r.isTextblock&&!r.hasRequiredAttrs())return r}return null}function Zc(e,t){for(let r=e.depth;r>0;r-=1){let n=e.node(r);if(t(n))return {pos:r>0?e.before(r):0,start:e.start(r),depth:r,node:n}}}function In(e){return t=>Zc(t.$from,e)}function U(e,t,r){return e.config[t]===void 0&&e.parent?U(e.parent,t,r):typeof e.config[t]=="function"?e.config[t].bind({...r,parent:e.parent?U(e.parent,t,r):null}):e.config[t]}function rd(e){return typeof e=="function"}function Ce(e,t=void 0,...r){return rd(e)?t?e.bind(t)(...r):e(...r):e}function Jt(e){let t=e.filter(o=>o.type==="extension"),r=e.filter(o=>o.type==="node"),n=e.filter(o=>o.type==="mark");return {baseExtensions:t,nodeExtensions:r,markExtensions:n}}function od(e){let t=[],r="",n=false,o=false,a=0,s=e.length;for(let l=0;l<s;l+=1){let i=e[l];if(i==="'"&&!o){n=!n,r+=i;continue}if(i==='"'&&!n){o=!o,r+=i;continue}if(!n&&!o){if(i==="("){a+=1,r+=i;continue}if(i===")"&&a>0){a-=1,r+=i;continue}if(i===";"&&a===0){t.push(r),r="";continue}}r+=i;}return r&&t.push(r),t}function ka(e){let t=[],r=od(e||""),n=r.length;for(let o=0;o<n;o+=1){let a=r[o],s=a.indexOf(":");if(s===-1)continue;let l=a.slice(0,s).trim(),i=a.slice(s+1).trim();l&&i&&t.push([l,i]);}return t}function Qt(...e){return e.filter(t=>!!t).reduce((t,r)=>{let n={...t};return Object.entries(r).forEach(([o,a])=>{if(!n[o]){n[o]=a;return}if(o==="class"){let l=a?String(a).split(" "):[],i=n[o]?n[o].split(" "):[],d=l.filter(m=>!i.includes(m));n[o]=[...i,...d].join(" ");}else if(o==="style"){let l=new Map([...ka(n[o]),...ka(a)]);n[o]=Array.from(l.entries()).map(([i,d])=>`${i}: ${d}`).join("; ");}else n[o]=a;}),n},{})}function ld(e,t,r){let{from:n,to:o}=t,{blockSeparator:a=`
|
|
84
|
+
|
|
85
|
+
`,textSerializers:s={}}=r||{},l="";return e.nodesBetween(n,o,(i,d,m,u)=>{var p;i.isBlock&&d>n&&(l+=a);let c=s?.[i.type.name];if(c)return m&&(l+=c({node:i,pos:d,parent:m,index:u,range:t})),false;i.isText&&(l+=(p=i?.text)==null?void 0:p.slice(Math.max(n,d)-d,o-d));}),l}function cd(e){return Object.fromEntries(Object.entries(e.nodes).filter(([,t])=>t.spec.toText).map(([t,r])=>[t,r.spec.toText]))}function dd(e,t=JSON.stringify){let r={};return e.filter(n=>{let o=t(n);return Object.prototype.hasOwnProperty.call(r,o)?false:r[o]=true})}function ud(e){let t=dd(e);return t.length===1?t:t.filter((r,n)=>!t.filter((a,s)=>s!==n).some(a=>r.oldRange.from>=a.oldRange.from&&r.oldRange.to<=a.oldRange.to&&r.newRange.from>=a.newRange.from&&r.newRange.to<=a.newRange.to))}function pd(e){let{mapping:t,steps:r}=e,n=[];return t.maps.forEach((o,a)=>{let s=[];if(o.ranges.length)o.forEach((l,i)=>{s.push({from:l,to:i});});else {let{from:l,to:i}=r[a];if(l===void 0||i===void 0)return;s.push({from:l,to:i});}s.forEach(({from:l,to:i})=>{let d=t.slice(a).map(l,-1),m=t.slice(a).map(i),u=t.invert().map(d,-1),p=t.invert().map(m);n.push({oldRange:{from:u,to:p},newRange:{from:d,to:m}});});}),ud(n)}function $r(e,t,r){return Object.fromEntries(Object.entries(r).filter(([n])=>{let o=e.find(a=>a.type===t&&a.name===n);return o?o.attribute.keepOnSplit:false}))}function fd(e,t,r={}){let{empty:n,ranges:o}=e.selection,a=t?ht(t,e.schema):null;if(n)return !!(e.storedMarks||e.selection.$from.marks()).filter(u=>a?a.name===u.type.name:true).find(u=>Br(u.attrs,r,{strict:false}));let s=0,l=[];if(o.forEach(({$from:u,$to:p})=>{let c=u.pos,h=p.pos;e.doc.nodesBetween(c,h,(f,g)=>{if(a&&f.inlineContent&&!f.type.allowsMarkType(a))return false;if(!f.isText&&!f.marks.length)return;let b=Math.max(c,g),w=Math.min(h,g+f.nodeSize),C=w-b;s+=C,l.push(...f.marks.map(x=>({mark:x,from:b,to:w})));});}),s===0)return false;let i=l.filter(u=>a?a.name===u.mark.type.name:true).filter(u=>Br(u.mark.attrs,r,{strict:false})).reduce((u,p)=>u+p.to-p.from,0),d=l.filter(u=>a?u.mark.type!==a&&u.mark.type.excludes(a):true).reduce((u,p)=>u+p.to-p.from,0);return (i>0?i+d:i)>=s}function Ta(e,t){let{nodeExtensions:r}=Jt(t),n=r.find(s=>s.name===e);if(!n)return false;let o={name:n.name,options:n.options,storage:n.storage},a=Ce(U(n,"group",o));return typeof a!="string"?false:a.split(" ").includes("list")}function $a(e,{checkChildren:t=true,ignoreWhitespace:r=false}={}){var n;if(r){if(e.type.name==="hardBreak")return true;if(e.isText)return !/\S/.test((n=e.text)!=null?n:"")}if(e.isText)return !e.text;if(e.isAtom||e.isLeaf)return false;if(e.content.childCount===0)return true;if(t){let o=true;return e.content.forEach(a=>{o!==false&&($a(a,{ignoreWhitespace:r,checkChildren:t})||(o=false));}),o}return false}function hd(e,t,r){var n;let{selection:o}=t,a=null;if(za(o)&&(a=o.$cursor),a){let l=(n=e.storedMarks)!=null?n:a.marks();return a.parent.type.allowsMarkType(r)&&(!!r.isInSet(l)||!l.some(d=>d.type.excludes(r)))}let{ranges:s}=o;return s.some(({$from:l,$to:i})=>{let d=l.depth===0?e.doc.inlineContent&&e.doc.type.allowsMarkType(r):false;return e.doc.nodesBetween(l.pos,i.pos,(m,u,p)=>{if(d)return false;if(m.isInline){let c=!p||p.type.allowsMarkType(r),h=!!r.isInSet(m.marks)||!m.marks.some(f=>f.type.excludes(r));d=c&&h;}return !d}),d})}var gd=(e,t={})=>({tr:r,state:n,dispatch:o})=>{let{selection:a}=r,{empty:s,ranges:l}=a,i=ht(e,n.schema);if(o)if(s){let d=Xc(n,i);r.addStoredMark(i.create({...d,...t}));}else l.forEach(d=>{let m=d.$from.pos,u=d.$to.pos;n.doc.nodesBetween(m,u,(p,c)=>{let h=Math.max(c,m),f=Math.min(c+p.nodeSize,u);p.marks.find(b=>b.type===i)?p.marks.forEach(b=>{i===b.type&&r.addMark(h,f,i.create({...b.attrs,...t}));}):r.addMark(h,f,i.create(t));});});return hd(n,r,i)},bd=(e,t)=>({tr:r})=>(r.setMeta(e,t),true),vd=(e,t={})=>({state:r,dispatch:n,chain:o})=>{let a=Ve(e,r.schema),s;return r.selection.$anchor.sameParent(r.selection.$head)&&(s=r.selection.$anchor.parent.attrs),a.isTextblock?o().command(({commands:l})=>commands.setBlockType(a,{...s,...t})(r)?true:l.clearNodes()).command(({state:l})=>commands.setBlockType(a,{...s,...t})(l,n)).run():(console.warn('[tiptap warn]: Currently "setNode()" only supports text block nodes.'),false)},xd=e=>({tr:t,dispatch:r})=>{if(r){let{doc:n}=t,o=It(e,0,n.content.size),a=state.NodeSelection.create(n,o);t.setSelection(a);}return true},wd=(e,t)=>({tr:r,state:n,dispatch:o})=>{let{selection:a}=n,s,l;return typeof t=="number"?(s=t,l=t):t&&"from"in t&&"to"in t?(s=t.from,l=t.to):(s=a.from,l=a.to),o&&r.doc.nodesBetween(s,l,(i,d)=>{i.isText||r.setNodeMarkup(d,void 0,{...i.attrs,dir:e});}),true},kd=e=>({tr:t,dispatch:r})=>{if(r){let{doc:n}=t,{from:o,to:a}=typeof e=="number"?{from:e,to:e}:e,s=state.TextSelection.atStart(n).from,l=state.TextSelection.atEnd(n).to,i=It(o,s,l),d=It(a,s,l),m=state.TextSelection.create(n,i,d);t.setSelection(m);}return true},Nd=e=>({state:t,dispatch:r})=>{let n=Ve(e,t.schema);return schemaList.sinkListItem(n)(t,r)};function Pa(e,t){let r=e.storedMarks||e.selection.$to.parentOffset&&e.selection.$from.marks();if(r){let n=r.filter(o=>t?.includes(o.type.name));e.tr.ensureMarks(n);}}var Td=({keepMarks:e=true}={})=>({tr:t,state:r,dispatch:n,editor:o})=>{let{selection:a,doc:s}=t,{$from:l,$to:i}=a,d=o.extensionManager.attributes,m=$r(d,l.node().type.name,l.node().attrs);if(a instanceof state.NodeSelection&&a.node.isBlock)return !l.parentOffset||!transform.canSplit(s,l.pos)?false:(n&&(e&&Pa(r,o.extensionManager.splittableMarks),t.split(l.pos).scrollIntoView()),true);if(!l.parent.isBlock)return false;let u=i.parentOffset===i.parent.content.size,p=l.depth===0?void 0:Qc(l.node(-1).contentMatchAt(l.indexAfter(-1))),c=u&&p?[{type:p,attrs:m}]:void 0,h=transform.canSplit(t.doc,t.mapping.map(l.pos),1,c);if(!c&&!h&&transform.canSplit(t.doc,t.mapping.map(l.pos),1,p?[{type:p}]:void 0)&&(h=true,c=p?[{type:p,attrs:m}]:void 0),n){if(h&&(a instanceof state.TextSelection&&t.deleteSelection(),t.split(t.mapping.map(l.pos),1,c),p&&!u&&!l.parentOffset&&l.parent.type!==p)){let f=t.mapping.map(l.before()),g=t.doc.resolve(f);l.node(-1).canReplaceWith(g.index(),g.index()+1,p)&&t.setNodeMarkup(t.mapping.map(l.before()),p);}e&&Pa(r,o.extensionManager.splittableMarks),t.scrollIntoView();}return h},Dd=(e,t={})=>({tr:r,state:n,dispatch:o,editor:a})=>{var s;let l=Ve(e,n.schema),{$from:i,$to:d}=n.selection,m=n.selection.node;if(m&&m.isBlock||i.depth<2||!i.sameParent(d))return false;let u=i.node(-1);if(u.type!==l)return false;let p=a.extensionManager.attributes;if(i.parent.content.size===0&&i.node(-1).childCount===i.indexAfter(-1)){if(i.depth===2||i.node(-3).type!==l||i.index(-2)!==i.node(-2).childCount-1)return false;if(o){let b=model.Fragment.empty,w=i.index(-1)?1:i.index(-2)?2:3;for(let L=i.depth-w;L>=i.depth-3;L-=1)b=model.Fragment.from(i.node(L).copy(b));let C=i.indexAfter(-1)<i.node(-2).childCount?1:i.indexAfter(-2)<i.node(-3).childCount?2:3,x={...$r(p,i.node().type.name,i.node().attrs),...t},M=((s=l.contentMatch.defaultType)==null?void 0:s.createAndFill(x))||void 0;b=b.append(model.Fragment.from(l.createAndFill(null,M)||void 0));let F=i.before(i.depth-(w-1));r.replace(F,i.after(-C),new model.Slice(b,4-w,0));let P=-1;r.doc.nodesBetween(F,r.doc.content.size,(L,H)=>{if(P>-1)return false;L.isTextblock&&L.content.size===0&&(P=H+1);}),P>-1&&r.setSelection(state.TextSelection.near(r.doc.resolve(P))),r.scrollIntoView();}return true}let c=d.pos===i.end()?u.contentMatchAt(0).defaultType:null,h={...$r(p,u.type.name,u.attrs),...t},f={...$r(p,i.node().type.name,i.node().attrs),...t};r.delete(i.pos,d.pos);let g=c?[{type:l,attrs:h},{type:c,attrs:f}]:[{type:l,attrs:h}];if(!transform.canSplit(r.doc,i.pos,2))return false;if(o){let{selection:b,storedMarks:w}=n,{splittableMarks:C}=a.extensionManager,x=w||b.$to.parentOffset&&b.$from.marks();if(r.split(i.pos,2,g).scrollIntoView(),!x||!o)return true;let M=x.filter(F=>C.includes(F.type.name));r.ensureMarks(M);}return true},En=(e,t)=>{let r=In(s=>s.type===t)(e.selection);if(!r)return true;let n=e.doc.resolve(Math.max(0,r.pos-1)).before(r.depth);if(n===void 0)return true;let o=e.doc.nodeAt(n);return r.node.type===o?.type&&transform.canJoin(e.doc,r.pos)&&e.join(r.pos),true},Pn=(e,t)=>{let r=In(s=>s.type===t)(e.selection);if(!r)return true;let n=e.doc.resolve(r.start).after(r.depth);if(n===void 0)return true;let o=e.doc.nodeAt(n);return r.node.type===o?.type&&transform.canJoin(e.doc,n)&&e.join(n),true},Ad=(e,t,r,n={})=>({editor:o,tr:a,state:s,dispatch:l,chain:i,commands:d,can:m})=>{let{extensions:u,splittableMarks:p}=o.extensionManager,c=Ve(e,s.schema),h=Ve(t,s.schema),{selection:f,storedMarks:g}=s,{$from:b,$to:w}=f,C=b.blockRange(w),x=g||f.$to.parentOffset&&f.$from.marks();if(!C)return false;let M=In(F=>Ta(F.type.name,u))(f);if(C.depth>=1&&M&&C.depth-M.depth<=1){if(M.node.type===c)return d.liftListItem(h);if(Ta(M.node.type.name,u)&&c.validContent(M.node.content)&&l)return i().command(()=>(a.setNodeMarkup(M.pos,c),true)).command(()=>En(a,c)).command(()=>Pn(a,c)).run()}return !r||!x||!l?i().command(()=>m().wrapInList(c,n)?true:d.clearNodes()).wrapInList(c,n).command(()=>En(a,c)).command(()=>Pn(a,c)).run():i().command(()=>{let F=m().wrapInList(c,n),P=x.filter(L=>p.includes(L.type.name));return a.ensureMarks(P),F?true:d.clearNodes()}).wrapInList(c,n).command(()=>En(a,c)).command(()=>Pn(a,c)).run()},zd=(e,t={},r={})=>({state:n,commands:o})=>{let{extendEmptyMarkRange:a=false}=r,s=ht(e,n.schema);return fd(n,s,t)?o.unsetMark(s,{extendEmptyMarkRange:a}):o.setMark(s,t)},Ld=(e,t,r={})=>({state:n,commands:o})=>{let a=Ve(e,n.schema),s=Ve(t,n.schema),l=Ln(n,a,r),i;return n.selection.$anchor.sameParent(n.selection.$head)&&(i=n.selection.$anchor.parent.attrs),l?o.setNode(s,i):o.setNode(a,{...i,...r})},Id=(e,t={})=>({state:r,commands:n})=>{let o=Ve(e,r.schema);return Ln(r,o,t)?n.lift(o):n.wrapIn(o,t)},_d=()=>({state:e,dispatch:t})=>{let r=e.plugins;for(let n=0;n<r.length;n+=1){let o=r[n],a;if(o.spec.isInputRules&&(a=o.getState(e))){if(t){let s=e.tr,l=a.transform;for(let i=l.steps.length-1;i>=0;i-=1)s.step(l.steps[i].invert(l.docs[i]));if(a.text){let i=s.doc.resolve(a.from).marks();s.replaceWith(a.from,a.to,e.schema.text(a.text,i));}else s.delete(a.from,a.to);}return true}}return false},Hd=()=>({tr:e,dispatch:t})=>{let{selection:r}=e,{empty:n,ranges:o}=r;return n||t&&o.forEach(a=>{e.removeMark(a.$from.pos,a.$to.pos);}),true},Od=(e,t={})=>({tr:r,state:n,dispatch:o})=>{var a;let{extendEmptyMarkRange:s=false}=t,{selection:l}=r,i=ht(e,n.schema),{$from:d,empty:m,ranges:u}=l;if(!o)return true;if(m&&s){let{from:p,to:c}=l,h=(a=d.marks().find(g=>g.type===i))==null?void 0:a.attrs,f=Aa(d,i,h);f&&(p=f.from,c=f.to),r.removeMark(p,c,i);}else u.forEach(p=>{r.removeMark(p.$from.pos,p.$to.pos,i);});return r.removeStoredMark(i),true},Fd=e=>({tr:t,state:r,dispatch:n})=>{let{selection:o}=r,a,s;return typeof e=="number"?(a=e,s=e):e&&"from"in e&&"to"in e?(a=e.from,s=e.to):(a=o.from,s=o.to),n&&t.doc.nodesBetween(a,s,(l,i)=>{if(l.isText)return;let d={...l.attrs};delete d.dir,t.setNodeMarkup(i,void 0,d);}),true},$d=(e,t={})=>({tr:r,state:n,dispatch:o})=>{let a=null,s=null,l=_a(typeof e=="string"?e:e.name,n.schema);if(!l)return false;l==="node"&&(a=Ve(e,n.schema)),l==="mark"&&(s=ht(e,n.schema));let i=false;return r.selection.ranges.forEach(d=>{let m=d.$from.pos,u=d.$to.pos,p,c,h,f;r.selection.empty?n.doc.nodesBetween(m,u,(g,b)=>{a&&a===g.type&&(i=true,h=Math.max(b,m),f=Math.min(b+g.nodeSize,u),p=b,c=g);}):n.doc.nodesBetween(m,u,(g,b)=>{b<m&&a&&a===g.type&&(i=true,h=Math.max(b,m),f=Math.min(b+g.nodeSize,u),p=b,c=g),b>=m&&b<=u&&(a&&a===g.type&&(i=true,o&&r.setNodeMarkup(b,void 0,{...g.attrs,...t})),s&&g.marks.length&&g.marks.forEach(w=>{if(s===w.type&&(i=true,o)){let C=Math.max(b,m),x=Math.min(b+g.nodeSize,u);r.addMark(C,x,s.create({...w.attrs,...t}));}}));}),c&&(p!==void 0&&o&&r.setNodeMarkup(p,void 0,{...c.attrs,...t}),s&&c.marks.length&&c.marks.forEach(g=>{s===g.type&&o&&r.addMark(h,f,s.create({...g.attrs,...t}));}));}),i},Vd=(e,t={})=>({state:r,dispatch:n})=>{let o=Ve(e,r.schema);return commands.wrapIn(o,t)(r,n)},Ud=(e,t={})=>({state:r,dispatch:n})=>{let o=Ve(e,r.schema);return schemaList.wrapInList(o,t)(r,n)};function Gd(e){return Object.prototype.toString.call(e).slice(8,-1)}function Or(e){return Gd(e)!=="Object"?false:e.constructor===Object&&Object.getPrototypeOf(e)===Object.prototype}function Va(e,t){let r={...e};return Or(e)&&Or(t)&&Object.keys(t).forEach(n=>{Or(t[n])&&Or(e[n])?r[n]=Va(e[n],t[n]):r[n]=t[n];}),r}var Hn=class{constructor(e={}){this.type="extendable",this.parent=null,this.child=null,this.name="",this.config={name:this.name},this.config={...this.config,...e},this.name=this.config.name;}get options(){return {...Ce(U(this,"addOptions",{name:this.name}))||{}}}get storage(){return {...Ce(U(this,"addStorage",{name:this.name,options:this.options}))||{}}}configure(e={}){let t=this.extend({...this.config,addOptions:()=>Va(this.options,e)});return t.name=this.name,t.parent=this.parent,t}extend(e={}){let t=new this.constructor({...this.config,...e});return t.parent=this,this.child=t,t.name="name"in e?e.name:t.parent.name,t}},On=class ja extends Hn{constructor(){super(...arguments),this.type="mark";}static create(t={}){let r=typeof t=="function"?t():t;return new ja(r)}static handleExit({editor:t,mark:r}){let{tr:n}=t.state,o=t.state.selection.$from;if(o.pos===o.end()){let s=o.marks();if(!!!s.find(d=>d?.type.name===r.name))return false;let i=s.find(d=>d?.type.name===r.name);return i&&n.removeStoredMark(i),n.insertText(" ",o.pos),t.view.dispatch(n),true}return false}configure(t){return super.configure(t)}extend(t){let r=typeof t=="function"?t():t;return super.extend(r)}};var ou={};Dn(ou,{ClipboardTextSerializer:()=>iu,Commands:()=>lu,Delete:()=>du,Drop:()=>mu,Editable:()=>gu,FocusEvents:()=>yu,Keymap:()=>ku,Paste:()=>Cu,Tabindex:()=>Eu,TextDirection:()=>Du,focusEventsPluginKey:()=>Ka});var Me=class Ua extends Hn{constructor(){super(...arguments),this.type="extension";}static create(t={}){let r=typeof t=="function"?t():t;return new Ua(r)}configure(t){return super.configure(t)}extend(t){let r=typeof t=="function"?t():t;return super.extend(r)}},iu=Me.create({name:"clipboardTextSerializer",addOptions(){return {blockSeparator:void 0}},addProseMirrorPlugins(){return [new state.Plugin({key:new state.PluginKey("clipboardTextSerializer"),props:{clipboardTextSerializer:()=>{let{editor:e}=this,{state:t,schema:r}=e,{doc:n,selection:o}=t,{ranges:a}=o,s=Math.min(...a.map(m=>m.$from.pos)),l=Math.max(...a.map(m=>m.$to.pos)),i=cd(r);return ld(n,{from:s,to:l},{...this.options.blockSeparator!==void 0?{blockSeparator:this.options.blockSeparator}:{},textSerializers:i})}}})]}}),lu=Me.create({name:"commands",addCommands(){return {...Ra}}}),du=Me.create({name:"delete",onUpdate({transaction:e,appendedTransactions:t}){var r,n,o;let a=()=>{var s,l,i,d;if((d=(i=(l=(s=this.editor.options.coreExtensionOptions)==null?void 0:s.delete)==null?void 0:l.filterTransaction)==null?void 0:i.call(l,e))!=null?d:e.getMeta("y-sync$"))return;let m=Jc(e.before,[e,...t]);pd(m).forEach(c=>{m.mapping.mapResult(c.oldRange.from).deletedAfter&&m.mapping.mapResult(c.oldRange.to).deletedBefore&&m.before.nodesBetween(c.oldRange.from,c.oldRange.to,(h,f)=>{let g=f+h.nodeSize-2,b=c.oldRange.from<=f&&g<=c.oldRange.to;this.editor.emit("delete",{type:"node",node:h,from:f,to:g,newFrom:m.mapping.map(f),newTo:m.mapping.map(g),deletedRange:c.oldRange,newRange:c.newRange,partial:!b,editor:this.editor,transaction:e,combinedTransform:m});});});let p=m.mapping;m.steps.forEach((c,h)=>{var f,g;if(c instanceof transform.RemoveMarkStep){let b=p.slice(h).map(c.from,-1),w=p.slice(h).map(c.to),C=p.invert().map(b,-1),x=p.invert().map(w),M=(f=m.doc.nodeAt(b-1))==null?void 0:f.marks.some(P=>P.eq(c.mark)),F=(g=m.doc.nodeAt(w))==null?void 0:g.marks.some(P=>P.eq(c.mark));this.editor.emit("delete",{type:"mark",mark:c.mark,from:c.from,to:c.to,deletedRange:{from:C,to:x},newRange:{from:b,to:w},partial:!!(F||M),editor:this.editor,transaction:e,combinedTransform:m});}});};(o=(n=(r=this.editor.options.coreExtensionOptions)==null?void 0:r.delete)==null?void 0:n.async)==null||o?setTimeout(a,0):a();}}),mu=Me.create({name:"drop",addProseMirrorPlugins(){return [new state.Plugin({key:new state.PluginKey("tiptapDrop"),props:{handleDrop:(e,t,r,n)=>{this.editor.emit("drop",{editor:this.editor,event:t,slice:r,moved:n});}}})]}}),gu=Me.create({name:"editable",addProseMirrorPlugins(){return [new state.Plugin({key:new state.PluginKey("editable"),props:{editable:()=>this.editor.options.editable}})]}}),Ka=new state.PluginKey("focusEvents"),yu=Me.create({name:"focusEvents",addProseMirrorPlugins(){let{editor:e}=this;return [new state.Plugin({key:Ka,props:{handleDOMEvents:{focus:(t,r)=>{e.isFocused=true;let n=e.state.tr.setMeta("focus",{event:r}).setMeta("addToHistory",false);return t.dispatch(n),false},blur:(t,r)=>{e.isFocused=false;let n=e.state.tr.setMeta("blur",{event:r}).setMeta("addToHistory",false);return t.dispatch(n),false}}}})]}}),ku=Me.create({name:"keymap",addKeyboardShortcuts(){let e=()=>this.editor.commands.first(({commands:s})=>[()=>s.undoInputRule(),()=>s.command(({tr:l})=>{let{selection:i,doc:d}=l,{empty:m,$anchor:u}=i,{pos:p,parent:c}=u,h=u.parent.isTextblock&&p>0?l.doc.resolve(p-1):u,f=h.parent.type.spec.isolating,g=u.pos-u.parentOffset,b=f&&h.parent.childCount===1?g===u.pos:state.Selection.atStart(d).from===p;return !m||!c.type.isTextblock||c.textContent.length||!b||b&&u.parent.type.name==="paragraph"?false:s.clearNodes()}),()=>s.deleteSelection(),()=>s.joinBackward(),()=>s.selectNodeBackward()]),t=()=>this.editor.commands.first(({commands:s})=>[()=>s.deleteSelection(),()=>s.deleteCurrentNode(),()=>s.joinForward(),()=>s.selectNodeForward()]),n={Enter:()=>this.editor.commands.first(({commands:s})=>[()=>s.newlineInCode(),()=>s.createParagraphNear(),()=>s.liftEmptyBlock(),()=>s.splitBlock()]),"Mod-Enter":()=>this.editor.commands.exitCode(),Backspace:e,"Mod-Backspace":e,"Shift-Backspace":e,Delete:t,"Mod-Delete":t,"Mod-a":()=>this.editor.commands.selectAll()},o={...n},a={...n,"Ctrl-h":e,"Alt-Backspace":e,"Ctrl-d":t,"Ctrl-Alt-Backspace":t,"Alt-Delete":t,"Alt-d":t,"Ctrl-a":()=>this.editor.commands.selectTextblockStart(),"Ctrl-e":()=>this.editor.commands.selectTextblockEnd()};return Vr()||Ia()?a:o},addProseMirrorPlugins(){return [new state.Plugin({key:new state.PluginKey("clearDocument"),appendTransaction:(e,t,r)=>{if(e.some(f=>f.getMeta("composition")))return;let n=e.some(f=>f.docChanged)&&!t.doc.eq(r.doc),o=e.some(f=>f.getMeta("preventClearDocument"));if(!n||o)return;let{empty:a,from:s,to:l}=t.selection,i=state.Selection.atStart(t.doc).from,d=state.Selection.atEnd(t.doc).to;if(a||!(s===i&&l===d)||!$a(r.doc))return;let p=r.tr,c=Ur({state:r,transaction:p}),{commands:h}=new An({editor:this.editor,state:c});if(h.clearNodes(),!!p.steps.length)return p}})]}}),Cu=Me.create({name:"paste",addProseMirrorPlugins(){return [new state.Plugin({key:new state.PluginKey("tiptapPaste"),props:{handlePaste:(e,t,r)=>{this.editor.emit("paste",{editor:this.editor,event:t,slice:r});}}})]}}),Eu=Me.create({name:"tabindex",addProseMirrorPlugins(){return [new state.Plugin({key:new state.PluginKey("tabindex"),props:{attributes:()=>this.editor.isEditable?{tabindex:"0"}:{}}})]}}),Du=Me.create({name:"textDirection",addOptions(){return {direction:void 0}},addGlobalAttributes(){if(!this.options.direction)return [];let{nodeExtensions:e}=Jt(this.extensions);return [{types:e.filter(t=>t.name!=="text").map(t=>t.name),attributes:{dir:{default:this.options.direction,parseHTML:t=>{let r=t.getAttribute("dir");return r&&(r==="ltr"||r==="rtl"||r==="auto")?r:this.options.direction},renderHTML:t=>t.dir?{dir:t.dir}:{}}}}]},addProseMirrorPlugins(){return [new state.Plugin({key:new state.PluginKey("textDirection"),props:{attributes:()=>{let e=this.options.direction;return e?{dir:e}:{}}}})]}});var Au={};Dn(Au,{createAtomBlockMarkdownSpec:()=>zu,createBlockMarkdownSpec:()=>Lu,createInlineMarkdownSpec:()=>Hu,parseAttributes:()=>$n,parseIndentedBlocks:()=>Ou,renderNestedMarkdownContent:()=>Fu,serializeAttributes:()=>Bn});function $n(e){if(!e?.trim())return {};let t={},r=[],n=e.replace(/["']([^"']*)["']/g,d=>(r.push(d),`__QUOTED_${r.length-1}__`)),o=n.match(/(?:^|\s)\.([a-zA-Z][\w-]*)/g);if(o){let d=o.map(m=>m.trim().slice(1));t.class=d.join(" ");}let a=n.match(/(?:^|\s)#([a-zA-Z][\w-]*)/);a&&(t.id=a[1]);let s=/([a-zA-Z][\w-]*)\s*=\s*(__QUOTED_\d+__)/g;Array.from(n.matchAll(s)).forEach(([,d,m])=>{var u;let p=parseInt(((u=m.match(/__QUOTED_(\d+)__/))==null?void 0:u[1])||"0",10),c=r[p];c&&(t[d]=c.slice(1,-1));});let i=n.replace(/(?:^|\s)\.([a-zA-Z][\w-]*)/g,"").replace(/(?:^|\s)#([a-zA-Z][\w-]*)/g,"").replace(/([a-zA-Z][\w-]*)\s*=\s*__QUOTED_\d+__/g,"").trim();return i&&i.split(/\s+/).filter(Boolean).forEach(m=>{m.match(/^[a-zA-Z][\w-]*$/)&&(t[m]=true);}),t}function Bn(e){if(!e||Object.keys(e).length===0)return "";let t=[];return e.class&&String(e.class).split(/\s+/).filter(Boolean).forEach(n=>t.push(`.${n}`)),e.id&&t.push(`#${e.id}`),Object.entries(e).forEach(([r,n])=>{r==="class"||r==="id"||(n===true?t.push(r):n!==false&&n!=null&&t.push(`${r}="${String(n)}"`));}),t.join(" ")}function zu(e){let{nodeName:t,name:r,parseAttributes:n=$n,serializeAttributes:o=Bn,defaultAttributes:a={},requiredAttributes:s=[],allowedAttributes:l}=e,i=r||t,d=m=>{if(!l)return m;let u={};return l.forEach(p=>{p in m&&(u[p]=m[p]);}),u};return {parseMarkdown:(m,u)=>{let p={...a,...m.attributes};return u.createNode(t,p,[])},markdownTokenizer:{name:t,level:"block",start(m){var u;let p=new RegExp(`^:::${i}(?:\\s|$)`,"m"),c=(u=m.match(p))==null?void 0:u.index;return c!==void 0?c:-1},tokenize(m,u,p){let c=new RegExp(`^:::${i}(?:\\s+\\{([^}]*)\\})?\\s*:::(?:\\n|$)`),h=m.match(c);if(!h)return;let f=h[1]||"",g=n(f);if(!s.find(w=>!(w in g)))return {type:t,raw:h[0],attributes:g}}},renderMarkdown:m=>{let u=d(m.attrs||{}),p=o(u),c=p?` {${p}}`:"";return `:::${i}${c} :::`}}}function Lu(e){let{nodeName:t,name:r,getContent:n,parseAttributes:o=$n,serializeAttributes:a=Bn,defaultAttributes:s={},content:l="block",allowedAttributes:i}=e,d=r||t,m=u=>{if(!i)return u;let p={};return i.forEach(c=>{c in u&&(p[c]=u[c]);}),p};return {parseMarkdown:(u,p)=>{let c;if(n){let f=n(u);c=typeof f=="string"?[{type:"text",text:f}]:f;}else l==="block"?c=p.parseChildren(u.tokens||[]):c=p.parseInline(u.tokens||[]);let h={...s,...u.attributes};return p.createNode(t,h,c)},markdownTokenizer:{name:t,level:"block",start(u){var p;let c=new RegExp(`^:::${d}`,"m"),h=(p=u.match(c))==null?void 0:p.index;return h!==void 0?h:-1},tokenize(u,p,c){var h;let f=new RegExp(`^:::${d}(?:\\s+\\{([^}]*)\\})?\\s*\\n`),g=u.match(f);if(!g)return;let[b,w=""]=g,C=o(w),x=1,M=b.length,F="",P=/^:::([\w-]*)(\s.*)?/gm,L=u.slice(M);for(P.lastIndex=0;;){let H=P.exec(L);if(H===null)break;let R=H.index,y=H[1];if(!((h=H[2])!=null&&h.endsWith(":::"))){if(y)x+=1;else if(x-=1,x===0){let _=L.slice(0,R);F=_.trim();let X=u.slice(0,M+R+H[0].length),z=[];if(F)if(l==="block")for(z=c.blockTokens(_),z.forEach(Y=>{Y.text&&(!Y.tokens||Y.tokens.length===0)&&(Y.tokens=c.inlineTokens(Y.text));});z.length>0;){let Y=z[z.length-1];if(Y.type==="paragraph"&&(!Y.text||Y.text.trim()===""))z.pop();else break}else z=c.inlineTokens(F);return {type:t,raw:X,attributes:C,content:F,tokens:z}}}}}},renderMarkdown:(u,p)=>{let c=m(u.attrs||{}),h=a(c),f=h?` {${h}}`:"",g=p.renderChildren(u.content||[],`
|
|
86
|
+
|
|
87
|
+
`);return `:::${d}${f}
|
|
88
|
+
|
|
89
|
+
${g}
|
|
90
|
+
|
|
91
|
+
:::`}}}function Iu(e){if(!e.trim())return {};let t={},r=/(\w+)=(?:"([^"]*)"|'([^']*)')/g,n=r.exec(e);for(;n!==null;){let[,o,a,s]=n;t[o]=a||s,n=r.exec(e);}return t}function _u(e){return Object.entries(e).filter(([,t])=>t!=null).map(([t,r])=>`${t}="${r}"`).join(" ")}function Hu(e){let{nodeName:t,name:r,getContent:n,parseAttributes:o=Iu,serializeAttributes:a=_u,defaultAttributes:s={},selfClosing:l=false,allowedAttributes:i}=e,d=r||t,m=p=>{if(!i)return p;let c={};return i.forEach(h=>{let f=typeof h=="string"?h:h.name,g=typeof h=="string"?void 0:h.skipIfDefault;if(f in p){let b=p[f];if(g!==void 0&&b===g)return;c[f]=b;}}),c},u=d.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");return {parseMarkdown:(p,c)=>{let h={...s,...p.attributes};if(l)return c.createNode(t,h);let f=n?n(p):p.content||"";return f?c.createNode(t,h,[c.createTextNode(f)]):c.createNode(t,h,[])},markdownTokenizer:{name:t,level:"inline",start(p){let c=l?new RegExp(`\\[${u}\\s*[^\\]]*\\]`):new RegExp(`\\[${u}\\s*[^\\]]*\\][\\s\\S]*?\\[\\/${u}\\]`),h=p.match(c),f=h?.index;return f!==void 0?f:-1},tokenize(p,c,h){let f=l?new RegExp(`^\\[${u}\\s*([^\\]]*)\\]`):new RegExp(`^\\[${u}\\s*([^\\]]*)\\]([\\s\\S]*?)\\[\\/${u}\\]`),g=p.match(f);if(!g)return;let b="",w="";if(l){let[,x]=g;w=x;}else {let[,x,M]=g;w=x,b=M||"";}let C=o(w.trim());return {type:t,raw:g[0],content:b.trim(),attributes:C}}},renderMarkdown:p=>{let c="";n?c=n(p):p.content&&p.content.length>0&&(c=p.content.filter(b=>b.type==="text").map(b=>b.text).join(""));let h=m(p.attrs||{}),f=a(h),g=f?` ${f}`:"";return l?`[${d}${g}]`:`[${d}${g}]${c}[/${d}]`}}}function Ou(e,t,r){var n,o,a,s;let l=e.split(`
|
|
92
|
+
`),i=[],d="",m=0,u=t.baseIndentSize||2;for(;m<l.length;){let p=l[m],c=p.match(t.itemPattern);if(!c){if(i.length>0)break;if(p.trim()===""){m+=1,d=`${d}${p}
|
|
93
|
+
`;continue}else return}let h=t.extractItemData(c),{indentLevel:f,mainContent:g}=h;d=`${d}${p}
|
|
94
|
+
`;let b=[g];for(m+=1;m<l.length;){let M=l[m];if(M.trim()===""){let P=l.slice(m+1).findIndex(R=>R.trim()!=="");if(P===-1)break;if((((o=(n=l[m+1+P].match(/^(\s*)/))==null?void 0:n[1])==null?void 0:o.length)||0)>f){b.push(M),d=`${d}${M}
|
|
95
|
+
`,m+=1;continue}else break}if((((s=(a=M.match(/^(\s*)/))==null?void 0:a[1])==null?void 0:s.length)||0)>f)b.push(M),d=`${d}${M}
|
|
96
|
+
`,m+=1;else break}let w,C=b.slice(1);if(C.length>0){let M=C.map(F=>F.slice(f+u)).join(`
|
|
97
|
+
`);M.trim()&&(t.customNestedParser?w=t.customNestedParser(M):w=r.blockTokens(M));}let x=t.createToken(h,w);i.push(x);}if(i.length!==0)return {items:i,raw:d}}function Fu(e,t,r,n){if(!e||!Array.isArray(e.content))return "";let o=typeof r=="function"?r(n):r,[a,...s]=e.content,l=t.renderChildren([a]),i=`${o}${l}`;return s&&s.length>0&&s.forEach((d,m)=>{var u,p;let c=(p=(u=t.renderChild)==null?void 0:u.call(t,d,m+1))!=null?p:t.renderChildren([d]);if(c!=null){let h=c.split(`
|
|
98
|
+
`).map(f=>f?t.indent(f):t.indent("")).join(`
|
|
99
|
+
`);i+=d.type==="paragraph"?`
|
|
100
|
+
|
|
101
|
+
${h}`:`
|
|
102
|
+
${h}`;}}),i}var Vn=class Wa extends Hn{constructor(){super(...arguments),this.type="node";}static create(t={}){let r=typeof t=="function"?t():t;return new Wa(r)}configure(t){return super.configure(t)}extend(t){let r=typeof t=="function"?t():t;return super.extend(r)}};var Bu=20,Ya=(e,t=0)=>{let r=[];return !e.children.length||t>Bu||Array.from(e.children).forEach(n=>{n.tagName==="SPAN"?r.push(n):n.children.length&&r.push(...Ya(n,t+1));}),r},Vu=e=>{if(!e.children.length)return;let t=Ya(e);t&&t.forEach(r=>{var n,o;let a=r.getAttribute("style"),s=(o=(n=r.parentElement)==null?void 0:n.closest("span"))==null?void 0:o.getAttribute("style");r.setAttribute("style",`${s};${a}`);});},jn=On.create({name:"textStyle",priority:101,addOptions(){return {HTMLAttributes:{},mergeNestedSpanStyles:true}},parseHTML(){return [{tag:"span",consuming:false,getAttrs:e=>e.hasAttribute("style")?(this.options.mergeNestedSpanStyles&&Vu(e),{}):false}]},renderHTML({HTMLAttributes:e}){return ["span",Qt(this.options.HTMLAttributes,e),0]},addCommands(){return {toggleTextStyle:e=>({commands:t})=>t.toggleMark(this.name,e),removeEmptyTextStyle:()=>({tr:e})=>{let{selection:t}=e;return e.doc.nodesBetween(t.from,t.to,(r,n)=>{if(r.isTextblock)return true;r.marks.filter(o=>o.type===this.type).some(o=>Object.values(o.attrs).some(a=>!!a))||e.removeMark(n,n+r.nodeSize,this.type);}),true}}}}),ju=Me.create({name:"backgroundColor",addOptions(){return {types:["textStyle"]}},addGlobalAttributes(){return [{types:this.options.types,attributes:{backgroundColor:{default:null,parseHTML:e=>{var t;let r=e.getAttribute("style");if(r){let n=r.split(";").map(o=>o.trim()).filter(Boolean);for(let o=n.length-1;o>=0;o-=1){let a=n[o].split(":");if(a.length>=2){let s=a[0].trim().toLowerCase(),l=a.slice(1).join(":").trim();if(s==="background-color")return l.replace(/['"]+/g,"")}}}return (t=e.style.backgroundColor)==null?void 0:t.replace(/['"]+/g,"")},renderHTML:e=>e.backgroundColor?{style:`background-color: ${e.backgroundColor}`}:{}}}}]},addCommands(){return {setBackgroundColor:e=>({chain:t})=>t().setMark("textStyle",{backgroundColor:e}).run(),unsetBackgroundColor:()=>({chain:e})=>e().setMark("textStyle",{backgroundColor:null}).removeEmptyTextStyle().run()}}}),Uu=Me.create({name:"color",addOptions(){return {types:["textStyle"]}},addGlobalAttributes(){return [{types:this.options.types,attributes:{color:{default:null,parseHTML:e=>{var t;let r=e.getAttribute("style");if(r){let n=r.split(";").map(o=>o.trim()).filter(Boolean);for(let o=n.length-1;o>=0;o-=1){let a=n[o].split(":");if(a.length>=2){let s=a[0].trim().toLowerCase(),l=a.slice(1).join(":").trim();if(s==="color")return l.replace(/['"]+/g,"")}}}return (t=e.style.color)==null?void 0:t.replace(/['"]+/g,"")},renderHTML:e=>e.color?{style:`color: ${e.color}`}:{}}}}]},addCommands(){return {setColor:e=>({chain:t})=>t().setMark("textStyle",{color:e}).run(),unsetColor:()=>({chain:e})=>e().setMark("textStyle",{color:null}).removeEmptyTextStyle().run()}}}),Ku=Me.create({name:"fontFamily",addOptions(){return {types:["textStyle"]}},addGlobalAttributes(){return [{types:this.options.types,attributes:{fontFamily:{default:null,parseHTML:e=>e.style.fontFamily,renderHTML:e=>e.fontFamily?{style:`font-family: ${e.fontFamily}`}:{}}}}]},addCommands(){return {setFontFamily:e=>({chain:t})=>t().setMark("textStyle",{fontFamily:e}).run(),unsetFontFamily:()=>({chain:e})=>e().setMark("textStyle",{fontFamily:null}).removeEmptyTextStyle().run()}}}),Wu=Me.create({name:"fontSize",addOptions(){return {types:["textStyle"]}},addGlobalAttributes(){return [{types:this.options.types,attributes:{fontSize:{default:null,parseHTML:e=>e.style.fontSize,renderHTML:e=>e.fontSize?{style:`font-size: ${e.fontSize}`}:{}}}}]},addCommands(){return {setFontSize:e=>({chain:t})=>t().setMark("textStyle",{fontSize:e}).run(),unsetFontSize:()=>({chain:e})=>e().setMark("textStyle",{fontSize:null}).removeEmptyTextStyle().run()}}}),Yu=Me.create({name:"lineHeight",addOptions(){return {types:["textStyle"]}},addGlobalAttributes(){return [{types:this.options.types,attributes:{lineHeight:{default:null,parseHTML:e=>e.style.lineHeight,renderHTML:e=>e.lineHeight?{style:`line-height: ${e.lineHeight}`}:{}}}}]},addCommands(){return {setLineHeight:e=>({chain:t})=>t().setMark("textStyle",{lineHeight:e}).run(),unsetLineHeight:()=>({chain:e})=>e().setMark("textStyle",{lineHeight:null}).removeEmptyTextStyle().run()}}});Me.create({name:"textStyleKit",addExtensions(){let e=[];return this.options.backgroundColor!==false&&e.push(ju.configure(this.options.backgroundColor)),this.options.color!==false&&e.push(Uu.configure(this.options.color)),this.options.fontFamily!==false&&e.push(Ku.configure(this.options.fontFamily)),this.options.fontSize!==false&&e.push(Wu.configure(this.options.fontSize)),this.options.lineHeight!==false&&e.push(Yu.configure(this.options.lineHeight)),this.options.textStyle!==false&&e.push(jn.configure(this.options.textStyle)),e}});function Xu({node:e,updateAttributes:t,selected:r}){let n=Yr.useRef(null),[o,a]=Yr.useState(false),s=Yr.useRef({x:0,width:0}),{src:l,alt:i,title:d}=e.attrs,m=e.attrs.width;function u(p){p.preventDefault(),p.stopPropagation();let c=n.current?.offsetWidth??(typeof m=="number"?m:200);s.current={x:p.clientX,width:c},a(true);}return Yr.useEffect(()=>{if(!o)return;function p(h){let f=h.clientX-s.current.x,g=Math.max(60,Math.round(s.current.width+f));t({width:g,height:null});}function c(){a(false);}return document.addEventListener("mousemove",p),document.addEventListener("mouseup",c),()=>{document.removeEventListener("mousemove",p),document.removeEventListener("mouseup",c);}},[o,t]),jsxRuntime.jsxs(react.NodeViewWrapper,{as:"span",className:`rte-image-wrapper${r?" rte-image-wrapper--selected":""}`,children:[jsxRuntime.jsx("img",{ref:n,src:l,alt:i??"",title:d??"",draggable:false,style:{display:"block",maxWidth:"100%",width:m?`${m}px`:void 0,cursor:o?"ew-resize":"default"}}),r&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("span",{className:"rte-rh rte-rh--nw"}),jsxRuntime.jsx("span",{className:"rte-rh rte-rh--ne"}),jsxRuntime.jsx("span",{className:"rte-rh rte-rh--sw"}),jsxRuntime.jsx("span",{className:"rte-rh rte-rh--se",onMouseDown:u,title:"Drag to resize",role:"separator","aria-label":"Resize image"}),jsxRuntime.jsx("span",{className:"rte-rh rte-rh--e",onMouseDown:u,title:"Drag to resize",role:"separator","aria-label":"Resize image"}),m&&jsxRuntime.jsxs("span",{className:"rte-image-size-label","aria-live":"polite",children:[m,"px"]})]})]})}var qa=qu__default.default.extend({name:"image",addAttributes(){return {...this.parent?.(),width:{default:null,parseHTML:e=>{let t=e.getAttribute("width");return t?parseInt(t,10):null},renderHTML:e=>e.width?{width:e.width,style:`width:${e.width}px;`}:{}},height:{default:null,parseHTML:e=>{let t=e.getAttribute("height");return t?parseInt(t,10):null},renderHTML:e=>e.height?{height:e.height}:{}}}},addNodeView(){return react.ReactNodeViewRenderer(Xu)}}).configure({inline:true,allowBase64:true});function Gu({node:e,updateAttributes:t,selected:r}){let n=Yr.useRef(null),[o,a]=Yr.useState(false),s=Yr.useRef({x:0,width:0}),{src:l}=e.attrs,i=e.attrs.width;function d(m){m.preventDefault(),m.stopPropagation();let u=n.current?.offsetWidth??(typeof i=="number"?i:320);s.current={x:m.clientX,width:u},a(true);}return Yr.useEffect(()=>{if(!o)return;function m(p){let c=p.clientX-s.current.x,h=Math.max(120,Math.round(s.current.width+c));t({width:h});}function u(){a(false);}return document.addEventListener("mousemove",m),document.addEventListener("mouseup",u),()=>{document.removeEventListener("mousemove",m),document.removeEventListener("mouseup",u);}},[o,t]),jsxRuntime.jsx(react.NodeViewWrapper,{as:"div",className:`rte-video-wrapper${r?" rte-video-wrapper--selected":""}`,children:jsxRuntime.jsxs("div",{ref:n,style:{display:"inline-block",maxWidth:"100%",width:i?`${i}px`:"100%",position:"relative"},children:[jsxRuntime.jsx("video",{src:l,controls:true,style:{display:"block",width:"100%",maxWidth:"100%"}}),r&&jsxRuntime.jsx("span",{className:"rte-rh rte-rh--e",onMouseDown:d,title:"Drag to resize",role:"separator","aria-label":"Resize video"})]})})}var Xa=Vn.create({name:"resizableVideo",group:"block",atom:true,draggable:true,addAttributes(){return {src:{default:null},width:{default:null,parseHTML:e=>{let t=e.getAttribute("data-width");return t?parseInt(t,10):null},renderHTML:e=>e.width?{"data-width":e.width}:{}}}},parseHTML(){return [{tag:"div[data-type=resizable-video]"}]},renderHTML({HTMLAttributes:e}){return ["div",Qt({"data-type":"resizable-video"},e)]},addNodeView(){return react.ReactNodeViewRenderer(Gu)}});function Ju({node:e,updateAttributes:t,selected:r}){let n=Yr.useRef(null),[o,a]=Yr.useState(false),s=Yr.useRef({x:0,width:0}),{src:l}=e.attrs,i=e.attrs.width??480,d=e.attrs.height??Math.round(i*9/16);function m(u){u.preventDefault(),u.stopPropagation();let p=n.current?.offsetWidth??i;s.current={x:u.clientX,width:p},a(true);}return Yr.useEffect(()=>{if(!o)return;function u(c){let h=c.clientX-s.current.x,f=Math.max(160,Math.round(s.current.width+h));t({width:f,height:Math.round(f*9/16)});}function p(){a(false);}return document.addEventListener("mousemove",u),document.addEventListener("mouseup",p),()=>{document.removeEventListener("mousemove",u),document.removeEventListener("mouseup",p);}},[o,t]),jsxRuntime.jsx(react.NodeViewWrapper,{as:"div",className:`rte-embed-wrapper${r?" rte-embed-wrapper--selected":""}`,children:jsxRuntime.jsxs("div",{ref:n,style:{display:"inline-block",position:"relative",width:`${i}px`,maxWidth:"100%"},children:[jsxRuntime.jsx("iframe",{src:l,width:i,height:d,allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; fullscreen",sandbox:"allow-scripts allow-same-origin allow-popups allow-presentation",title:"Embedded video",style:{display:"block",border:"none",maxWidth:"100%"}}),r&&jsxRuntime.jsx("span",{className:"rte-rh rte-rh--e",onMouseDown:m,title:"Drag to resize",role:"separator","aria-label":"Resize embed"})]})})}var Ga=Vn.create({name:"embedFrame",group:"block",atom:true,draggable:true,addAttributes(){return {src:{default:null},width:{default:480},height:{default:270}}},parseHTML(){return [{tag:"div[data-type=embed-frame]"}]},renderHTML({HTMLAttributes:e}){return ["div",Qt({"data-type":"embed-frame"},e)]},addNodeView(){return react.ReactNodeViewRenderer(Ju)}});function pr(e){return marked.marked.parse(e,{async:false})}function Kr(e){return e.replace(/<h1[^>]*>([\s\S]*?)<\/h1>/gi,`# $1
|
|
103
|
+
|
|
104
|
+
`).replace(/<h2[^>]*>([\s\S]*?)<\/h2>/gi,`## $1
|
|
105
|
+
|
|
106
|
+
`).replace(/<h3[^>]*>([\s\S]*?)<\/h3>/gi,`### $1
|
|
107
|
+
|
|
108
|
+
`).replace(/<h4[^>]*>([\s\S]*?)<\/h4>/gi,`#### $1
|
|
109
|
+
|
|
110
|
+
`).replace(/<h5[^>]*>([\s\S]*?)<\/h5>/gi,`##### $1
|
|
111
|
+
|
|
112
|
+
`).replace(/<h6[^>]*>([\s\S]*?)<\/h6>/gi,`###### $1
|
|
113
|
+
|
|
114
|
+
`).replace(/<blockquote[^>]*>([\s\S]*?)<\/blockquote>/gi,(t,r)=>r.trim().replace(/^/gm,"> ")+`
|
|
115
|
+
|
|
116
|
+
`).replace(/<pre[^>]*><code[^>]*>([\s\S]*?)<\/code><\/pre>/gi,"```\n$1\n```\n\n").replace(/<hr\s*\/?>/gi,`
|
|
117
|
+
---
|
|
118
|
+
|
|
119
|
+
`).replace(/<li[^>]*>([\s\S]*?)<\/li>/gi,`- $1
|
|
120
|
+
`).replace(/<\/?(ul|ol)[^>]*>/gi,`
|
|
121
|
+
`).replace(/<strong[^>]*>([\s\S]*?)<\/strong>/gi,"**$1**").replace(/<b[^>]*>([\s\S]*?)<\/b>/gi,"**$1**").replace(/<em[^>]*>([\s\S]*?)<\/em>/gi,"_$1_").replace(/<i[^>]*>([\s\S]*?)<\/i>/gi,"_$1_").replace(/<s[^>]*>([\s\S]*?)<\/s>/gi,"~~$1~~").replace(/<del[^>]*>([\s\S]*?)<\/del>/gi,"~~$1~~").replace(/<code[^>]*>([\s\S]*?)<\/code>/gi,"`$1`").replace(/<a[^>]*href="([^"]*)"[^>]*>([\s\S]*?)<\/a>/gi,"[$2]($1)").replace(/<img[^>]*src="([^"]*)"[^>]*alt="([^"]*)"[^>]*\/?>/gi,"").replace(/<img[^>]*src="([^"]*)"[^>]*\/?>/gi,"").replace(/<br\s*\/?>/gi,`
|
|
122
|
+
`).replace(/<p[^>]*>([\s\S]*?)<\/p>/gi,`$1
|
|
123
|
+
|
|
124
|
+
`).replace(/<[^>]+>/g,"").replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,'"').replace(/'/g,"'").replace(/ /g," ").replace(/\n{3,}/g,`
|
|
125
|
+
|
|
126
|
+
`).trim()}function qn(e){return e.trim()?e.trim().split(/\s+/).length:0}function Xn(e,t,r=false){if(!t)return [];let n=[],o=r?"g":"gi",a=t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),s=new RegExp(a,o);return e.descendants((l,i)=>{if(!l.isText||!l.text)return;let d;for(s.lastIndex=0;(d=s.exec(l.text))!==null;)n.push({from:i+d.index,to:i+d.index+d[0].length});}),n}function Wr(e,t,r=false){if(!t)return [];let n=r?"g":"gi",o=t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),a=new RegExp(o,n),s=[],l;for(;(l=a.exec(e))!==null;)s.push([l.index,l.index+l[0].length]);return s}var ot=new state.PluginKey("rteSearch"),xp=Me.create({name:"rteSearch",addProseMirrorPlugins(){return [new state.Plugin({key:ot,state:{init(){return {query:"",caseSensitive:false,currentIndex:0,matches:[]}},apply(e,t){let r=e.getMeta(ot);if(r){let n={...t,...r};return n.matches=Xn(e.doc,n.query,n.caseSensitive),n.currentIndex>=n.matches.length&&(n.currentIndex=0),n}if(e.docChanged&&t.query){let n=Xn(e.doc,t.query,t.caseSensitive),o=Math.min(t.currentIndex,Math.max(0,n.length-1));return {...t,matches:n,currentIndex:o}}return t}},props:{decorations(e){let t=ot.getState(e);if(!t?.query||!t.matches.length)return view.DecorationSet.empty;let r=t.matches.map((n,o)=>view.Decoration.inline(n.from,n.to,{class:o===t.currentIndex?"rte-search-current":"rte-search-match"}));return view.DecorationSet.create(e.doc,r)}}})]}});function Qa(e){return react.useEditor({extensions:[op__default.default,ap__default.default,sp__default.default.configure({types:["heading","paragraph"]}),jn,extensionColor.Color,lp__default.default.configure({multicolor:true}),qa,Xa,Ga,cp__default.default.configure({openOnClick:false}),dp__default.default.configure({width:480,height:320}),up__default.default.configure({placeholder:e.placeholder??"Start typing\u2026"}),pp__default.default,mp__default.default,fp__default.default,hp__default.default,extensionTable.Table.configure({resizable:true}),bp__default.default,vp__default.default,yp__default.default,xp],content:e.defaultValue??"",editable:!e.readOnly,autofocus:e.autoFocus,onUpdate:({editor:r})=>{e.onChange?.({html:r.getHTML(),markdown:"",json:r.getJSON(),text:r.getText()});}})}var mm={tab_home:"Home",tab_insert:"Insert",tab_format:"Format",group_clipboard:"Clipboard",undo:"Undo",redo:"Redo",save:"Save",group_text:"Text",bold:"Bold",italic:"Italic",underline:"Underline",strikethrough:"Strikethrough",group_headings:"Headings",h1:"H1",h2:"H2",h3:"H3",paragraph:"Normal",group_alignment:"Alignment",alignLeft:"Left",alignCenter:"Center",alignRight:"Right",alignJustify:"Justify",group_lists:"Lists",bulletList:"Bullet",orderedList:"Ordered",group_media:"Media",image:"Image",video:"Video",youtube:"Video",group_content:"Content",link:"Link",table:"Table",codeBlock:"Code Block",blockquote:"Quote",divider:"Divider",group_style:"Style",color:"Color",highlight:"Highlight",subscript:"Sub",superscript:"Sup",group_reset:"Reset",clear:"Clear",group_table_rows:"Rows",addRowBefore:"Add Above",addRowAfter:"Add Below",deleteRow:"Del Row",group_table_cols:"Columns",addColBefore:"Add Left",addColAfter:"Add Right",deleteColumn:"Del Col",group_table_cells:"Cells",mergeCells:"Merge",splitCell:"Split",deleteTable:"Del Table"};function gt({icon:e,label:t,onClick:r,disabled:n=false,title:o}){return jsxRuntime.jsxs("button",{type:"button",className:v("rte-tbar-btn",n&&"rte-tbar-btn--disabled"),onClick:r,disabled:n,title:o??t,children:[e,jsxRuntime.jsx("span",{className:"rte-tbar-label",children:t})]})}function fm({editor:e,L:t,readOnly:r}){let[,n]=Yr.useState(0),[o,a]=Yr.useState(null),s=Yr.useRef(null);if(Yr.useEffect(()=>{if(!e)return;let m=()=>n(u=>u+1);return e.on("selectionUpdate",m),e.on("transaction",m),()=>{e.off("selectionUpdate",m),e.off("transaction",m);}},[e]),Yr.useEffect(()=>{if(!o)return;function m(u){s.current&&!s.current.contains(u.target)&&a(null);}return document.addEventListener("mousedown",m),()=>document.removeEventListener("mousedown",m)},[o]),!e||r||!e.isActive("table"))return null;let l=e.can().mergeCells(),i=e.can().splitCell();function d(){i?e.chain().focus().splitCell().run():a(m=>m?null:"col");}return jsxRuntime.jsxs("div",{className:"rte-tablebar",role:"toolbar","aria-label":"Table editing",children:[jsxRuntime.jsx("span",{className:"rte-tbar-group-label",children:t.group_table_rows}),jsxRuntime.jsx(gt,{icon:jsxRuntime.jsx(lucideReact.BetweenHorizontalStart,{size:13}),label:t.addRowBefore,onClick:()=>e.chain().focus().addRowBefore().run()}),jsxRuntime.jsx(gt,{icon:jsxRuntime.jsx(lucideReact.BetweenHorizontalEnd,{size:13}),label:t.addRowAfter,onClick:()=>e.chain().focus().addRowAfter().run()}),jsxRuntime.jsx(gt,{icon:jsxRuntime.jsx(lucideReact.Trash2,{size:13}),label:t.deleteRow,onClick:()=>e.chain().focus().deleteRow().run()}),jsxRuntime.jsx("div",{className:"rte-tbar-sep"}),jsxRuntime.jsx("span",{className:"rte-tbar-group-label",children:t.group_table_cols}),jsxRuntime.jsx(gt,{icon:jsxRuntime.jsx(lucideReact.BetweenVerticalStart,{size:13}),label:t.addColBefore,onClick:()=>e.chain().focus().addColumnBefore().run()}),jsxRuntime.jsx(gt,{icon:jsxRuntime.jsx(lucideReact.BetweenVerticalEnd,{size:13}),label:t.addColAfter,onClick:()=>e.chain().focus().addColumnAfter().run()}),jsxRuntime.jsx(gt,{icon:jsxRuntime.jsx(lucideReact.Trash2,{size:13}),label:t.deleteColumn,onClick:()=>e.chain().focus().deleteColumn().run()}),jsxRuntime.jsx("div",{className:"rte-tbar-sep"}),jsxRuntime.jsx("span",{className:"rte-tbar-group-label",children:t.group_table_cells}),jsxRuntime.jsx(gt,{icon:jsxRuntime.jsx(lucideReact.TableCellsMerge,{size:13}),label:t.mergeCells,onClick:()=>e.chain().focus().mergeCells().run(),disabled:!l,title:l?t.mergeCells:`${t.mergeCells} (Shift+click to select cells)`}),jsxRuntime.jsxs("div",{className:"rte-tbar-split-wrap",ref:s,children:[jsxRuntime.jsx(gt,{icon:jsxRuntime.jsx(lucideReact.TableCellsSplit,{size:13}),label:i?t.splitCell:`${t.splitCell}\u2026`,onClick:d,title:i?t.splitCell:"Split by adding a column or row"}),o&&!i&&jsxRuntime.jsxs("div",{className:"rte-tbar-split-picker",children:[jsxRuntime.jsxs("button",{className:"rte-tbar-split-pick-btn",onClick:()=>{e.chain().focus().addColumnAfter().run(),a(null);},children:[jsxRuntime.jsx(lucideReact.BetweenVerticalEnd,{size:13}),"Split column"]}),jsxRuntime.jsxs("button",{className:"rte-tbar-split-pick-btn",onClick:()=>{e.chain().focus().addRowAfter().run(),a(null);},children:[jsxRuntime.jsx(lucideReact.BetweenHorizontalEnd,{size:13}),"Split row"]})]})]}),jsxRuntime.jsx("div",{className:"rte-tbar-sep"}),jsxRuntime.jsx(gt,{icon:jsxRuntime.jsx(lucideReact.Trash2,{size:13}),label:t.deleteTable,onClick:()=>e.chain().focus().deleteTable().run()})]})}function Jn({open:e,onClose:t,children:r}){let n=Yr.useRef(null);return Yr.useEffect(()=>{if(!e)return;function o(a){n.current&&!n.current.contains(a.target)&&t();}return document.addEventListener("mousedown",o),()=>document.removeEventListener("mousedown",o)},[e,t]),e?jsxRuntime.jsx("div",{ref:n,className:"rte-inline-dialog",children:r}):null}function hm({mode:e,onClose:t,onFind:r,onPrev:n,onNext:o,onReplace:a,onReplaceAll:s,matchCount:l,currentIndex:i}){let[d,m]=Yr__default.default.useState(""),[u,p]=Yr__default.default.useState(""),[c,h]=Yr__default.default.useState(false),f=Yr__default.default.useRef(null);Yr.useEffect(()=>{f.current?.focus();},[]);function g(M){let F=M.target.value;m(F),r(F,c);}function b(){let M=!c;h(M),r(d,M);}function w(M){if(M.key==="Escape"){t();return}M.key==="Enter"&&(M.shiftKey?n():o());}let C=l>0,x=d?C?`${i+1} / ${l}`:"No results":"";return jsxRuntime.jsxs("div",{className:"rte-findbar",role:"search","aria-label":"Find and replace",children:[jsxRuntime.jsxs("div",{className:"rte-findbar-row",children:[jsxRuntime.jsx(lucideReact.Search,{size:14,className:"rte-findbar-icon"}),jsxRuntime.jsx("input",{ref:f,className:"rte-findbar-input",value:d,onChange:g,onKeyDown:w,placeholder:"Find\u2026","aria-label":"Find",spellCheck:false}),jsxRuntime.jsx("button",{className:v("rte-findbar-btn",c&&"rte-findbar-btn--active"),onClick:b,title:"Match case","aria-pressed":c,children:"Aa"}),jsxRuntime.jsx("span",{className:"rte-findbar-count",children:x}),jsxRuntime.jsx("button",{className:"rte-findbar-btn",onClick:n,disabled:!C,title:"Previous match (Shift+Enter)","aria-label":"Previous match",children:jsxRuntime.jsx(lucideReact.ChevronUp,{size:14})}),jsxRuntime.jsx("button",{className:"rte-findbar-btn",onClick:o,disabled:!C,title:"Next match (Enter)","aria-label":"Next match",children:jsxRuntime.jsx(lucideReact.ChevronDown,{size:14})}),jsxRuntime.jsx("button",{className:"rte-findbar-btn rte-findbar-btn--close",onClick:t,title:"Close (Esc)","aria-label":"Close find bar",children:jsxRuntime.jsx(lucideReact.X,{size:14})})]}),e==="replace"&&jsxRuntime.jsxs("div",{className:"rte-findbar-row",children:[jsxRuntime.jsx(lucideReact.Replace,{size:14,className:"rte-findbar-icon"}),jsxRuntime.jsx("input",{className:"rte-findbar-input",value:u,onChange:M=>p(M.target.value),onKeyDown:M=>M.key==="Escape"&&t(),placeholder:"Replace with\u2026","aria-label":"Replace with",spellCheck:false}),jsxRuntime.jsx("button",{className:"rte-findbar-btn rte-findbar-btn--action",onClick:()=>a(u),disabled:!C,title:"Replace current",children:"Replace"}),jsxRuntime.jsx("button",{className:"rte-findbar-btn rte-findbar-btn--action",onClick:()=>s(u),disabled:!C,title:"Replace all",children:"All"})]})]})}var fr=Yr.forwardRef(function(t,r){let{mode:n,defaultMode:o="richtext",onModeChange:a,showPreview:s,defaultShowPreview:l=false,onPreviewChange:i,defaultValue:d="",value:m,onChange:u,placeholder:p="Start typing\u2026",readOnly:c=false,height:h=400,minHeight:f,maxHeight:g,showWordCount:b=true,showCharCount:w=true,onImageUpload:C,allowedImageTypes:x,maxImageSize:M,autoFocus:F=false,spellCheck:P=true,className:L,style:H,labels:R,extraRibbonGroups:y,extraRibbonTabs:_,onSave:X}=t,z={...mm,...R},[Y,ge]=Yr.useState(o),E=n??Y;function ye(D){if(D!==E){if(D==="markdown"){let I=N?.getHTML()??le;ae(Kr(I));}else {let I=pr(O);te(I),N?.commands.setContent(I);}n===void 0&&ge(D),a?.(D);}}let[fe,Ne]=Yr.useState(()=>typeof window<"u"?window.matchMedia("(prefers-color-scheme: dark)").matches:false);function ne(D){Ne(D),D?document.documentElement.classList.add("dark"):document.documentElement.classList.remove("dark");}Yr.useEffect(()=>{ne(fe);let D=window.matchMedia("(prefers-color-scheme: dark)");function I(ue){Ne(ue.matches),ne(ue.matches);}return D.addEventListener("change",I),()=>D.removeEventListener("change",I)},[]);let[Te,K]=Yr.useState(l),Ee=s??Te;function We(D){let I=D??!Ee;s===void 0&&K(I),i?.(I);}let[O,ae]=Yr.useState(E==="markdown"?m??d:""),[le,te]=Yr.useState(E==="richtext"?m??d??"":""),[be,Se]=Yr.useState(false),[De,J]=Yr.useState(""),[at,ce]=Yr.useState(false),[Pe,G]=Yr.useState(""),[he,ke]=Yr.useState(false),[Ze,xe]=Yr.useState(""),[re,Ye]=Yr.useState(null),[ct,it]=Yr.useState(null),[St,Ae]=Yr.useState(0),[_e,T]=Yr.useState(0),[q,de]=Yr.useState(""),A=Yr.useRef(null),oe=Yr.useRef(null),Re=Yr.useRef(null);Yr.useEffect(()=>{function D(I){!(I.metaKey||I.ctrlKey)||I.key.toLowerCase()!=="f"||oe.current?.contains(I.target)&&(I.preventDefault(),I.shiftKey?it(pe=>pe==="replace"?null:"replace"):it(pe=>pe!==null?null:"find"));}return document.addEventListener("keydown",D,true),()=>document.removeEventListener("keydown",D,true)},[]);function et(D){let I=D.trim();if(/\.(mp4|webm|ogg|ogv|mov|m4v|flv|mkv)(\?[^#]*)?$/i.test(I))return {kind:"video"};if(/(?:youtube\.com|youtu\.be|youtube-nocookie\.com)/.test(I))return {kind:"youtube"};let ue=I.match(/vimeo\.com\/(?:video\/)?(\d+)/);if(ue)return {kind:"iframe",embedUrl:`https://player.vimeo.com/video/${ue[1]}`};let pe=I.match(/bilibili\.com\/video\/(BV[\w]+|av\d+)/i);if(pe)return {kind:"iframe",embedUrl:`https://player.bilibili.com/player.html?bvid=${pe[1]}&high_quality=1&danmaku=0`};let Ie=I.match(/dailymotion\.com\/(?:video\/|embed\/video\/)([a-z0-9]+)/i);if(Ie)return {kind:"iframe",embedUrl:`https://www.dailymotion.com/embed/video/${Ie[1]}`};let $e=I.match(/twitch\.tv\/\w+\/clip\/([\w-]+)/);if($e){let Je=typeof window<"u"?window.location.hostname:"localhost";return {kind:"iframe",embedUrl:`https://clips.twitch.tv/embed?clip=${$e[1]}&parent=${Je}`}}return null}function _t(){let D=Ze.trim();if(!D)return;let I=et(D);if(!I){Ye("Unsupported URL. Paste a YouTube, Vimeo, Bilibili, Dailymotion, or direct .mp4/.webm link.");return}I.kind==="youtube"?N?.chain().focus().setYoutubeVideo({src:D}).run():I.kind==="iframe"?N?.chain().focus().insertContent({type:"embedFrame",attrs:{src:I.embedUrl}}).run():N?.chain().focus().insertContent({type:"resizableVideo",attrs:{src:D}}).run(),xe(""),Ye(null),ke(false);}function k(D,I){N&&N.view.dispatch(N.view.state.tr.setMeta(ot,{query:D,caseSensitive:I,currentIndex:0}));}function j(D){if(!N)return;let I=ot.getState(N.view.state);if(!I||!I.matches.length)return;let ue=I.matches.length,pe=((I.currentIndex+D)%ue+ue)%ue;N.view.dispatch(N.view.state.tr.setMeta(ot,{currentIndex:pe}));let Ie=I.matches[pe];Ie&&(N.commands.setTextSelection({from:Ie.from,to:Ie.to}),N.commands.scrollIntoView());}function se(D){if(!N)return;let I=ot.getState(N.view.state);if(!I||!I.matches.length)return;let ue=I.matches[I.currentIndex];ue&&(N.chain().setTextSelection({from:ue.from,to:ue.to}).insertContent(D).run(),k(I.query,I.caseSensitive));}function ie(D){if(!N)return;let I=ot.getState(N.view.state);if(!I||!I.matches.length)return;let ue=N.chain();[...I.matches].reverse().forEach(pe=>{ue.setTextSelection({from:pe.from,to:pe.to}).insertContent(D);}),ue.run(),k(I.query,I.caseSensitive);}function ve(D,I){de(D);let ue=Wr(O,D,I);Ae(ue.length),T(0);}function qe(D,I,ue){let pe=Wr(O,I,ue);if(!pe.length)return;let Ie=pe.length,$e=((_e+D)%Ie+Ie)%Ie;T($e);let Je=Re.current;Je&&(Je.focus(),Je.setSelectionRange(pe[$e][0],pe[$e][1]));}function dt(D,I,ue){let pe=Wr(O,D,ue);if(!pe.length)return;let[Ie,$e]=pe[_e]??pe[0],Je=O.slice(0,Ie)+I+O.slice($e);ae(Je);}function hr(D,I,ue){let pe=D.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),Ie=new RegExp(pe,"gi");ae($e=>$e.replace(Ie,I)),Ae(0),T(0);}let N=Qa({defaultValue:E==="richtext"?m??d:"",placeholder:p,readOnly:c,autoFocus:E==="richtext"&&F,onChange:D=>{te(D.html),u?.({...D,markdown:Kr(D.html)});}});Yr.useEffect(()=>{m!==void 0&&N&&E==="richtext"&&N.getHTML()!==m&&(N.commands.setContent(m),te(m));},[m,N,E]);let ut=N?ot.getState(N.view.state):null,bt=E==="richtext"?ut?.matches.length??0:St,er=E==="richtext"?ut?.currentIndex??0:_e;function Ht(){if(!X)return;let D=E==="markdown"?O:N?.getHTML()??"";X(D,E);}Yr.useEffect(()=>{if(!X)return;function D(I){!(I.metaKey||I.ctrlKey)||I.key.toLowerCase()!=="s"||oe.current?.contains(I.target)&&(I.preventDefault(),Ht());}return document.addEventListener("keydown",D,true),()=>document.removeEventListener("keydown",D,true)},[X,E,O,N]);function Tt(D){let I=D.target.value;ae(I),u?.({html:pr(I),markdown:I,json:{},text:I});}let rs=Yr.useCallback(async D=>{let ue=Array.from(D.clipboardData?.items??[]).find($e=>$e.type.startsWith("image/"));if(!ue)return;D.preventDefault();let pe=ue.getAsFile();if(!pe||x&&!x.includes(pe.type)||M&&pe.size>M)return;let Ie;if(C?Ie=await C(pe):Ie=await new Promise($e=>{let Je=new FileReader;Je.onload=()=>$e(Je.result),Je.readAsDataURL(pe);}),E==="richtext"&&N)N.chain().focus().setImage({src:Ie}).run();else {let $e=D.currentTarget.querySelector(".rte-markdown-source");if($e){let Je=$e.selectionStart,is=``,ls=O.slice(0,Je),cs=O.slice(Je);ae(ls+is+cs);}}},[E,N,O,C,x,M]);Yr.useImperativeHandle(r,()=>({getContent:()=>E==="markdown"?O:N?.getHTML()??"",getMode:()=>E,getHTML:()=>N?.getHTML()??"",getMarkdown:()=>E==="markdown"?O:Kr(N?.getHTML()??""),getJSON:()=>N?.getJSON()??{},getText:()=>N?.getText()??"",setHTML:D=>N?.commands.setContent(D),setMarkdown:D=>{ae(D),N?.commands.setContent(pr(D));},setJSON:D=>N?.commands.setContent(D),clear:()=>{N?.commands.clearContent(),ae("");},focus:()=>N?.commands.focus(),blur:()=>(N?.view.dom).blur()}));let ns=N?.storage?.characterCount?.characters?.()??O.length,os=E==="richtext"?qn(N?.getText()??""):qn(O),as=[...[{key:"home",label:z.tab_home,groups:[{key:"clipboard",label:z.group_clipboard,items:[{key:"undo",label:z.undo,icon:jsxRuntime.jsx(lucideReact.Undo2,{}),disabled:c||!N?.can().undo()||E==="markdown",onClick:()=>N?.chain().focus().undo().run()},{key:"redo",label:z.redo,icon:jsxRuntime.jsx(lucideReact.Redo2,{}),disabled:c||!N?.can().redo()||E==="markdown",onClick:()=>N?.chain().focus().redo().run()},{key:"save",label:z.save,icon:jsxRuntime.jsx(lucideReact.Save,{}),disabled:c||!X,onClick:Ht}]},{key:"text",label:z.group_text,items:[{key:"bold",label:z.bold,icon:jsxRuntime.jsx(lucideReact.Bold,{}),active:N?.isActive("bold"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleBold().run()},{key:"italic",label:z.italic,icon:jsxRuntime.jsx(lucideReact.Italic,{}),active:N?.isActive("italic"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleItalic().run()},{key:"underline",label:z.underline,icon:jsxRuntime.jsx(lucideReact.Underline,{}),active:N?.isActive("underline"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleUnderline().run()},{key:"strike",label:z.strikethrough,icon:jsxRuntime.jsx(lucideReact.Strikethrough,{}),active:N?.isActive("strike"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleStrike().run()}]},{key:"headings",label:z.group_headings,items:[{key:"h1",label:z.h1,icon:jsxRuntime.jsx(lucideReact.Heading1,{}),active:N?.isActive("heading",{level:1}),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleHeading({level:1}).run()},{key:"h2",label:z.h2,icon:jsxRuntime.jsx(lucideReact.Heading2,{}),active:N?.isActive("heading",{level:2}),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleHeading({level:2}).run()},{key:"h3",label:z.h3,icon:jsxRuntime.jsx(lucideReact.Heading3,{}),active:N?.isActive("heading",{level:3}),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleHeading({level:3}).run()},{key:"paragraph",label:z.paragraph,icon:jsxRuntime.jsx(lucideReact.Type,{}),active:N?.isActive("paragraph"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().setParagraph().run()}]},{key:"alignment",label:z.group_alignment,items:[{key:"align-left",label:z.alignLeft,icon:jsxRuntime.jsx(lucideReact.AlignLeft,{}),active:N?.isActive({textAlign:"left"}),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().setTextAlign("left").run()},{key:"align-center",label:z.alignCenter,icon:jsxRuntime.jsx(lucideReact.AlignCenter,{}),active:N?.isActive({textAlign:"center"}),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().setTextAlign("center").run()},{key:"align-right",label:z.alignRight,icon:jsxRuntime.jsx(lucideReact.AlignRight,{}),active:N?.isActive({textAlign:"right"}),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().setTextAlign("right").run()},{key:"align-justify",label:z.alignJustify,icon:jsxRuntime.jsx(lucideReact.AlignJustify,{}),active:N?.isActive({textAlign:"justify"}),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().setTextAlign("justify").run()}]},{key:"lists",label:z.group_lists,items:[{key:"bullet-list",label:z.bulletList,icon:jsxRuntime.jsx(lucideReact.List,{}),active:N?.isActive("bulletList"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleBulletList().run()},{key:"ordered-list",label:z.orderedList,icon:jsxRuntime.jsx(lucideReact.ListOrdered,{}),active:N?.isActive("orderedList"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleOrderedList().run()}]},...y?.home??[]]},{key:"insert",label:z.tab_insert,groups:[{key:"media",label:z.group_media,items:[{key:"image",label:z.image,icon:jsxRuntime.jsx(lucideReact.Image,{}),disabled:c||E==="markdown",onClick:()=>Se(true)},{key:"video",label:z.video??z.youtube,icon:jsxRuntime.jsx(lucideReact.Video,{}),disabled:c||E==="markdown",onClick:()=>{xe(""),Ye(null),ke(true);}}]},{key:"content",label:z.group_content,items:[{key:"link",label:z.link,icon:jsxRuntime.jsx(lucideReact.Link,{}),active:N?.isActive("link"),disabled:c||E==="markdown",onClick:()=>{let D=N?.getAttributes("link").href??"";G(D),ce(true);}},{key:"table",label:z.table,icon:jsxRuntime.jsx(lucideReact.Table,{}),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().insertTable({rows:3,cols:3,withHeaderRow:true}).run()},{key:"code-block",label:z.codeBlock,icon:jsxRuntime.jsx(lucideReact.Code,{}),active:N?.isActive("codeBlock"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleCodeBlock().run()},{key:"blockquote",label:z.blockquote,icon:jsxRuntime.jsx(lucideReact.Quote,{}),active:N?.isActive("blockquote"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleBlockquote().run()},{key:"hr",label:z.divider,icon:jsxRuntime.jsx(lucideReact.Minus,{}),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().setHorizontalRule().run()}]},...y?.insert??[]]},{key:"format",label:z.tab_format,groups:[{key:"style",label:z.group_style,items:[{key:"color",label:z.color,icon:jsxRuntime.jsx(lucideReact.Palette,{}),disabled:c||E==="markdown",onClick:()=>{document.getElementById("rte-color-input")?.click();}},{key:"highlight",label:z.highlight,icon:jsxRuntime.jsx(lucideReact.Highlighter,{}),active:N?.isActive("highlight"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleHighlight().run()},{key:"subscript",label:z.subscript,icon:jsxRuntime.jsx(lucideReact.Subscript,{}),active:N?.isActive("subscript"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleSubscript().run()},{key:"superscript",label:z.superscript,icon:jsxRuntime.jsx(lucideReact.Superscript,{}),active:N?.isActive("superscript"),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().toggleSuperscript().run()}]},{key:"reset",label:z.group_reset,items:[{key:"clear",label:z.clear,icon:jsxRuntime.jsx(lucideReact.Eraser,{}),disabled:c||E==="markdown",onClick:()=>N?.chain().focus().unsetAllMarks().clearNodes().run()}]},...y?.format??[]]}],..._??[]],gr={};h&&(gr.height=typeof h=="number"?`${h}px`:h),f&&(gr.minHeight=typeof f=="number"?`${f}px`:f),g&&(gr.maxHeight=typeof g=="number"?`${g}px`:g);let ss=E==="richtext"?le:pr(O);return jsxRuntime.jsxs("div",{ref:oe,className:v("rte-root",L),style:{...gr,...H},"data-testid":"rte-root",onPaste:rs,children:[jsxRuntime.jsx("input",{id:"rte-color-input",type:"color",className:"sr-only","aria-hidden":true,onChange:D=>{N?.chain().focus().setColor(D.target.value).run();}}),jsxRuntime.jsxs("div",{ref:A,className:"rte-ribbon relative",children:[jsxRuntime.jsx(ha,{tabs:as}),jsxRuntime.jsxs(Jn,{open:be,onClose:()=>Se(false),children:[jsxRuntime.jsx("input",{type:"url",placeholder:"Image URL\u2026",value:De,onChange:D=>J(D.target.value),onKeyDown:D=>{D.key==="Enter"&&(De&&N?.chain().focus().setImage({src:De}).run(),J(""),Se(false));},autoFocus:true}),jsxRuntime.jsx("button",{onClick:()=>{De&&N?.chain().focus().setImage({src:De}).run(),J(""),Se(false);},children:"Insert"}),jsxRuntime.jsx("button",{className:"rte-cancel-btn",onClick:()=>Se(false),children:"Cancel"})]}),jsxRuntime.jsxs(Jn,{open:at,onClose:()=>ce(false),children:[jsxRuntime.jsx("input",{type:"url",placeholder:"https://\u2026",value:Pe,onChange:D=>G(D.target.value),onKeyDown:D=>{D.key==="Enter"&&(N?.chain().focus().setLink({href:Pe}).run(),G(""),ce(false));},autoFocus:true}),jsxRuntime.jsx("button",{onClick:()=>{N?.chain().focus().setLink({href:Pe}).run(),G(""),ce(false);},children:"Apply"}),jsxRuntime.jsx("button",{className:"rte-cancel-btn",onClick:()=>ce(false),children:"Cancel"})]}),jsxRuntime.jsxs(Jn,{open:he,onClose:()=>ke(false),children:[jsxRuntime.jsx("input",{type:"url",placeholder:"YouTube, Vimeo, Bilibili, or .mp4 URL\u2026",value:Ze,onChange:D=>{xe(D.target.value),Ye(null);},onKeyDown:D=>{D.key==="Enter"&&_t();},autoFocus:true,style:{minWidth:280}}),re&&jsxRuntime.jsx("span",{style:{fontSize:"0.72rem",color:"var(--color-danger-500)",flex:"0 0 100%"},children:re}),jsxRuntime.jsx("button",{onClick:_t,children:"Embed"}),jsxRuntime.jsx("button",{className:"rte-cancel-btn",onClick:()=>ke(false),children:"Cancel"})]})]}),E==="richtext"&&jsxRuntime.jsx(fm,{editor:N,L:z,readOnly:c??false}),ct!==null&&jsxRuntime.jsx(hm,{mode:ct,onClose:()=>{it(null),N&&N.view.dispatch(N.view.state.tr.setMeta(ot,{query:"",currentIndex:0,matches:[]})),Ae(0),T(0),de("");},onFind:(D,I)=>{E==="richtext"?k(D,I):ve(D,I);},onPrev:()=>{E==="richtext"?j(-1):qe(-1,q,false);},onNext:()=>{E==="richtext"?j(1):qe(1,q,false);},onReplace:D=>{if(E==="richtext"){let I=N?ot.getState(N.view.state):null;se(D),I&&ve(I.query,I.caseSensitive);}else dt(q,D,false);},onReplaceAll:D=>{E==="richtext"?ie(D):hr(q,D);},matchCount:bt,currentIndex:er}),jsxRuntime.jsxs("div",{className:"rte-body",children:[jsxRuntime.jsx("div",{className:"rte-editor-pane",children:E==="richtext"?jsxRuntime.jsx(react.EditorContent,{editor:N,spellCheck:P,readOnly:c}):jsxRuntime.jsx("textarea",{ref:Re,className:"rte-markdown-source",value:O,onChange:Tt,placeholder:p,readOnly:c,spellCheck:P,"data-testid":"rte-markdown-source"})}),Ee&&jsxRuntime.jsx("div",{className:"rte-preview-pane","data-testid":"rte-preview-pane",children:jsxRuntime.jsx("div",{className:"prose",dangerouslySetInnerHTML:{__html:ss}})})]}),jsxRuntime.jsxs("div",{className:"rte-statusbar",children:[jsxRuntime.jsxs("div",{className:"rte-statusbar-left",children:[jsxRuntime.jsx(Ir,{size:"sm",checked:fe,onCheckedChange:ne,checkedContent:jsxRuntime.jsx(lucideReact.Moon,{size:10}),uncheckedContent:jsxRuntime.jsx(lucideReact.Sun,{size:10}),"aria-label":"Toggle dark mode",title:fe?"Switch to light mode":"Switch to dark mode"}),jsxRuntime.jsx("span",{className:"rte-statusbar-divider"}),jsxRuntime.jsx(Ir,{size:"sm",checked:E==="markdown",onCheckedChange:D=>ye(D?"markdown":"richtext"),disabled:n!==void 0,checkedContent:jsxRuntime.jsx(lucideReact.Code,{size:10}),uncheckedContent:jsxRuntime.jsx(lucideReact.FileText,{size:10}),"aria-label":"Toggle editor mode",title:n!==void 0?`Mode locked: ${E}`:E==="markdown"?"Markdown mode (click for Rich Text)":"Rich Text mode (click for Markdown)"}),jsxRuntime.jsx("span",{className:"rte-statusbar-label",children:E==="markdown"?"Markdown":"Rich Text"})]}),jsxRuntime.jsxs("div",{className:"rte-statusbar-right",children:[jsxRuntime.jsx(Ir,{size:"sm",checked:Ee,onCheckedChange:We,checkedContent:jsxRuntime.jsx(lucideReact.Eye,{size:10}),uncheckedContent:jsxRuntime.jsx(lucideReact.EyeOff,{size:10}),"aria-label":"Toggle live preview",title:Ee?"Hide preview":"Show live preview"}),jsxRuntime.jsx("span",{className:"rte-statusbar-label",children:"Preview"}),(b||w)&&jsxRuntime.jsx("span",{className:"rte-statusbar-divider"}),b&&jsxRuntime.jsxs("span",{children:[os," words"]}),w&&jsxRuntime.jsxs("span",{children:[ns," chars"]})]})]})]})});fr.displayName="RichTextEditor";var gm={FilmReel:Gr,MiniPlayer:Qr,CinePlayer:en,FileExplorer:dn,Masonry:fn,TypewriterText:Sr,CommandPalette:Er,Timeline:bn,DateTimePicker:Rr,LoginPanel:zr,RichTextEditor:fr},Dv=gm;
|
|
127
|
+
exports.CinePlayer=en;exports.CommandPalette=Er;exports.DateTimePicker=Rr;exports.Extras=gm;exports.FileExplorer=dn;exports.FilmReel=Gr;exports.LoginPanel=zr;exports.Masonry=fn;exports.MiniPlayer=Qr;exports.RichTextEditor=fr;exports.Timeline=bn;exports.TypewriterText=Sr;exports.default=Dv;
|