@wyxos/vibe 2.2.4 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (75) hide show
  1. package/README.md +451 -95
  2. package/lib/components/FullscreenHeader.vue.d.ts +25 -0
  3. package/lib/components/FullscreenMediaBar.vue.d.ts +14 -0
  4. package/lib/components/FullscreenSurface.vue.d.ts +46 -0
  5. package/lib/components/Layout.vue.d.ts +42 -0
  6. package/lib/components/ListCard.vue.d.ts +44 -0
  7. package/lib/components/ListSurface.vue.d.ts +64 -0
  8. package/lib/components/viewer-core/assetErrors.d.ts +30 -0
  9. package/lib/components/viewer-core/assetState.d.ts +12 -0
  10. package/lib/components/viewer-core/autoBuckets.d.ts +18 -0
  11. package/lib/components/viewer-core/autoResolveHelpers.d.ts +19 -0
  12. package/lib/components/viewer-core/autoResolveState.d.ts +50 -0
  13. package/lib/components/viewer-core/dom.d.ts +2 -0
  14. package/lib/components/viewer-core/fillDelay.d.ts +9 -0
  15. package/lib/components/viewer-core/format.d.ts +1 -0
  16. package/lib/components/viewer-core/itemIdentity.d.ts +6 -0
  17. package/lib/components/viewer-core/listCardAsset.d.ts +4 -0
  18. package/lib/components/viewer-core/listPreview.d.ts +10 -0
  19. package/lib/components/viewer-core/loadError.d.ts +4 -0
  20. package/lib/components/viewer-core/masonryLayout.d.ts +37 -0
  21. package/lib/components/viewer-core/masonryViewport.d.ts +7 -0
  22. package/lib/components/viewer-core/media.d.ts +4 -0
  23. package/lib/components/viewer-core/mediaPlayback.d.ts +1 -0
  24. package/lib/components/viewer-core/removalState.d.ts +50 -0
  25. package/lib/components/viewer-core/slotContent.d.ts +2 -0
  26. package/lib/components/viewer-core/surfaceSlots.d.ts +22 -0
  27. package/lib/components/viewer-core/theme.d.ts +3 -0
  28. package/lib/components/viewer-core/useActivation.d.ts +8 -0
  29. package/lib/components/viewer-core/useAssetLoadQueue.d.ts +22 -0
  30. package/lib/components/viewer-core/useAutoResolveSource.d.ts +51 -0
  31. package/lib/components/viewer-core/useController.d.ts +71 -0
  32. package/lib/components/viewer-core/useDataSource.d.ts +100 -0
  33. package/lib/components/viewer-core/useEdgeBoundary.d.ts +16 -0
  34. package/lib/components/viewer-core/useFullscreen.d.ts +1 -0
  35. package/lib/components/viewer-core/useMasonryList.d.ts +43 -0
  36. package/lib/components/viewer-core/useMasonryMotion.d.ts +29 -0
  37. package/lib/components/viewer-core/useMedia.d.ts +39 -0
  38. package/lib/components/viewer-core/useViewer.d.ts +61 -0
  39. package/lib/components/viewer-core/virtualization.d.ts +14 -0
  40. package/lib/components/viewer.d.ts +16 -0
  41. package/lib/index.cjs +1 -1
  42. package/lib/index.d.ts +58 -5
  43. package/lib/index.js +3196 -1485
  44. package/lib/style.css +3 -0
  45. package/package.json +86 -83
  46. package/lib/App.vue.d.ts +0 -3
  47. package/lib/apple-touch-icon-114x114.png +0 -0
  48. package/lib/apple-touch-icon-120x120.png +0 -0
  49. package/lib/apple-touch-icon-144x144.png +0 -0
  50. package/lib/apple-touch-icon-152x152.png +0 -0
  51. package/lib/apple-touch-icon-180x180.png +0 -0
  52. package/lib/apple-touch-icon-57x57.png +0 -0
  53. package/lib/apple-touch-icon-60x60.png +0 -0
  54. package/lib/apple-touch-icon-72x72.png +0 -0
  55. package/lib/apple-touch-icon-76x76.png +0 -0
  56. package/lib/components/Masonry.vue.d.ts +0 -68
  57. package/lib/components/MasonryItem.vue.d.ts +0 -3
  58. package/lib/components/MasonryLoader.vue.d.ts +0 -27
  59. package/lib/components/MasonryVideoControls.vue.d.ts +0 -30
  60. package/lib/components/masonryItemRegistry.d.ts +0 -24
  61. package/lib/favicon-128x128.png +0 -0
  62. package/lib/favicon-16x16.png +0 -0
  63. package/lib/favicon-256x256.png +0 -0
  64. package/lib/favicon-32x32.png +0 -0
  65. package/lib/favicon-48x48.png +0 -0
  66. package/lib/favicon-64x64.png +0 -0
  67. package/lib/favicon.ico +0 -0
  68. package/lib/logo-dark.svg +0 -36
  69. package/lib/logo-light.svg +0 -29
  70. package/lib/logo.svg +0 -32
  71. package/lib/manifest.json +0 -41
  72. package/lib/masonry/backfill.d.ts +0 -53
  73. package/lib/masonry/layout.d.ts +0 -13
  74. package/lib/masonry/layoutEngine.d.ts +0 -33
  75. package/lib/masonry/types.d.ts +0 -95
package/lib/index.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("vue"),bt={mode:"default",pageSize:20,backfillRequestDelayMs:2e3,enterStaggerMs:40,page:1,itemWidth:300,prefetchThresholdPx:200,gapX:16,gapY:16,headerHeight:0,footerHeight:0,overscanPx:600},Wt=["aria-label","aria-valuemax","aria-valuenow"],qe=e.defineComponent({__name:"MasonryVideoControls",props:{currentTime:{},duration:{},ariaLabel:{default:"Seek"},step:{default:.1},keyboardStep:{default:5}},emits:["seek"],setup(l,{expose:x,emit:u}){const a=l,v=u,k=e.ref(null),y=e.ref(null),p=e.ref(null),c=e.ref(!1),h=e.computed(()=>Number.isFinite(a.step)?Math.max(0,a.step):0),w=e.computed(()=>Number.isFinite(a.duration)?Math.max(0,a.duration):0),S=e.computed(()=>{const f=Number.isFinite(a.currentTime)?a.currentTime:0;return E(f,0,w.value)}),F=e.computed(()=>w.value>0?S.value/w.value:0);function E(f,B,_){return Math.min(_,Math.max(B,f))}function M(f){return h.value<=0?f:Math.round(f/h.value)*h.value}function R(f){const B=E(f,0,w.value);v("seek",M(B))}function N(f){const B=y.value;if(!B)return;const _=B.getBoundingClientRect();if(!_.width)return;const O=E((f-_.left)/_.width,0,1);R(O*w.value)}function $(f){const B=y.value;B&&(c.value=!0,B.setPointerCapture&&B.setPointerCapture(f.pointerId),N(f.clientX))}function A(f){c.value&&N(f.clientX)}function T(f){if(!c.value)return;c.value=!1;const B=y.value;B?.releasePointerCapture&&B.releasePointerCapture(f.pointerId)}function D(f){if(w.value<=0)return;const B=Number.isFinite(a.keyboardStep)?a.keyboardStep:1;let _=S.value;switch(f.key){case"ArrowLeft":case"ArrowDown":_-=B;break;case"ArrowRight":case"ArrowUp":_+=B;break;case"Home":_=0;break;case"End":_=w.value;break;default:return}f.preventDefault(),R(_)}function U(){k.value?.focus()}return x({focus:U,seekTo:R,percent:F,currentValue:S,maxValue:w,isDragging:c,rootEl:k,trackEl:y,thumbEl:p}),(f,B)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"rootEl",ref:k,class:"w-full select-none",role:"slider",tabindex:"0","aria-label":a.ariaLabel,"aria-valuemin":0,"aria-valuemax":w.value,"aria-valuenow":S.value,onKeydown:D},[e.createElementVNode("div",{ref_key:"trackEl",ref:y,class:"relative h-2 w-full cursor-pointer rounded-full bg-slate-200",onPointerdown:$,onPointermove:A,onPointerup:T,onPointercancel:T,onPointerleave:T},[e.createElementVNode("div",{class:"absolute inset-y-0 left-0 rounded-full bg-slate-500",style:e.normalizeStyle({width:`${F.value*100}%`})},null,4),e.createElementVNode("div",{ref_key:"thumbEl",ref:p,class:"absolute top-1/2 h-3 w-3 -translate-x-1/2 -translate-y-1/2 rounded-full bg-slate-700 shadow",style:e.normalizeStyle({left:`${F.value*100}%`}),"aria-hidden":"true"},null,4)],544)],40,Wt))}}),Gt={key:0,"data-testid":"masonry-loader-spinner",class:"absolute inset-0 z-10 flex flex-col items-center justify-center gap-1"},Kt={key:1,class:"h-5 w-5 animate-spin text-slate-500",viewBox:"0 0 24 24","aria-hidden":"true"},Jt={key:1,"data-testid":"masonry-loader-error",class:"absolute inset-0 z-20 grid place-items-center p-3 pointer-events-none"},Qt={class:"pointer-events-auto flex flex-col items-center justify-center gap-2"},Zt={key:1,class:"text-center text-xs font-medium text-red-700"},en=["src","width","height","alt"],tn=["poster"],nn=["src"],on={key:4,class:"pointer-events-none absolute inset-x-0 bottom-0 z-20 px-2 pb-2 opacity-0 transition-opacity duration-200 group-hover:pointer-events-auto group-hover:opacity-100"},pt=e.defineComponent({__name:"MasonryLoader",props:{item:{},remove:{},loaderSlotFn:{},errorSlotFn:{},hovered:{type:Boolean,default:!1}},emits:["success","error"],setup(l,{emit:x}){const u=l,a=x,v=e.defineComponent({name:"SlotRenderer",props:{slotFn:{type:Function,required:!1},slotProps:{type:Object,required:!0}},setup(i){return()=>{const b=i.slotFn;return b?b(i.slotProps):null}}}),k=e.ref(null),y=e.ref(null),p=e.ref(null),c=e.ref(!1),h=e.ref(!1),w=e.ref(!1),S=e.ref(null),F=e.computed(()=>u.item?.type==="video"),E=e.computed(()=>{if(!F.value)return;const i=u.item?.preview,b=u.item?.original;if(!(typeof i!="string"||!i)&&!(typeof b=="string"&&i===b)&&!/\.(mp4|webm)(\?|#|$)/i.test(i)&&/\.(png|jpe?g|gif|webp)(\?|#|$)/i.test(i))return i}),M=e.computed(()=>{if(!F.value)return;const i=u.item?.preview;if(typeof i=="string"&&i&&!/\.(png|jpe?g|gif|webp)(\?|#|$)/i.test(i))return i;const b=u.item?.original;if(typeof b=="string"&&b)return b}),R=e.ref(!1),N=e.computed(()=>!!u.hovered),$=e.ref(0),A=e.ref(0);function T(){u.remove?.()}const D=e.computed(()=>{const i=u.item?.width,b=u.item?.height;return{aspectRatio:`${i} / ${b}`}}),U=e.computed(()=>!F.value);let f=null,B=null;function _(){c.value||(c.value=!0,h.value=!1,w.value=!1,S.value=null)}function O(i){$.value=Number.isFinite(i.duration)?i.duration:0,A.value=Number.isFinite(i.currentTime)?i.currentTime:0}async function J(){if(!F.value||!N.value||!c.value||!h.value||!R.value)return;const i=p.value;if(i)try{i.muted=!0,await i.play()}catch{}}function W(){const i=p.value;i&&(i.paused||i.pause())}function ke(){const i=p.value;i&&(i.paused||i.pause())}e.watch(()=>u.hovered,i=>{if(i){_(),J();return}W()});function be(i){const b=p.value;b&&Number.isFinite(i)&&(b.currentTime=Math.max(0,Math.min(i,Number.isFinite(b.duration)?b.duration:i)),O(b))}e.onMounted(()=>{if(typeof IntersectionObserver>"u"){_();return}if(f=new IntersectionObserver(i=>{for(const b of i)if(b.isIntersecting&&!((b.intersectionRatio??0)<.5)){_(),f?.disconnect(),f=null;return}},{threshold:[0,.5,1]}),k.value&&f.observe(k.value),F.value&&k.value){const i=k.value.closest('[data-testid="items-scroll-container"]');B=new IntersectionObserver(b=>{for(const j of b){const xe=j.intersectionRatio??0,me=!!j.isIntersecting&&xe>=.5;R.value=me,me?N.value&&J():ke()}},{root:i??void 0,threshold:[0,.25,.5,.75,1]}),B.observe(k.value)}}),e.onUnmounted(()=>{f?.disconnect(),f=null,B?.disconnect(),B=null});function Y(){h.value||(h.value=!0,w.value=!1,S.value=null,a("success",u.item))}function X(i){w.value||(h.value=!1,w.value=!0,S.value=i,a("error",{item:u.item,error:i}))}function de(){if(c.value&&!h.value&&!w.value){if(U.value){const i=y.value;if(!i||!i.complete)return;i.naturalWidth>0&&Y();return}if(F.value){const i=p.value;i&&(i.readyState??0)>=1&&ve()}}}e.watch([c,()=>u.item.preview,()=>M.value],()=>{c.value&&Promise.resolve().then(de)},{flush:"post"});function ve(){Y();const i=p.value;i&&O(i),J()}function Q(){const i=p.value;i&&O(i)}return(i,b)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"rootEl",ref:k,class:"relative bg-slate-100",style:e.normalizeStyle(D.value)},[c.value&&!h.value&&!w.value?(e.openBlock(),e.createElementBlock("div",Gt,[u.loaderSlotFn?(e.openBlock(),e.createBlock(e.unref(v),{key:0,"slot-fn":u.loaderSlotFn,"slot-props":{item:u.item,remove:T}},null,8,["slot-fn","slot-props"])):(e.openBlock(),e.createElementBlock("svg",Kt,b[2]||(b[2]=[e.createElementVNode("circle",{class:"opacity-25",cx:"12",cy:"12",r:"10",fill:"none",stroke:"currentColor","stroke-width":"4"},null,-1),e.createElementVNode("path",{class:"opacity-75",fill:"currentColor",d:"M4 12a8 8 0 0 1 8-8v4a4 4 0 0 0-4 4H4z"},null,-1)])))])):c.value&&w.value?(e.openBlock(),e.createElementBlock("div",Jt,[e.createElementVNode("div",Qt,[u.errorSlotFn?(e.openBlock(),e.createBlock(e.unref(v),{key:0,"slot-fn":u.errorSlotFn,"slot-props":{item:u.item,remove:T,error:S.value}},null,8,["slot-fn","slot-props"])):(e.openBlock(),e.createElementBlock("p",Zt,"Error "+e.toDisplayString(S.value),1))])])):e.createCommentVNode("",!0),c.value&&U.value&&!w.value?(e.openBlock(),e.createElementBlock("img",{key:u.item.id+":img",ref_key:"imgEl",ref:y,class:e.normalizeClass(["h-full w-full object-cover transition-opacity duration-300",h.value?"opacity-100":"opacity-0"]),src:u.item.preview,width:u.item.width,height:u.item.height,loading:"lazy",alt:u.item.id,onLoad:Y,onError:b[0]||(b[0]=j=>X(j))},null,42,en)):c.value&&!w.value?(e.openBlock(),e.createElementBlock("video",{key:u.item.id+":vid",class:e.normalizeClass(["h-full w-full object-cover transition-opacity duration-300",h.value?"opacity-100":"opacity-0"]),poster:E.value,ref_key:"videoEl",ref:p,playsinline:"",loop:"",preload:"metadata",onLoadedmetadata:ve,onTimeupdate:Q,onDurationchange:Q,onLoadeddata:Q,onError:b[1]||(b[1]=j=>X(j))},[e.createElementVNode("source",{src:M.value,type:"video/mp4"},null,8,nn)],42,tn)):e.createCommentVNode("",!0),c.value&&F.value&&!w.value?(e.openBlock(),e.createElementBlock("div",on,[e.createVNode(qe,{duration:$.value,"current-time":A.value,onSeek:be},null,8,["duration","current-time"])])):e.createCommentVNode("",!0)],4))}}),xt=Symbol("masonryItemRegistry");function ln(l,x){return!l||l<=0||!x||x<=0?1:Math.max(1,Math.floor(l/x))}function rn(l,x,u,a=0){if(!l||l<=0||!x||x<=0)return u;const v=typeof a=="number"&&a>0?a:0,k=Math.max(0,x-1)*v,y=l-k;return!y||y<=0?u:y/x}function an(l,x){const u=l?.width,a=l?.height;return typeof u=="number"&&typeof a=="number"&&u>0&&a>0?a/u*x:x}function St(l){return Number.isFinite(l)&&l>0?Math.floor(l):1}function Ye(l){return Number.isFinite(l)&&l>0?Math.floor(l):0}function sn(){const l=new Error("aborted");return l.name="AbortError",l}function un(l){async function x(a){const v=Ye(a);if(v<=0)return;l.stats.value={...l.stats.value,cooldownMsTotal:v,cooldownMsRemaining:v};const k=Date.now(),y=100;await new Promise(p=>{const c=setInterval(()=>{const h=Date.now()-k,w=Math.max(0,v-h);l.stats.value={...l.stats.value,cooldownMsTotal:v,cooldownMsRemaining:w},w<=0&&(clearInterval(c),p())},y)})}async function u(a){const v=St(l.getPageSize()),k=l.isEnabled(),y=Ye(l.getRequestDelayMs()),p=l.stats.value.page??null,c=l.getCancelToken?.()??null,h=()=>c!==null&&l.getCancelToken&&l.getCancelToken()!==c,w=()=>{if(h())throw sn()},S=[];let F=0;l.buffer.value.length&&(F=l.buffer.value.length,S.push(...l.buffer.value),l.buffer.value=[]),l.stats.value={...l.stats.value,enabled:k,isBackfillActive:!1,isRequestInFlight:!1,page:p??a,next:a,cooldownMsTotal:y,cooldownMsRemaining:0,progress:{collected:0,target:0},pageSize:v,bufferSize:0};const E=[];let M=a,R=0,N=!1;for(;S.length<v&&M!=null;){w();const T=M;N&&(l.stats.value={...l.stats.value,enabled:k,isBackfillActive:!0,isRequestInFlight:!0,page:T,next:null,progress:{collected:Math.min(S.length,v),target:v},cooldownMsTotal:y,cooldownMsRemaining:0,pageSize:v});const D=await l.getContent(T);w(),E.push(T),N&&(l.stats.value={...l.stats.value,enabled:k,isBackfillActive:!0,isRequestInFlight:!1,page:T,next:D.nextPage}),R+=D.items.length,l.markEnterFromLeft(D.items),S.push(...D.items),M=D.nextPage,!N&&S.length<v&&M!=null?(N=!0,l.stats.value={...l.stats.value,enabled:k,isBackfillActive:!0,isRequestInFlight:!1,page:T,next:M,progress:{collected:Math.min(S.length,v),target:v},cooldownMsTotal:y,cooldownMsRemaining:0,pageSize:v}):N&&(l.stats.value={...l.stats.value,enabled:k,isBackfillActive:!0,page:T,next:M,progress:{collected:Math.min(S.length,v),target:v}}),N&&S.length<v&&M!=null&&(await x(y),w())}const $=S.slice(0,v),A=S.slice(v);return l.buffer.value=A,l.stats.value={...l.stats.value,enabled:k,isBackfillActive:!1,isRequestInFlight:!1,page:E.length?E[E.length-1]:p??a,next:M,progress:{collected:0,target:0},cooldownMsTotal:y,cooldownMsRemaining:0,pageSize:v,bufferSize:A.length,lastBatch:{startPage:a,pages:E,usedFromBuffer:F,fetchedFromNetwork:R,collectedTotal:S.length,emitted:$.length,carried:A.length},totals:{pagesFetched:l.stats.value.totals.pagesFetched+E.length,itemsFetchedFromNetwork:l.stats.value.totals.itemsFetchedFromNetwork+R}},{batchItems:$,pages:E,nextPage:M}}return{loadBackfillBatch:u}}function cn(l){const x=l.columnCount,u=l.columnWidth,a=l.gapX,v=l.gapY,k=l.headerHeight,y=l.footerHeight,p=l.bucketPx,c=Array.from({length:x},()=>0),h=new Array(l.items.length),w=new Array(l.items.length),S=new Map,F=new Map;let E=0;for(let M=0;M<l.items.length;M+=1){const R=l.items[M];R?.id&&F.set(R.id,M);let N=0;for(let f=1;f<c.length;f+=1)c[f]<c[N]&&(N=f);const $=N*(u+a),A=c[N],T=an(R,u)+k+y;h[M]={x:$,y:A},w[M]=T,c[N]=A+T+v,E=Math.max(E,A+T);const D=Math.floor(A/p),U=Math.floor((A+T)/p);for(let f=D;f<=U;f+=1){const B=S.get(f);B?B.push(M):S.set(f,[M])}}return{positions:h,heights:w,buckets:S,contentHeight:E,indexById:F}}function fn(l){const x=l.itemCount;if(!x)return[];if(l.viewportHeight<=0)return Array.from({length:x},(c,h)=>h);const u=Math.max(0,l.scrollTop-l.overscanPx),a=l.scrollTop+l.viewportHeight+l.overscanPx,v=Math.floor(u/l.bucketPx),k=Math.floor(a/l.bucketPx),y=new Set;for(let c=v;c<=k;c+=1){const h=l.buckets.get(c);if(h)for(const w of h)y.add(w)}const p=Array.from(y);return p.sort((c,h)=>c-h),p}const dn={class:"hidden"},vn={key:0,class:"flex h-full items-center justify-center"},mn={key:1,class:"text-sm font-medium text-red-700"},pn=["onMouseenter","onMouseleave"],hn={key:0,class:"pointer-events-auto absolute inset-0 z-10"},gn={class:"relative"},yn={key:0,class:"pointer-events-auto absolute inset-0 z-10"},wn={class:"mt-4 pb-2 text-center text-xs text-slate-600"},kn={key:0,class:"inline-flex items-center justify-center gap-2"},bn={key:1},xn={key:2},ht=100,Sn=200,gt=600,yt=300,wt=600,kt=600,Mn=400,Bn=5,En=1e3,Mt=e.defineComponent({inheritAttrs:!1,__name:"Masonry",props:e.mergeDefaults({getContent:{},mode:{},pageSize:{},backfillRequestDelayMs:{},enterStaggerMs:{},items:{},page:{},restoredPages:{},itemWidth:{},prefetchThresholdPx:{},gapX:{},gapY:{},headerHeight:{},footerHeight:{},overscanPx:{}},bt),emits:["update:items","preloaded","failures","removed"],setup(l,{expose:x,emit:u}){const a=l,v=u,k=e.useAttrs(),y=e.defineComponent({name:"SlotRenderer",props:{slotFn:{type:Function,required:!1},slotProps:{type:Object,required:!0}},setup(t){return()=>{const o=t.slotFn;return o?o(t.slotProps):null}}}),p=e.shallowRef(null),c=e.ref(null);function h(t){c.value=t}function w(t){c.value===t&&(c.value=null)}e.provide(xt,t=>{p.value||(p.value=t)});const S=[],F=[];let E=null,M=null;function R(){if(!S.length)return;const t=S.splice(0,S.length);v("preloaded",t)}function N(){if(!F.length)return;const t=F.splice(0,F.length);v("failures",t)}function $(){E||(E=setTimeout(()=>{E=null,R()},ht))}function A(){M||(M=setTimeout(()=>{M=null,N()},ht))}function T(t){p.value?.onPreloaded?.(t),S.push(t),$()}function D(t){p.value?.onFailed?.(t),F.push(t),A()}e.onMounted(()=>{if(!p.value)throw new Error("[Masonry] Missing <MasonryItem> definition. Add <MasonryItem> as a child of <Masonry>.")});const U=e.computed(()=>{const{class:t,...o}=k;return o}),f=e.ref(null),B=e.ref(0),_=e.ref(0),O=e.ref(0);let J;const W=e.computed(()=>a.gapX),ke=e.computed(()=>a.gapY);function be(t){if(!t)return 0;const o=Math.max(0,W.value);return Math.max(0,t.clientWidth-o)}const Y=e.computed(()=>a.headerHeight),X=e.computed(()=>a.footerHeight),de=e.computed(()=>p.value?.header),ve=e.computed(()=>p.value?.loader),Q=e.computed(()=>p.value?.footer),i=e.computed(()=>p.value?.overlay),b=e.computed(()=>p.value?.error),j=e.computed(()=>!!de.value),xe=e.computed(()=>!!Q.value),me=e.computed(()=>!!i.value),Xe=e.computed(()=>{if(Y.value>0)return{height:`${Y.value}px`}}),je=e.computed(()=>{if(X.value>0)return{height:`${X.value}px`}}),pe=e.ref([]),Ve=e.ref([]),Ue=e.ref(new Map),We=e.ref(0),Se=e.ref(new Map);function Et(t){const o=typeof t=="number"&&Number.isFinite(t)?t:0;return O.value+_.value+Math.max(0,o)}const Z=e.ref(new Set),ee=e.ref(new Set),Me=new Set,he=e.ref(new Map);function It(t){return Number.isFinite(t)?Math.max(0,Math.min(250,t)):0}function Ft(t){if(!ee.value.has(t))return;const o=he.value.get(t)??0;if(!(o<=0))return`${o}ms`}const Be=e.ref(new Map),G=e.ref(new Set),K=e.ref([]);function _t(t){const o=Be.value.get(t);return o||{dx:0,dy:0}}function Nt(t){if(ee.value.has(t))return`transform ${wt}ms ease-out`;if(G.value.has(t))return`transform ${yt}ms ease-out`}function Pt(t){const n=m.value[t]?.id,r=pe.value[t]??{x:0,y:0},s=Ve.value[t]??0,d=s>0?s:we.value,g=r.x,I=n&&Z.value.has(n)?Et(d):r.y,H=n?_t(n):{dx:0,dy:0};return`translate3d(${g+H.dx}px,${I+H.dy}px,0)`}function ie(t){(typeof requestAnimationFrame=="function"?requestAnimationFrame:n=>setTimeout(()=>n(0),0))(()=>t())}function Tt(t){ie(()=>ie(t))}const Ge=new Set;function Ke(t){return typeof t=="number"&&Number.isFinite(t)&&t>0}function Ee(t){if(!Array.isArray(t)||t.length===0)return;const o=new Set(Z.value);let n=!1;for(const r of t){const s=r?.id;if(s){if(!Ge.has(s)){const d=r?.width,g=r?.height;(!Ke(d)||!Ke(g))&&(Ge.add(s),console.warn(`[Masonry] Item "${s}" has invalid dimensions (width=${String(d)}, height=${String(g)}); layout expects { id, width, height }.`))}o.has(s)||(o.add(s),n=!0)}}n&&(Z.value=o)}function Je(){const t=new Map;for(const o of Le.value){const r=m.value[o]?.id;if(!r)continue;const s=pe.value[o];s&&t.set(r,{x:s.x,y:s.y})}return t}function Qe(t,o){if(!t.size)return;const n=new Map,r=[];for(const[d,g]of t.entries()){if(o?.has(d))continue;const I=Se.value.get(d);if(I==null)continue;const H=pe.value[I];if(!H)continue;const L=g.x-H.x,C=g.y-H.y;(L||C)&&(n.set(d,{dx:L,dy:C}),r.push(d))}if(!n.size)return;Be.value=n;const s=new Set(G.value);for(const d of r)s.delete(d);G.value=s,ie(()=>{G.value=new Set([...G.value,...r]),ie(()=>{Be.value=new Map})}),setTimeout(()=>{const d=new Set(G.value);for(const g of r)d.delete(g);G.value=d},yt)}const te=e.ref(!0),ne=e.ref(!1),ue=e.ref("");let z=0,Ce=0,Ie=0,Fe=0,ge=!1;function Ze(t){return t instanceof Error&&t.name==="AbortError"}function et(){const t=new Error("aborted");return t.name="AbortError",t}function Vt(t){return new Promise(o=>setTimeout(o,t))}async function tt(t,o){let n=0;for(;;){if(o!==z)throw et();try{return await a.getContent(t)}catch(r){if(o!==z)throw et();if(n>=Bn)throw r;n+=1,await Vt(n*En)}}}const q=e.ref([]),nt=e.ref([]),Re=e.ref([]),V=e.ref(a.page),_e=e.ref([]);let oe=null,le=null,Ne=0;function Ct(t){let o=-1;for(const n of t){const r=n?.originalIndex;ye(r)&&r>o&&(o=r)}Ne=o+1}function ce(t){for(const o of t)!o||typeof o!="object"||o.id&&o.originalIndex==null&&(o.originalIndex=Ne,Ne+=1)}const re=new Map,ae=[];function ye(t){return typeof t=="number"&&Number.isFinite(t)}function Rt(t,o){if(!o.length)return t;const n=new Set;for(const g of t){const I=g?.id;I&&n.add(I)}const r=[];for(const g of o){const I=g?.id;I&&(n.has(I)||(r.push(g),n.add(I)))}if(!r.length)return t;const s=r.slice().sort((g,I)=>{const H=ye(g.originalIndex)?g.originalIndex:Number.POSITIVE_INFINITY,L=ye(I.originalIndex)?I.originalIndex:Number.POSITIVE_INFINITY;return H-L}),d=t.slice();for(const g of s){const I=g.originalIndex;if(!ye(I)){d.push(g);continue}let H=0,L=d.length;for(;H<L;){const C=H+L>>1,P=d[C]?.originalIndex;(ye(P)?P:Number.POSITIVE_INFINITY)<=I?H=C+1:L=C}d.splice(H,0,g)}return d}async function ot(t){if(!t.length)return;ge=!0,Ee(t);const o=Je();m.value=Rt(m.value,t),await e.nextTick(),Qe(o)}async function At(t){const n=(Array.isArray(t)?t:[t]).map(He).filter(Boolean);if(!n.length)return;const r=[];for(const s of n){const d=re.get(s);d&&r.push(d)}if(r.length){await ot(r);for(const s of r)s?.id&&re.delete(s.id)}}async function zt(){const t=ae.pop();if(!t?.length)return;const o=[];for(const n of t){const r=re.get(n);r&&o.push(r)}if(o.length){await ot(o);for(const n of o)n?.id&&re.delete(n.id)}}function Ht(t){const n=(Array.isArray(t)?t:[t]).map(He).filter(Boolean);if(!n.length)return;const r=new Set(n);for(const s of r)re.delete(s);for(let s=ae.length-1;s>=0;s-=1){const g=ae[s].filter(I=>!r.has(I));g.length?ae[s]=g:ae.splice(s,1)}}const Ae=e.shallowRef({enabled:!1,isBackfillActive:!1,isRequestInFlight:!1,page:a.page,next:a.page,progress:{collected:0,target:0},cooldownMsRemaining:0,cooldownMsTotal:2e3,pageSize:20,bufferSize:0,lastBatch:null,totals:{pagesFetched:0,itemsFetchedFromNetwork:0}}),lt=un({getContent:t=>tt(t,z),markEnterFromLeft:Ee,buffer:_e,stats:Ae,isEnabled:()=>a.mode==="backfill",getPageSize:()=>a.pageSize,getRequestDelayMs:()=>a.backfillRequestDelayMs,getCancelToken:()=>Ce}),Pe=e.computed(()=>a.items!==void 0);e.watch(()=>a.items,t=>{Pe.value&&(Re.value=Array.isArray(t)?t:[])},{immediate:!0});const m=e.computed({get(){return Pe.value?Re.value:nt.value},set(t){Pe.value?(Re.value=t,v("update:items",t)):nt.value=t}}),fe=e.ref(!1),ze=e.ref(!1);async function rt(t){const o=await tt(t,z);return ce(o.items),Ee(o.items),{items:o.items,nextPage:o.nextPage}}function He(t){return t?typeof t=="string"?t:t?.id:null}async function at(t){const n=(Array.isArray(t)?t:[t]).map(He).filter(Boolean);if(!n.length)return;const r=new Set(n),s=[],d=[];for(const C of r){const P=Se.value.get(C);if(P==null)continue;const se=m.value[P];se&&(re.set(C,se),d.push(C),s.push(se))}d.length&&(ae.push(d),ge=!0);const g=Je(),I=we.value,H=O.value+_.value,L=[];for(const C of r){const P=Se.value.get(C);if(P==null)continue;const se=m.value[P];if(!se)continue;const Oe=pe.value[P]??{x:0,y:0},mt=Ve.value[P]??I,Ut=Math.max(Oe.y,H);L.push({id:C,item:se,fromX:Oe.x,fromY:Oe.y,toY:Ut+Math.max(0,mt),width:I,height:mt,leaving:!0})}if(L.length&&(K.value=[...K.value,...L]),m.value=m.value.filter(C=>{const P=C?.id;return!P||!r.has(P)}),await e.nextTick(),Qe(g,r),L.length){const C=new Set(L.map(P=>P.id));ie(()=>{K.value=K.value.map(P=>C.has(P.id)?{...P,leaving:!1}:P),setTimeout(()=>{K.value=K.value.filter(P=>!C.has(P.id))},kt)})}s.length&&v("removed",{items:s,ids:d})}async function Te(t){return at(t)}function Lt(){z+=1,Ce+=1,oe=null,le=null,te.value=!1,ne.value=!1}x({remove:at,restore:At,undo:zt,forget:Ht,loadNextPage:it,cancel:Lt,get pagesLoaded(){return q.value},set pagesLoaded(t){q.value=t},get nextPage(){return V.value},set nextPage(t){V.value=t},get isLoading(){return te.value||ne.value},get hasReachedEnd(){return a.mode!=="backfill"?V.value==null:V.value==null&&_e.value.length===0},get backfillStats(){return Ae.value}});function st(){const t=cn({items:m.value,columnCount:$e.value,columnWidth:we.value,gapX:W.value,gapY:ke.value,headerHeight:Y.value,footerHeight:X.value,bucketPx:gt});pe.value=t.positions,Ve.value=t.heights,Ue.value=t.buckets,We.value=t.contentHeight,Se.value=t.indexById}const Dt=e.computed(()=>Math.max(We.value,_.value)+Sn),Le=e.computed(()=>fn({itemCount:m.value.length,viewportHeight:_.value,scrollTop:O.value,overscanPx:a.overscanPx,bucketPx:gt,buckets:Ue.value}));e.watch(Le,t=>{if(!t?.length)return;if(fe.value&&!ze.value){const r=[];for(const s of t){const d=m.value[s];d&&r.push(d)}r.length&&Ee(r),ze.value=!0}const o=[];for(const r of t){const s=m.value[r]?.id;s&&Z.value.has(s)&&(Me.has(s)||(Me.add(s),o.push(s)))}if(!o.length)return;const n=o.length>1?It(a.enterStaggerMs):0;if(n>0){const r=new Map(he.value);for(let s=0;s<o.length;s+=1){const d=o[s],g=Math.min(s*n,Mn);r.set(d,g)}he.value=r}ie(()=>{const r=new Set(ee.value);for(const s of o)r.add(s);ee.value=r}),Tt(()=>{const r=new Set(Z.value);for(const s of o)r.delete(s);Z.value=r,setTimeout(()=>{const s=new Set(ee.value),d=new Map(he.value);for(const g of o)s.delete(g),Me.delete(g),d.delete(g);ee.value=s,he.value=d},wt)})},{flush:"post"});async function it(){if(oe)return oe;if(te.value||ne.value||a.mode!=="backfill"&&V.value==null||a.mode==="backfill"&&V.value==null&&_e.value.length===0)return;const t=z;let o=null;return o=(async()=>{try{if(ne.value=!0,ue.value="",a.mode==="backfill"){const s=await lt.loadBackfillBatch(V.value);if(t!==z)return;s.pages.length&&(q.value=[...q.value,...s.pages]),ce(s.batchItems),m.value=[...m.value,...s.batchItems],V.value=s.nextPage;return}const n=V.value;if(n==null)return;const r=await rt(n);if(t!==z)return;q.value=[...q.value,n],ce(r.items),m.value=[...m.value,...r.items],V.value=r.nextPage}catch(n){if(t!==z||Ze(n))return;ue.value=n instanceof Error?n.message:String(n)}finally{t===z&&(ne.value=!1),oe===o&&(oe=null)}})(),oe=o,o}function $t(){const t=f.value;if(!t)return;const o=t.scrollTop,n=t.clientHeight,r=t.scrollHeight;O.value=o,_.value=n;const s=Ie,d=Fe,g=o>s,I=d>0&&r<d;if(Ie=o,Fe=r,ge){if(!g)return;ge=!1}if(I&&!g)return;r-(o+n)<=a.prefetchThresholdPx&&it()}function ut(){return f.value}function ct(t){B.value=be(t),_.value=t.clientHeight}function Ot(){typeof ResizeObserver>"u"||(J=new ResizeObserver(()=>{const t=ut();t&&ct(t)}))}function Yt(){return{enabled:a.mode==="backfill",isBackfillActive:!1,isRequestInFlight:!1,page:a.page,next:a.page,progress:{collected:0,target:0},cooldownMsRemaining:0,cooldownMsTotal:Ye(a.backfillRequestDelayMs),pageSize:St(a.pageSize),bufferSize:0,lastBatch:null,totals:{pagesFetched:0,itemsFetchedFromNetwork:0}}}function ft(){z+=1,Ce+=1,oe=null,le=null,Ie=0,Fe=0,ge=!1,Ne=0,re.clear(),ae.length=0,Z.value=new Set,ee.value=new Set,Me.clear(),Be.value=new Map,G.value=new Set,K.value=[],q.value=[],V.value=null,_e.value=[],Ae.value=Yt(),te.value=!0,ne.value=!1,ue.value="",ze.value=!1}function dt(t){ft(),m.value=[],V.value=t}function qt(t){const o=Array.isArray(t)?t:[t],n=[],r=new Set;for(const s of o){if(s==null)continue;const d=typeof s=="string"?`s:${s}`:`n:${String(s)}`;r.has(d)||(r.add(d),n.push(s))}return n}function De(t){ft(),q.value=t?qt(t):[],V.value=a.page,te.value=!1,Ct(m.value),ce(m.value)}async function vt(t){if(le)return le;const o=z;let n=null;return n=(async()=>{try{if(a.mode==="backfill"){const r=await lt.loadBackfillBatch(t);if(o!==z)return;q.value=r.pages.length?r.pages:[t],ce(r.batchItems),m.value=r.batchItems,V.value=r.nextPage}else{const r=await rt(t);if(o!==z)return;q.value=[t],ce(r.items),m.value=r.items,V.value=r.nextPage}}catch(r){if(o!==z||Ze(r))return;ue.value=r instanceof Error?r.message:String(r)}finally{o===z&&(te.value=!1),le===n&&(le=null)}})(),le=n,n}function Xt(){const t=ut();t&&(ct(t),O.value=t.scrollTop,Ie=t.scrollTop,Fe=t.scrollHeight,J?.observe(t))}e.onMounted(async()=>{if(Ot(),Xt(),a.restoredPages!=null){fe.value=!0,De(a.restoredPages);return}if(Pe.value&&m.value.length>0){fe.value=!0,De();return}fe.value=!1,dt(a.page),await vt(a.page)}),e.onUnmounted(()=>{J?.disconnect(),E&&(clearTimeout(E),E=null),M&&(clearTimeout(M),M=null),R(),N()}),e.watch(()=>a.page,async t=>{if(fe.value){V.value=t;return}dt(t),await vt(t)}),e.watch(()=>a.restoredPages,t=>{t&&(fe.value=!0,De(t))}),e.watch(W,()=>{const t=f.value;t&&(B.value=be(t))},{immediate:!1});const $e=e.computed(()=>ln(B.value,a.itemWidth)),we=e.computed(()=>rn(B.value,$e.value,a.itemWidth,W.value));e.watch([$e,we,W,ke,Y,X],()=>{st()},{immediate:!0}),e.watch(()=>[m.value,m.value.length],()=>st(),{immediate:!0});const jt=e.computed(()=>["mt-8 flex min-h-0 flex-1 flex-col rounded-2xl border border-slate-200/70 bg-white/70 p-5 shadow-sm backdrop-blur",k.class]);return(t,o)=>(e.openBlock(),e.createElementBlock("section",e.mergeProps(U.value,{class:jt.value}),[e.createElementVNode("div",dn,[e.renderSlot(t.$slots,"default")]),e.createElementVNode("div",{ref_key:"scrollViewportRef",ref:f,"data-testid":"items-scroll-container",class:"mt-4 min-h-0 flex-1 overflow-auto",style:e.normalizeStyle({paddingRight:W.value+"px"}),onScroll:$t},[te.value?(e.openBlock(),e.createElementBlock("div",vn,o[0]||(o[0]=[e.createElementVNode("div",{class:"inline-flex items-center gap-3 text-sm text-slate-600"},[e.createElementVNode("svg",{class:"h-5 w-5 animate-spin text-slate-500",viewBox:"0 0 24 24","aria-hidden":"true"},[e.createElementVNode("circle",{class:"opacity-25",cx:"12",cy:"12",r:"10",fill:"none",stroke:"currentColor","stroke-width":"4"}),e.createElementVNode("path",{class:"opacity-75",fill:"currentColor",d:"M4 12a8 8 0 0 1 8-8v4a4 4 0 0 0-4 4H4z"})]),e.createElementVNode("span",null,"Loading…")],-1)]))):ue.value?(e.openBlock(),e.createElementBlock("p",mn,"Error: "+e.toDisplayString(ue.value),1)):(e.openBlock(),e.createElementBlock("div",{key:2,class:"relative",style:e.normalizeStyle({height:Dt.value+"px"})},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(Le.value,n=>(e.openBlock(),e.createElementBlock("article",{key:m.value[n].id,"data-testid":"item-card",class:"absolute overflow-hidden rounded-xl border border-slate-200/60 bg-white shadow-sm",style:e.normalizeStyle({width:we.value+"px",transition:Nt(m.value[n].id),transitionDelay:Ft(m.value[n].id),transform:Pt(n)})},[j.value||Y.value>0?(e.openBlock(),e.createElementBlock("div",{key:0,"data-testid":"item-header-container",class:"w-full",style:e.normalizeStyle(Xe.value)},[e.createVNode(e.unref(y),{"slot-fn":de.value,"slot-props":{item:m.value[n],remove:()=>Te(m.value[n])}},null,8,["slot-fn","slot-props"])],4)):e.createCommentVNode("",!0),e.createElementVNode("div",{class:"group relative",onMouseenter:r=>h(m.value[n].id),onMouseleave:r=>w(m.value[n].id)},[e.createVNode(pt,{item:m.value[n],remove:()=>Te(m.value[n]),"loader-slot-fn":ve.value,"error-slot-fn":b.value,hovered:c.value===m.value[n].id,onSuccess:T,onError:D},null,8,["item","remove","loader-slot-fn","error-slot-fn","hovered"]),me.value?(e.openBlock(),e.createElementBlock("div",hn,[e.createVNode(e.unref(y),{"slot-fn":i.value,"slot-props":{item:m.value[n],remove:()=>Te(m.value[n])}},null,8,["slot-fn","slot-props"])])):e.createCommentVNode("",!0)],40,pn),xe.value||X.value>0?(e.openBlock(),e.createElementBlock("div",{key:1,"data-testid":"item-footer-container",class:"w-full",style:e.normalizeStyle(je.value)},[e.createVNode(e.unref(y),{"slot-fn":Q.value,"slot-props":{item:m.value[n],remove:()=>Te(m.value[n])}},null,8,["slot-fn","slot-props"])],4)):e.createCommentVNode("",!0)],4))),128)),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(K.value,n=>(e.openBlock(),e.createElementBlock("article",{key:n.id+":leaving","data-testid":"item-card-leaving",class:"pointer-events-none absolute overflow-hidden rounded-xl border border-slate-200/60 bg-white shadow-sm",style:e.normalizeStyle({width:n.width+"px",transition:"transform "+kt+"ms ease-out",transform:n.leaving?"translate3d("+n.fromX+"px,"+n.fromY+"px,0)":"translate3d("+n.fromX+"px,"+n.toY+"px,0)"})},[j.value||Y.value>0?(e.openBlock(),e.createElementBlock("div",{key:0,"data-testid":"item-header-container",class:"w-full",style:e.normalizeStyle(Xe.value)},[e.createVNode(e.unref(y),{"slot-fn":de.value,"slot-props":{item:n.item,remove:()=>{}}},null,8,["slot-fn","slot-props"])],4)):e.createCommentVNode("",!0),e.createElementVNode("div",gn,[e.createVNode(pt,{item:n.item,remove:()=>{},"loader-slot-fn":ve.value,"error-slot-fn":b.value,hovered:!1},null,8,["item","loader-slot-fn","error-slot-fn"]),me.value?(e.openBlock(),e.createElementBlock("div",yn,[e.createVNode(e.unref(y),{"slot-fn":i.value,"slot-props":{item:n.item,remove:()=>{}}},null,8,["slot-fn","slot-props"])])):e.createCommentVNode("",!0)]),xe.value||X.value>0?(e.openBlock(),e.createElementBlock("div",{key:1,"data-testid":"item-footer-container",class:"w-full",style:e.normalizeStyle(je.value)},[e.createVNode(e.unref(y),{"slot-fn":Q.value,"slot-props":{item:n.item,remove:()=>{}}},null,8,["slot-fn","slot-props"])],4)):e.createCommentVNode("",!0)],4))),128))],4)),e.createElementVNode("div",wn,[ne.value?(e.openBlock(),e.createElementBlock("span",kn,o[1]||(o[1]=[e.createElementVNode("svg",{class:"h-4 w-4 animate-spin text-slate-500",viewBox:"0 0 24 24","aria-hidden":"true"},[e.createElementVNode("circle",{class:"opacity-25",cx:"12",cy:"12",r:"10",fill:"none",stroke:"currentColor","stroke-width":"4"}),e.createElementVNode("path",{class:"opacity-75",fill:"currentColor",d:"M4 12a8 8 0 0 1 8-8v4a4 4 0 0 0-4 4H4z"})],-1),e.createElementVNode("span",null,"Loading more…",-1)]))):V.value==null?(e.openBlock(),e.createElementBlock("span",bn,"End of list")):(e.openBlock(),e.createElementBlock("span",xn,"Scroll to load page "+e.toDisplayString(V.value),1))])],36)],16))}}),Bt=e.defineComponent({name:"MasonryItem",setup(l,{slots:x,attrs:u}){const a=e.inject(xt,null);if(!a)return()=>null;const v=u.onPreloaded,k=u.onFailed,y=x.overlay,p=x.default;return a({header:x.header,loader:x.loader,overlay:y??p,error:x.error,footer:x.footer,onPreloaded:typeof v=="function"?v:Array.isArray(v)?c=>{for(const h of v)typeof h=="function"&&h(c)}:void 0,onFailed:typeof k=="function"?k:Array.isArray(k)?c=>{for(const h of k)typeof h=="function"&&h(c)}:void 0}),()=>null}}),In={install(l){l.component("Masonry",Mt),l.component("MasonryItem",Bt),l.component("MasonryVideoControls",qe)}};exports.Masonry=Mt;exports.MasonryItem=Bt;exports.MasonryVideoControls=qe;exports.VibePlugin=In;exports.masonryDefaults=bt;
1
+ Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:`Module`}});let e=require(`vue`);var t=e=>{for(let t in e)if(t.startsWith(`aria-`)||t===`role`||t===`title`)return!0;return!1},n=e=>e===``,r=(...e)=>e.filter((e,t,n)=>!!e&&e.trim()!==``&&n.indexOf(e)===t).join(` `).trim(),i=e=>e.replace(/([a-z0-9])([A-Z])/g,`$1-$2`).toLowerCase(),a=e=>e.replace(/^([A-Z])|[\s-_]+(\w)/g,(e,t,n)=>n?n.toUpperCase():t.toLowerCase()),o=e=>{let t=a(e);return t.charAt(0).toUpperCase()+t.slice(1)},s={xmlns:`http://www.w3.org/2000/svg`,width:24,height:24,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":2,"stroke-linecap":`round`,"stroke-linejoin":`round`},c=({name:a,iconNode:c,absoluteStrokeWidth:l,"absolute-stroke-width":u,strokeWidth:d,"stroke-width":f,size:p=s.width,color:m=s.stroke,...h},{slots:g})=>(0,e.h)(`svg`,{...s,...h,width:p,height:p,stroke:m,"stroke-width":n(l)||n(u)||l===!0||u===!0?Number(d||f||s[`stroke-width`])*24/Number(p):d||f||s[`stroke-width`],class:r(`lucide`,h.class,...a?[`lucide-${i(o(a))}-icon`,`lucide-${i(a)}`]:[`lucide-icon`]),...!g.default&&!t(h)&&{"aria-hidden":`true`}},[...c.map(t=>(0,e.h)(...t)),...g.default?[g.default()]:[]]),l=(t,n)=>(r,{slots:i,attrs:a})=>(0,e.h)(c,{...a,...r,iconNode:n,name:t},i),u=l(`arrow-left`,[[`path`,{d:`m12 19-7-7 7-7`,key:`1l729n`}],[`path`,{d:`M19 12H5`,key:`x3x0zl`}]]),d=l(`audio-lines`,[[`path`,{d:`M2 10v3`,key:`1fnikh`}],[`path`,{d:`M6 6v11`,key:`11sgs0`}],[`path`,{d:`M10 3v18`,key:`yhl04a`}],[`path`,{d:`M14 8v7`,key:`3a1oy3`}],[`path`,{d:`M18 5v13`,key:`123xd1`}],[`path`,{d:`M22 10v3`,key:`154ddg`}]]),f=l(`clapperboard`,[[`path`,{d:`m12.296 3.464 3.02 3.956`,key:`qash78`}],[`path`,{d:`M20.2 6 3 11l-.9-2.4c-.3-1.1.3-2.2 1.3-2.5l13.5-4c1.1-.3 2.2.3 2.5 1.3z`,key:`1h7j8b`}],[`path`,{d:`M3 11h18v8a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z`,key:`4lm6w1`}],[`path`,{d:`m6.18 5.276 3.1 3.899`,key:`zjj9t3`}]]),p=l(`file`,[[`path`,{d:`M6 22a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h8a2.4 2.4 0 0 1 1.704.706l3.588 3.588A2.4 2.4 0 0 1 20 8v12a2 2 0 0 1-2 2z`,key:`1oefj6`}],[`path`,{d:`M14 2v5a1 1 0 0 0 1 1h5`,key:`wfsgrz`}]]),m=l(`image-plus`,[[`path`,{d:`M16 5h6`,key:`1vod17`}],[`path`,{d:`M19 2v6`,key:`4bpg5p`}],[`path`,{d:`M21 11.5V19a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h7.5`,key:`1ue2ih`}],[`path`,{d:`m21 15-3.086-3.086a2 2 0 0 0-2.828 0L6 21`,key:`1xmnt7`}],[`circle`,{cx:`9`,cy:`9`,r:`2`,key:`af1f0g`}]]),h=l(`loader-circle`,[[`path`,{d:`M21 12a9 9 0 1 1-6.219-8.56`,key:`13zald`}]]),g=l(`pause`,[[`rect`,{x:`14`,y:`3`,width:`5`,height:`18`,rx:`1`,key:`kaeet6`}],[`rect`,{x:`5`,y:`3`,width:`5`,height:`18`,rx:`1`,key:`1wsw3u`}]]),_=l(`play`,[[`path`,{d:`M5 5a2 2 0 0 1 3.008-1.728l11.997 6.998a2 2 0 0 1 .003 3.458l-12 7A2 2 0 0 1 5 19z`,key:`10ikf1`}]]),v=l(`triangle-alert`,[[`path`,{d:`m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3`,key:`wmoenq`}],[`path`,{d:`M12 9v4`,key:`juzpu7`}],[`path`,{d:`M12 17h.01`,key:`p32p05`}]]);function y(e,t=150){return x(e,e=>`${e.surface}|${e.occurrenceKey}|${e.url}|${e.kind}`,t)}function b(e,t=150){return x(e,e=>`${e.surface}|${e.occurrenceKey}|${e.url}`,t)}function x(e,t,n){let r=[],i=new Set,a=null;function o(e){let o=t(e);i.has(o)||(i.add(o),r.push(e),!a&&(a=setTimeout(()=>{s()},n)))}function s(){if(a&&=(clearTimeout(a),null),!r.length)return;let t=r.slice();r.length=0,i.clear(),e(t)}function c(){a&&=(clearTimeout(a),null),r.length=0,i.clear()}return{flush:s,report:o,stop:c}}function S(e){return e instanceof HTMLElement&&[`INPUT`,`TEXTAREA`,`SELECT`].includes(e.tagName)}function C(e){return e instanceof HTMLElement&&!!e.closest(`[data-swipe-lock], input, textarea, select, a`)}var w=`__vibeOccurrenceKey`;function T(e){let t=e[w];return typeof t==`string`&&t.length>0?t:e.id}function E(e,t,n){let r=new Map,i=[],a=n;for(let e of t){let t=r.get(e.id),n=T(e);t?t.push(n):r.set(e.id,[n])}for(let t of e){let e=r.get(t.id)?.shift()??`vibe-occurrence-${a+=1}`;i.push(D(t,e))}return{items:i,nextSequence:a}}function D(e,t){return T(e)===t?e:{...e,[w]:t}}function O(){let t=(0,e.ref)(new Set),n=(0,e.ref)([]);function r(e){let r=k(e).filter(e=>!t.value.has(e));if(!r.length)return{ids:[]};let i=new Set(t.value);for(let e of r)i.add(e);return t.value=i,n.value=[...n.value,r],{ids:r}}function i(e){let n=k(e).filter(e=>t.value.has(e));if(!n.length)return{ids:[]};let r=new Set(t.value);for(let e of n)r.delete(e);return t.value=r,{ids:n}}function a(){if(!n.value.length)return null;let e=[...n.value],r=e.pop()??[];n.value=e;let i=r.filter(e=>t.value.has(e));if(!i.length)return{ids:[]};let a=new Set(t.value);for(let e of i)a.delete(e);return t.value=a,{ids:i}}function o(){!t.value.size&&!n.value.length||(t.value=new Set,n.value=[])}function s(){return Array.from(t.value)}return{clearRemoved:o,getRemovedIds:s,remove:r,removedIds:t,restore:i,undo:a}}function k(e){let t=Array.isArray(e)?e:[e];return Array.from(new Set(t.filter(e=>typeof e==`string`&&e.length>0)))}function A(e){return e.flatMap(e=>e.items)}function j(e,t){return t.size?e.filter(e=>!t.has(e.id)):e}function M(e,t){return j(e.items,t)}function N(e,t){return M(e,t).length}function P(e,t,n){if(n<0)return null;let r=0;for(let i of e){let e=M(i,t),a=r+e.length;if(n<a)return i.cursor;r=a}return null}function F(e,t,n){let r=[...e],i=r.findIndex(e=>e.cursor===t);return i>=0&&r.splice(i,1,n),r}function I(e,t,n){let r=E(e,t,n);return{items:r.items,nextSequence:r.nextSequence}}function L(e){return e===`filling`||e===`loading`||e===`reloading`}function R(e){return!e||!Number.isFinite(e)||e<1?25:Math.floor(e)}function z(e){return e??`__vibe_initial_cursor__`}function B(e,t,n){return Math.min(Math.max(e,t),n)}function V(e){return e instanceof DOMException&&e.name===`AbortError`||e instanceof Error&&(e.name===`AbortError`||e.name===`CanceledError`)?!0:typeof e==`object`&&!!e&&`code`in e&&e.code===`ERR_CANCELED`}function H(e){let t=I(e.nextItems,e.previousItems,e.sequence);return{bucket:{cursor:e.cursor,items:t.items,nextCursor:e.nextCursor,previousCursor:e.previousCursor},nextSequence:t.nextSequence}}function U(e,t,n,r){if(!e.length)return r?null:{buckets:[],canceled:r,visibleCount:0};let i=t===`backward`?[...e].reverse():e;return{buckets:i,canceled:r,visibleCount:i.reduce((e,t)=>e+N(t,n),0)}}function W(e){let t=H({cursor:e.initialState.cursor,nextCursor:e.initialState.nextCursor??null,nextItems:e.initialState.items,previousCursor:e.initialState.previousCursor??null,previousItems:[],sequence:e.sequence}),n=j(t.bucket.items,e.removedIds);return{activeIndex:B(e.initialState.activeIndex??0,0,Math.max(0,n.length-1)),buckets:[t.bucket],nextSequence:t.nextSequence}}function G(e,t){let n=e[B(t,0,Math.max(0,e.length-1))];return n?T(n):null}function K(e,t,n=null){if(!e.length)return 0;let r=n?e.findIndex(e=>T(e)===n):-1;return r>=0?r:B(t,0,e.length-1)}function ee(e,t,n){return e?N(e,t)<n:!1}var te=1e3,q=100;function ne(e,t=te,n=250){return t+Math.max(0,e-1)*n}function re(e,t){return!Number.isFinite(e)||e==null||e<0?t:Math.floor(e)}function ie(){let t=(0,e.ref)(null),n=null,r=null,i=null;function a(e=!1){if(n&&=(clearInterval(n),null),r&&=(clearTimeout(r),null),t.value=null,e&&i){let e=i;i=null,e()}}async function o(e){a(!0),!(e<=0)&&(t.value=e,await new Promise(o=>{let s=Date.now(),c=!1,l=()=>{c||(c=!0,i=null,a(),o())};i=l;let u=()=>{let n=Math.max(0,e-(Date.now()-s));t.value=n,n<=0&&l()};n=setInterval(u,q),r=setTimeout(l,e),u()}))}return{clear:a,remainingMs:t,wait:o}}function ae(t){let n=(0,e.ref)([]),r=(0,e.ref)(0),i=(0,e.ref)([]),a=(0,e.ref)(null),o=(0,e.ref)(`idle`),s=(0,e.ref)(null),c=ie(),l=c.remainingMs,u=(0,e.ref)(null),d=(0,e.ref)(!1),f=(0,e.ref)(!0),p=new Set,m=null,h=null,g=0,_=0,v=(0,e.computed)(()=>re(t.fillDelayMs,te)),y=(0,e.computed)(()=>re(t.fillDelayStepMs,250)),b=(0,e.computed)(()=>t.mode??`dynamic`),x=(0,e.computed)(()=>R(t.pageSize)),S=(0,e.computed)(()=>A(n.value)),C=(0,e.computed)(()=>j(S.value,t.removedIds.value)),w=(0,e.computed)(()=>r.value),T=(0,e.computed)(()=>L(o.value)||d.value),E=(0,e.computed)(()=>n.value[0]??null),D=(0,e.computed)(()=>n.value[n.value.length-1]??null),O=(0,e.computed)(()=>D.value?.nextCursor??null),k=(0,e.computed)(()=>E.value?.previousCursor??null),M=(0,e.computed)(()=>!!O.value),I=(0,e.computed)(()=>!!k.value),q=(0,e.computed)(()=>j(A(i.value),t.removedIds.value)),ae=(0,e.computed)(()=>P(n.value,t.removedIds.value,w.value)),oe=(0,e.computed)(()=>!C.value.length&&!T.value&&!!a.value);(0,e.watch)(()=>C.value.length,e=>{if(e===0){r.value=0;return}r.value>e-1&&(r.value=e-1)}),(0,e.watch)(()=>r.value,()=>{f.value&&ye()}),(0,e.onMounted)(()=>{t.resolve&&(Te()||se())}),(0,e.onBeforeUnmount)(()=>{m?.abort(),m=null,c.clear(!0)});async function se(){h=se;let e=await Ce({continueUntilFilled:b.value===`dynamic`,cursor:t.initialCursor??null,direction:`forward`,phase:`loading`});e&&(n.value=e.buckets,r.value=0,J())}async function ce(){if(!(!M.value||T.value)){if(b.value===`static`&&De(`trailing`))return Se(`trailing`);await be(O.value)}}async function le(){if(!(!I.value||T.value)){if(b.value===`static`&&De(`leading`))return Se(`leading`);await xe(k.value)}}async function ue(){if(oe.value){if(n.value=[],r.value=0,i.value=[],a.value=null,o.value=`idle`,s.value=null,u.value=null,d.value=!1,p.clear(),m?.abort(),m=null,c.clear(!0),Te()){J();return}await se()}}async function de(){if(oe.value)return ue();o.value!==`failed`||!h||(a.value=null,await h())}async function fe(){if(!i.value.length)return d.value=!1,J();n.value=[...n.value,...i.value],i.value=[],d.value=!1,J()}function pe(e){let n=C.value;if(!n.length)return;let i=B(e,0,n.length-1);i!==r.value&&(r.value=i,t.emit(`update:activeIndex`,i))}function me(e){f.value=e}function he(){g+=1,m?.abort(),m=null,c.clear(!0),p.clear(),a.value=null,s.value=null,u.value=null,i.value.length>0&&(n.value=[...n.value,...i.value],i.value=[]),d.value=!1,J()}function ge(){return G(C.value,w.value)}function _e(e=null){r.value=K(C.value,w.value,e)}function ve(){i.value.length>0&&!q.value.length&&fe()}async function ye(){!C.value.length||Ee()||(I.value&&r.value<3&&await le(),M.value&&r.value>=C.value.length-3&&await ce())}async function be(e){h=async()=>{await be(e)};let t=await Ce({continueUntilFilled:b.value===`dynamic`,cursor:e,direction:`forward`,phase:`loading`});if(t){if(t.canceled)return n.value=[...n.value,...t.buckets],i.value=[],d.value=!1,J();if(i.value=t.buckets,!q.value.length)return n.value=[...n.value,...i.value],i.value=[],d.value=!1,J();d.value=!0}}async function xe(e){h=async()=>{await xe(e)};let t=await Ce({continueUntilFilled:b.value===`dynamic`,cursor:e,direction:`backward`,phase:`loading`});if(!t)return;let r=ge();n.value=[...t.buckets,...n.value],_e(r),J()}async function Se(e){if(h=async()=>{await Se(e)},!t.resolve)return;let r=e===`leading`?E.value:D.value;if(!r)return;let i=z(r.cursor);if(p.has(i))return;p.add(i),a.value=null,o.value=`reloading`,s.value=null,u.value=null;let c=++g,l=typeof AbortController>`u`?null:new AbortController;m=l;try{let e=await t.resolve({cursor:r.cursor,pageSize:x.value,signal:l?.signal});if(c!==g)return J();let i=we({cursor:r.cursor,nextCursor:e.nextPage,nextItems:e.items,previousCursor:e.previousPage??null,previousItems:r.items}),a=ge();n.value=F(n.value,r.cursor,i),_e(a),J()}catch(e){if(V(e)||c!==g){J();return}a.value=e instanceof Error?e.message:`The viewer could not load items.`,o.value=`failed`,s.value=null,u.value=null}finally{m===l&&(m=null),p.delete(i)}}async function Ce(e){if(!t.resolve)return null;let n=++g,r=new Set,i=[],l=e.cursor,d=0;for(a.value=null,o.value=e.phase,s.value=null,u.value=null;;){if(n!==g)return U(i,e.direction,t.removedIds.value,!0);let f=z(l);if(r.has(f)||p.has(f))break;r.add(f),p.add(f);let h=typeof AbortController>`u`?null:new AbortController;m=h;try{let r=await t.resolve({cursor:l,pageSize:x.value,signal:h?.signal});if(n!==g)return U(i,e.direction,t.removedIds.value,!0);let a=we({cursor:l,nextCursor:r.nextPage,nextItems:r.items,previousCursor:r.previousPage??null,previousItems:[]});i.push(a);let f=i.reduce((e,n)=>e+N(n,t.removedIds.value),0),p=e.direction===`forward`?a.nextCursor:a.previousCursor;if(!e.continueUntilFilled||f>=x.value||!p)return{canceled:!1,buckets:e.direction===`backward`?[...i].reverse():i,visibleCount:f};o.value=`filling`,s.value=f,u.value=x.value,d+=1;let m=ne(d,v.value,y.value);if(await c.wait(m),n!==g)return U(i,e.direction,t.removedIds.value,!0);l=p}catch(r){return V(r)||n!==g?U(i,e.direction,t.removedIds.value,!0):(a.value=r instanceof Error?r.message:`The viewer could not load items.`,o.value=`failed`,s.value=null,u.value=null,null)}finally{m===h&&(m=null),p.delete(f)}}return U(i,e.direction,t.removedIds.value,!1)}function we(e){let t=H({cursor:e.cursor,nextCursor:e.nextCursor,nextItems:e.nextItems,previousCursor:e.previousCursor,previousItems:e.previousItems,sequence:_});return _=t.nextSequence,t.bucket}function J(){o.value=`idle`,s.value=null,u.value=null,c.clear()}function Te(){if(!t.initialState||!t.initialState.items.length)return!1;let e=W({initialState:t.initialState,removedIds:t.removedIds.value,sequence:_});return n.value=e.buckets,r.value=e.activeIndex,_=e.nextSequence,a.value=null,i.value=[],d.value=!1,!0}function Ee(){return o.value===`loading`&&n.value.length===0&&i.value.length===0}function De(e){return ee(e===`leading`?E.value:D.value,t.removedIds.value,x.value)}return{activeIndex:w,canRetryInitialLoad:oe,cancel:he,commitPendingAppend:fe,currentCursor:ae,errorMessage:a,fillCollectedCount:s,fillDelayRemainingMs:l,fillTargetCount:u,hasNextPage:M,hasPreviousPage:I,items:C,loading:T,mode:b,nextCursor:O,pendingAppendItems:q,phase:o,prefetchNextPage:ce,prefetchPreviousPage:le,previousCursor:k,retryInitialLoad:ue,retry:de,setActiveIndex:pe,setAutoPrefetchEnabled:me,syncActiveIndexAfterVisibilityChange:_e,getActiveOccurrenceKey:ge,maybeCommitPendingAppendWhenFilteredOut:ve}}function oe(t,n){let r=t,i=t,{clearRemoved:a,getRemovedIds:o,remove:s,removedIds:c,restore:l,undo:u}=O(),d=ae({emit:n,fillDelayMs:i.fillDelayMs,fillDelayStepMs:i.fillDelayStepMs,initialCursor:i.initialCursor,initialState:i.initialState,mode:i.mode,pageSize:i.pageSize,removedIds:c,resolve:i.resolve}),f=!1,p=0,m=(0,e.ref)([]),h=(0,e.computed)(()=>typeof i.resolve==`function`),g=(0,e.computed)(()=>c.value.size?m.value.filter(e=>!c.value.has(e.id)):m.value),_=(0,e.computed)(()=>h.value?d.items.value:g.value),v=(0,e.computed)(()=>h.value?d.activeIndex.value:r.activeIndex??0),y=(0,e.computed)(()=>h.value?d.loading.value:r.loading??!1),b=(0,e.computed)(()=>h.value?d.hasNextPage.value:r.hasNextPage??!1),x=(0,e.computed)(()=>h.value?d.hasPreviousPage.value:r.hasPreviousPage??!1),S=(0,e.computed)(()=>c.value.size),C=(0,e.computed)(()=>r.paginationDetail??null);(0,e.watch)([()=>r.items,()=>i.resolve],([e,t])=>{!Array.isArray(e)||typeof t!=`function`||f||(f=!0,console.warn("[Vibe] `resolve` and `items` were both provided. `resolve` mode will be used."))},{immediate:!0}),(0,e.watch)(()=>r.items??[],e=>{if(h.value)return;let t=E(e,m.value,p);m.value=t.items,p=t.nextSequence},{deep:!0,immediate:!0});function w(e){let t=_.value;if(!t.length)return;let i=P(e,0,t.length-1);if(h.value){d.setActiveIndex(i);return}i!==(r.activeIndex??0)&&n(`update:activeIndex`,i)}function D(e){let t=M(),n=s(e);return n.ids.length?h.value?(d.maybeCommitPendingAppendWhenFilteredOut(),d.syncActiveIndexAfterVisibilityChange(t),n):(N(t),n):n}function k(e){let t=M(),n=l(e);return n.ids.length?h.value?(d.syncActiveIndexAfterVisibilityChange(t),n):(N(t),n):n}function A(){let e=M(),t=u();return t?.ids.length?h.value?(d.syncActiveIndexAfterVisibilityChange(e),t):(N(e),t):t}function j(){let e=M();if(a(),h.value){d.syncActiveIndexAfterVisibilityChange(e);return}N(e)}function M(){let e=_.value[P(v.value,0,Math.max(0,_.value.length-1))];return e?T(e):null}function N(e=null){if(!_.value.length)return;let t=e?_.value.findIndex(t=>T(t)===e):-1,i=t>=0?t:P(v.value,0,_.value.length-1);i!==(r.activeIndex??0)&&n(`update:activeIndex`,i)}function P(e,t,n){return Math.min(Math.max(e,t),n)}function F(){h.value&&d.cancel()}async function I(){if(h.value){await d.prefetchNextPage();return}y.value||typeof r.requestNextPage!=`function`||await r.requestNextPage()}async function L(){if(h.value){await d.prefetchPreviousPage();return}y.value||typeof r.requestPreviousPage!=`function`||await r.requestPreviousPage()}async function R(){h.value&&await d.retry()}return{activeIndex:v,canRetryInitialLoad:(0,e.computed)(()=>h.value?d.canRetryInitialLoad.value:!1),cancel:F,clearRemoved:j,commitPendingAppend:d.commitPendingAppend,currentCursor:(0,e.computed)(()=>h.value?d.currentCursor.value:null),errorMessage:(0,e.computed)(()=>h.value?d.errorMessage.value:null),fillCollectedCount:(0,e.computed)(()=>h.value?d.fillCollectedCount.value:null),fillDelayRemainingMs:(0,e.computed)(()=>h.value?d.fillDelayRemainingMs.value:null),fillTargetCount:(0,e.computed)(()=>h.value?d.fillTargetCount.value:null),getRemovedIds:o,hasNextPage:b,hasPreviousPage:x,isAutoMode:h,items:_,loading:y,loadNext:I,loadPrevious:L,mode:(0,e.computed)(()=>h.value?d.mode.value:null),nextCursor:(0,e.computed)(()=>h.value?d.nextCursor.value:null),paginationDetail:C,pendingAppendItems:d.pendingAppendItems,phase:(0,e.computed)(()=>h.value?d.phase.value:y.value?`loading`:`idle`),prefetchNextPage:h.value?d.prefetchNextPage:async()=>{y.value||typeof r.requestNextPage!=`function`||await r.requestNextPage()},prefetchPreviousPage:h.value?d.prefetchPreviousPage:async()=>{y.value||typeof r.requestPreviousPage!=`function`||await r.requestPreviousPage()},previousCursor:(0,e.computed)(()=>h.value?d.previousCursor.value:null),removedCount:S,remove:D,restore:k,retry:R,retryInitialLoad:d.retryInitialLoad,setActiveIndex:w,setAutoPrefetchEnabled:d.setAutoPrefetchEnabled,undo:A}}var se=1024;function ce(t,n){let r=oe(t,n),i=(0,e.ref)(0),a=(0,e.ref)(`list`),o=(0,e.ref)(0),s=(0,e.reactive)({activeIndex:0,currentCursor:null,errorMessage:null,fillCollectedCount:null,fillDelayRemainingMs:null,fillTargetCount:null,hasNextPage:!1,hasPreviousPage:!1,isAutoMode:!1,itemCount:0,loadState:`loaded`,mode:null,nextCursor:null,phase:`idle`,previousCursor:null,removedCount:0,surfaceMode:`list`}),c=(0,e.computed)(()=>i.value>=se),l=(0,e.computed)(()=>c.value?a.value:`fullscreen`),u=(0,e.computed)(()=>c.value&&l.value===`fullscreen`);(0,e.watch)(c,(e,t)=>{e&&!t&&a.value===`list`&&(o.value+=1)}),(0,e.watch)([l,()=>r.pendingAppendItems.value.length],([e,t])=>{e===`list`||t<=0||r.commitPendingAppend()}),(0,e.watch)(l,e=>{r.setAutoPrefetchEnabled(e===`fullscreen`)},{immediate:!0}),(0,e.watchEffect)(()=>{s.activeIndex=r.activeIndex.value,s.currentCursor=r.currentCursor.value,s.errorMessage=r.errorMessage.value,s.fillCollectedCount=r.fillCollectedCount.value,s.fillDelayRemainingMs=r.fillDelayRemainingMs.value,s.fillTargetCount=r.fillTargetCount.value,s.hasNextPage=r.hasNextPage.value,s.hasPreviousPage=r.hasPreviousPage.value,s.isAutoMode=r.isAutoMode.value,s.itemCount=r.items.value.length,s.loadState=r.loading.value?`loading`:r.errorMessage.value?`failed`:`loaded`,s.mode=r.mode.value,s.nextCursor=r.nextCursor.value,s.phase=r.phase.value,s.previousCursor=r.previousCursor.value,s.removedCount=r.removedCount.value,s.surfaceMode=l.value}),(0,e.onMounted)(()=>{m(),window.addEventListener(`keydown`,p),window.addEventListener(`resize`,m)}),(0,e.onBeforeUnmount)(()=>{window.removeEventListener(`keydown`,p),window.removeEventListener(`resize`,m)});function d(e){r.setActiveIndex(e),c.value&&(a.value=`fullscreen`)}function f(){c.value&&(a.value=`list`,o.value+=1)}function p(e){e.defaultPrevented||e.key!==`Escape`||!c.value||l.value!==`fullscreen`||S(e.target)||(e.preventDefault(),f())}function m(){i.value=window.innerWidth||0}return{...r,cancel:r.cancel,isDesktop:c,listRestoreToken:o,loadNext:r.loadNext,loadPrevious:r.loadPrevious,openFullscreen:d,returnToList:f,retry:r.retry,showBackToList:u,status:(0,e.readonly)(s),surfaceMode:l}}var le={"data-testid":`vibe-media-bar`,class:`absolute inset-x-0 bottom-0 z-[5] bg-[linear-gradient(180deg,transparent,rgba(0,0,0,0.42)_24%,rgba(0,0,0,0.78))] px-[clamp(1rem,2.6vw,2.25rem)] pt-4 pb-[1.15rem]`},ue={class:`grid grid-cols-[auto_minmax(0,1fr)_auto] items-center gap-3 border-t border-white/12 bg-black/70 px-4 py-3 backdrop-blur-[18px]`},de={class:`text-[0.76rem] font-bold uppercase tracking-[0.18em] text-[#f7f1ea]/74`},fe={class:`relative h-4 w-full`},pe=[`max`,`value`,`disabled`],me={class:`text-[0.76rem] font-bold uppercase tracking-[0.18em] text-[#f7f1ea]/74`},he=(0,e.defineComponent)({__name:`FullscreenMediaBar`,props:{currentTime:{},currentTimeLabel:{},duration:{},durationLabel:{},progress:{}},emits:[`seek-input`],setup(t,{emit:n}){let r=t,i=n;return(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,le,[(0,e.createElementVNode)(`div`,ue,[(0,e.createElementVNode)(`span`,de,(0,e.toDisplayString)(r.currentTimeLabel),1),(0,e.createElementVNode)(`div`,fe,[n[1]||=(0,e.createElementVNode)(`div`,{class:`absolute inset-x-0 top-1/2 h-px -translate-y-1/2 bg-white/12`},null,-1),(0,e.createElementVNode)(`div`,{class:`absolute left-0 top-1/2 h-px -translate-y-1/2 bg-[#f7f1ea]`,style:(0,e.normalizeStyle)({width:`${r.progress}%`})},null,4),(0,e.createElementVNode)(`input`,{"data-swipe-lock":`true`,type:`range`,"aria-label":`Seek active media`,min:`0`,step:`0.1`,max:r.duration||1,value:r.currentTime,disabled:r.duration<=0,class:`vibe-media-slider absolute inset-0 z-10 h-4 w-full cursor-pointer bg-transparent disabled:cursor-default disabled:opacity-50`,onInput:n[0]||=e=>i(`seek-input`,e)},null,40,pe)]),(0,e.createElementVNode)(`span`,me,(0,e.toDisplayString)(r.durationLabel),1)])]))}}),ge={class:`pointer-events-none absolute inset-0 z-[3] flex flex-col justify-between p-[clamp(1.25rem,2.6vw,2.25rem)]`},_e={class:`grid gap-4`},ve={class:`flex min-h-11 items-center justify-between gap-4`},ye={class:`min-w-0 flex flex-1 items-center gap-3`},be={key:1,"data-testid":`vibe-title`,class:`m-0 truncate text-left text-[0.82rem] leading-none tracking-[-0.04em] min-[721px]:text-[1.2rem]`},xe={class:`pointer-events-auto flex shrink-0 items-center gap-2`},Se={"data-testid":`vibe-pagination`,class:`inline-flex shrink-0 items-center gap-2 whitespace-nowrap border border-white/14 bg-black/40 px-3 py-2 text-[0.63rem] font-bold uppercase tracking-[0.12em] text-[#f7f1ea]/72 backdrop-blur-[18px] min-[721px]:gap-3 min-[721px]:px-4 min-[721px]:py-3 min-[721px]:text-[0.74rem] min-[721px]:tracking-[0.2em]`},Ce={class:`whitespace-nowrap`},we={key:0,class:`whitespace-nowrap border-l border-white/12 pl-2 text-[#f7f1ea]/56 min-[721px]:pl-3`},J={key:0,class:`grid gap-2 max-[720px]:justify-items-start`},Te=(0,e.defineComponent)({__name:`FullscreenHeader`,props:{currentIndex:{},paginationDetail:{},showBackToList:{type:Boolean},showEndBadge:{type:Boolean},title:{},total:{}},emits:[`back-to-list`],setup(t,{emit:n}){let r=t,i=n;return(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,ge,[(0,e.createElementVNode)(`div`,_e,[(0,e.createElementVNode)(`div`,ve,[(0,e.createElementVNode)(`div`,ye,[r.showBackToList?((0,e.openBlock)(),(0,e.createElementBlock)(`button`,{key:0,type:`button`,"data-testid":`vibe-back-to-list`,class:`pointer-events-auto inline-flex h-11 w-11 shrink-0 items-center justify-center border border-white/14 bg-black/40 text-[#f7f1ea]/78 backdrop-blur-[18px] transition hover:border-white/28 hover:bg-black/55`,"aria-label":`Back to list`,onClick:n[0]||=e=>i(`back-to-list`)},[(0,e.createVNode)((0,e.unref)(u),{class:`h-4 w-4 stroke-[2.2]`,"aria-hidden":`true`})])):(0,e.createCommentVNode)(``,!0),r.title?((0,e.openBlock)(),(0,e.createElementBlock)(`h2`,be,(0,e.toDisplayString)(r.title),1)):(0,e.createCommentVNode)(``,!0)]),(0,e.createElementVNode)(`div`,xe,[(0,e.createElementVNode)(`span`,Se,[(0,e.createElementVNode)(`span`,Ce,(0,e.toDisplayString)(r.currentIndex+1)+` / `+(0,e.toDisplayString)(r.total),1),r.paginationDetail?((0,e.openBlock)(),(0,e.createElementBlock)(`span`,we,(0,e.toDisplayString)(r.paginationDetail),1)):(0,e.createCommentVNode)(``,!0)]),(0,e.renderSlot)(t.$slots,`actions`)])])]),r.showEndBadge?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,J,[...n[1]||=[(0,e.createElementVNode)(`span`,{class:`inline-flex items-center border border-amber-300/35 bg-black/40 px-4 py-3 text-[0.74rem] font-bold uppercase tracking-[0.2em] text-amber-200 backdrop-blur-[18px]`},` End reached `,-1)]])):(0,e.createCommentVNode)(``,!0)]))}});function Ee(e){if(!Number.isFinite(e)||e<=0)return`0:00`;let t=Math.floor(e),n=Math.floor(t/3600),r=Math.floor(t%3600/60),i=t%60;return n>0?`${n}:${String(r).padStart(2,`0`)}:${String(i).padStart(2,`0`)}`:`${r}:${String(i).padStart(2,`0`)}`}function De(t){let n=!1;(0,e.watch)(t.enabled,async e=>{if(r(e),e){t.onResize(),await t.onEnable();return}t.onDisable()},{immediate:!0}),(0,e.onMounted)(()=>{t.onResize(),t.enabled.value&&t.onEnable()}),(0,e.onBeforeUnmount)(()=>{r(!1),t.onDisable()});function r(e){if(e&&!n){window.addEventListener(`resize`,t.onResize),window.addEventListener(`keydown`,t.onKeydown),n=!0;return}!e&&n&&(window.removeEventListener(`resize`,t.onResize),window.removeEventListener(`keydown`,t.onKeydown),n=!1)}}var Oe={currentTime:0,duration:0,errorKind:null,paused:!0,ready:!1};function ke(){return{...Oe}}function Ae(e){return e.complete&&!!(e.currentSrc||e.getAttribute(`src`))}function je(e,t,n){e.currentTime=Number.isFinite(t.currentTime)?t.currentTime:0,e.duration=Number.isFinite(t.duration)?t.duration:0,e.paused=t.paused,n&&n!==`error`&&(e.errorKind=null),e.ready=Me(t,n)}function Me(e,t){return t===`error`||t===`loadstart`||t===`waiting`||t===`stalled`?!1:t===`canplay`||t===`canplaythrough`||t===`playing`?!0:e.readyState>=HTMLMediaElement.HAVE_CURRENT_DATA}var Ne=new Map;function Pe(e){return e===`not-found`?`404`:`Load error`}function Fe(e){return e===`generic`}function Ie(e){let t=Ne.get(e);if(t)return t;let n=Le(e);return Ne.set(e,n),n}async function Le(e){if(!Re(e))return`generic`;try{let t=await fetch(e,{method:`HEAD`});if(!t.ok&&t.status===404)return`not-found`}catch{return`generic`}return`generic`}function Re(e){return/^(https?:\/\/|\/)/i.test(e)}function ze(e){try{let t=e.play();t&&typeof t.catch==`function`&&t.catch(()=>{})}catch{}}function Be(t){let n=(0,e.ref)({}),r=(0,e.ref)({}),i=(0,e.ref)({}),a=(0,e.ref)({}),o=new Map,s=new Map,c=new Set,l=(0,e.computed)(()=>t.activeItem.value?T(t.activeItem.value):null),u=(0,e.computed)(()=>t.activeMediaItem.value?T(t.activeMediaItem.value):null),d=(0,e.computed)(()=>u.value?i.value[u.value]??Oe:Oe),f=(0,e.computed)(()=>u.value?d.value.duration:0),p=(0,e.computed)(()=>f.value<=0?0:Ve(d.value.currentTime/f.value*100,0,100)),m=(0,e.computed)(()=>l.value?j(l.value):null);(0,e.watch)(()=>l.value,async()=>{await y()}),(0,e.watch)(()=>t.itemCount.value,async()=>{await y()});function h(e,t){if(t instanceof HTMLVideoElement){o.set(e,t),z(e,t);return}o.delete(e)}function g(e,t){if(t instanceof HTMLAudioElement){s.set(e,t),z(e,t);return}s.delete(e)}function _(e,t){t instanceof HTMLImageElement&&Ae(t)&&(n.value[e]=!0,r.value[e]=null,W(e,t.currentSrc||t.src||G()))}function v(){L(),a.value={},r.value={},n.value={},i.value={},c.clear()}async function y(){if(!t.isEnabled.value){L();return}await(0,e.nextTick)();let n=l.value;for(let[e,t]of o.entries()){if(e!==n||i.value[e]?.errorKind){I(t,e);continue}t.muted=!0,t.loop=!1,t.playsInline=!0,ze(t),z(e,t)}for(let[e,t]of s.entries()){if(e!==n||i.value[e]?.errorKind){I(t,e);continue}ze(t),z(e,t)}}function b(e,t){let n=t.currentTarget instanceof HTMLMediaElement?t.currentTarget:t.target instanceof HTMLMediaElement?t.target:null;if(n){let r=i.value[e]?.ready??!1;z(e,n,t.type);let a=i.value[e]?.ready??!1;!r&&a&&W(e,n.currentSrc||n.src||K())}}function x(e,t){n.value[e]=!0,r.value[e]=null,W(e,t)}async function S(e,i){let a=t.activeItem.value;n.value[e]=!1,r.value[e]=`generic`;let o=await Ie(i);r.value[e]=o,a&&t.onAssetError?.({item:a,occurrenceKey:e,url:i,kind:o,surface:`fullscreen`})}async function C(e,n){let r=V(e),i=R(e),a=t.activeMediaItem.value??t.activeItem.value;if(r){r.pause();try{r.currentTime=0}catch{}}i.currentTime=0,i.duration=0,i.paused=!0,i.ready=!1,i.errorKind=`generic`;let o=await Ie(n);i.errorKind=o,a&&t.onAssetError?.({item:a,occurrenceKey:e,url:n,kind:o,surface:`fullscreen`})}function w(e,t,n){e.button!==0||Date.now()<n||U(o.get(t)??null)}function E(e,t,n){e.button!==0||Date.now()<n||U(V(t))}function D(e){let t=H(),n=u.value;if(!t||!n||!(e.target instanceof HTMLInputElement))return;let r=Number.parseFloat(e.target.value);if(!Number.isFinite(r))return;let i=Ve(r,0,f.value||0);B(n,i,t),t.currentTime=i}function O(e){return!!n.value[e]&&!r.value[e]}function k(e){return(i.value[e]?.ready??!1)&&!i.value[e]?.errorKind}function A(e){return e.url}function j(e){return r.value[e]??i.value[e]?.errorKind??null}function M(e){let t=j(e);return t?Pe(t):null}function N(e){return Fe(j(e))}function P(e){return`${e}:${a.value[e]??0}`}async function F(t){if(!N(t))return;n.value[t]=!1,r.value[t]=null;let i=R(t);i.currentTime=0,i.duration=0,i.paused=!0,i.ready=!1,i.errorKind=null;let o=V(t);o&&I(o,t),c.forEach(e=>{e.startsWith(`${t}|`)&&c.delete(e)}),a.value[t]=(a.value[t]??0)+1,await(0,e.nextTick)(),await y()}function I(e,t){e.pause();try{e.currentTime=0}catch{}z(t,e)}function L(){for(let[e,t]of o.entries())I(t,e);for(let[e,t]of s.entries())I(t,e)}function R(e){return i.value[e]||(i.value[e]=ke()),i.value[e]}function z(e,t,n){je(R(e),t,n)}function B(e,t,n){let r=R(e);r.currentTime=t,r.duration=Number.isFinite(n.duration)?n.duration:r.duration,r.paused=n.paused}function V(e){return o.get(e)??s.get(e)??null}function H(){return u.value?V(u.value):null}function U(e){if(e){if(e.paused){ze(e);return}e.pause()}}function W(e,n){let r=t.activeMediaItem.value??t.activeItem.value;if(!r||!n)return;let i=`${e}|${n}`;c.has(i)||(c.add(i),t.onAssetLoad?.({item:r,occurrenceKey:e,surface:`fullscreen`,url:n}))}function G(){return t.activeItem.value?.url??null}function K(){return t.activeMediaItem.value?.url??t.activeItem.value?.url??null}return{activeAssetErrorKind:m,activeMediaDuration:f,activeMediaProgress:p,activeMediaState:d,getAssetErrorKind:j,getAssetErrorLabel:M,getAssetRenderKey:P,getImageSource:A,isImageReady:O,isMediaReady:k,canRetryAsset:N,mediaStates:i,onAudioCoverClick:E,onImageError:S,onImageLoad:x,onMediaError:C,onMediaEvent:b,onMediaSeekInput:D,onVideoClick:w,registerAudioElement:g,registerImageElement:_,registerVideoElement:h,resetMediaState:v,retryAsset:F,syncMediaPlayback:y}}function Ve(e,t,n){return Math.min(Math.max(e,t),n)}function He(e,t,n=2){return t<=0?{start:0,end:-1}:{start:Math.max(0,e-n),end:Math.min(t-1,e+n)}}function Ue(e,t,n=2){let r=He(t,e.length,n);return r.end<r.start?[]:e.slice(r.start,r.end+1).map((e,t)=>({item:e,index:r.start+t}))}function We(e,t,n,r,i){return{transform:`translate3d(0, ${(e-t)*n+r}px, 0)`,transition:i?`none`:`transform 320ms cubic-bezier(0.22, 1, 0.36, 1)`}}function Ge(t,n,r={}){let{activeIndex:i,canRetryInitialLoad:a,errorMessage:o,hasNextPage:s,items:c,loading:l,paginationDetail:u,retryInitialLoad:d,setActiveIndex:f}=oe(t,n),p=(0,e.ref)(null),m=(0,e.ref)(0),h=(0,e.ref)(!1),g=(0,e.ref)(1),_=r.enabled??(0,e.computed)(()=>!0),v=null,y=0,b=0,x=0,w=(0,e.computed)(()=>c.value.length===0?0:N(i.value,0,c.value.length-1)),T=(0,e.computed)(()=>c.value[w.value]??null),E=(0,e.computed)(()=>T.value?.type===`audio`||T.value?.type===`video`?T.value:null),D=Be({activeItem:T,activeMediaItem:E,isEnabled:_,itemCount:(0,e.computed)(()=>c.value.length),onAssetError:r.onAssetError,onAssetLoad:r.onAssetLoad}),O=(0,e.computed)(()=>c.value.length>0&&w.value===c.value.length-1),k=(0,e.computed)(()=>c.value.length===0&&l.value?`Loading the first page`:l.value&&s.value?`Loading more items`:O.value&&!s.value&&!l.value?`End of feed`:null),A=(0,e.computed)(()=>Math.min(96,g.value*.15||96)),j=(0,e.computed)(()=>He(w.value,c.value.length)),M=(0,e.computed)(()=>Ue(c.value,w.value));De({enabled:_,onDisable(){U(),D.resetMediaState()},onEnable(){return D.syncMediaPlayback()},onKeydown:G,onResize:P});function N(e,t,n){return Math.min(Math.max(e,t),n)}function P(){g.value=p.value?.clientHeight||window.innerHeight||1}function F(e){return c.value.length===0?!1:N(w.value+e,0,c.value.length-1)!==w.value}function I(e){if(c.value.length===0)return;let t=N(w.value+e,0,c.value.length-1);t!==w.value&&f(t)}function L(e){let t=e>0,n=e<0;return t&&!F(-1)||n&&!F(1)?e*.24:e}function R(e){!_.value||c.value.length===0||e.pointerType===`mouse`||C(e.target)||(v=e.pointerId,y=e.clientY,m.value=0,h.value=!0,p.value?.setPointerCapture?.(e.pointerId))}function z(e){!_.value||!h.value||v!==e.pointerId||(m.value=L(e.clientY-y))}function B(e){!_.value||v!==e.pointerId||(p.value?.releasePointerCapture?.(e.pointerId),H())}function V(e){!_.value||v!==e.pointerId||(p.value?.releasePointerCapture?.(e.pointerId),U())}function H(){Math.abs(m.value)>=A.value&&(x=Date.now()+250,I(m.value<0?1:-1)),U()}function U(){m.value=0,h.value=!1,v=null}function W(e){if(!_.value||c.value.length===0||h.value||C(e.target)||Math.abs(e.deltaY)<Math.max(Math.abs(e.deltaX),24))return;e.preventDefault();let t=Date.now();t<b||(b=t+400,I(e.deltaY>0?1:-1))}function G(e){!_.value||c.value.length===0||S(e.target)||((e.key===`ArrowDown`||e.key===`PageDown`)&&(e.preventDefault(),I(1)),(e.key===`ArrowUp`||e.key===`PageUp`)&&(e.preventDefault(),I(-1)))}function K(e,t){D.onVideoClick(e,t,x)}function ee(e,t){D.onAudioCoverClick(e,t,x)}function te(e){D.onMediaSeekInput(e)}function q(e){return e.type===`image`||e.type===`video`}function ne(e){return e.type===`audio`}function re(e){return We(e,w.value,g.value,m.value,h.value)}return{activeItem:T,activeAssetErrorKind:D.activeAssetErrorKind,activeMediaDuration:D.activeMediaDuration,activeMediaItem:E,activeMediaProgress:D.activeMediaProgress,activeMediaState:D.activeMediaState,canRetryAsset:D.canRetryAsset,canRetryInitialLoad:a,errorMessage:o,getAssetErrorKind:D.getAssetErrorKind,getAssetErrorLabel:D.getAssetErrorLabel,getAssetRenderKey:D.getAssetRenderKey,formatPlaybackTime:Ee,getImageSource:D.getImageSource,getSlideStyle:re,hasNextPage:s,isAtEnd:O,isAudio:ne,isVisual:q,items:c,loading:l,mediaStates:D.mediaStates,isImageReady:D.isImageReady,isMediaReady:D.isMediaReady,onAudioCoverClick:ee,onImageError:D.onImageError,onImageLoad:D.onImageLoad,onMediaEvent:D.onMediaEvent,onMediaError:D.onMediaError,onMediaSeekInput:te,onPointerCancel:V,onPointerDown:R,onPointerMove:z,onPointerUp:B,onVideoClick:K,onWheel:W,registerAudioElement:D.registerAudioElement,registerImageElement:D.registerImageElement,registerVideoElement:D.registerVideoElement,renderedItems:M,renderedRange:j,resolvedActiveIndex:w,retryInitialLoad:d,retryAsset:D.retryAsset,stageRef:p,statusMessage:k,paginationDetail:u}}var Ke={image:m,video:f,audio:d,other:p},qe={image:`Image`,video:`Video`,audio:`Audio`,other:`File`};function Y(e){return Ke[e]}function Je(e){return qe[e]}function X(t){if(!Array.isArray(t))return!1;for(let n of t){if(Array.isArray(n)){if(X(n))return!0;continue}if(!(0,e.isVNode)(n)){if(typeof n==`string`){if(n.trim().length>0)return!0;continue}if(n!=null&&n!==!1)return!0;continue}if(!Ye(n))return!0}return!1}function Ye(t){return t.type===e.Comment?!0:t.type===e.Text?typeof t.children==`string`?t.children.trim().length===0:!0:t.type===e.Fragment?!X(t.children):!1}var Xe={image:`bg-[radial-gradient(circle_at_top_center,rgba(251,191,36,0.4)_0,transparent_42%),linear-gradient(180deg,#120d08,#050507)]`,video:`bg-[radial-gradient(circle_at_top_center,rgba(56,189,248,0.38)_0,transparent_42%),linear-gradient(180deg,#07111c,#050608)]`,audio:`bg-[radial-gradient(circle_at_top_center,rgba(16,185,129,0.32)_0,transparent_42%),linear-gradient(180deg,#06120f,#040506)]`,other:`bg-[radial-gradient(circle_at_top_center,rgba(148,163,184,0.28)_0,transparent_42%),linear-gradient(180deg,#0d0c10,#040506)]`},Ze={image:`bg-[radial-gradient(circle_at_center,rgba(251,191,36,0.4)_0,transparent_42%),linear-gradient(180deg,#120d08,#050507)]`,video:`bg-[radial-gradient(circle_at_center,rgba(56,189,248,0.38)_0,transparent_42%),linear-gradient(180deg,#07111c,#050608)]`,audio:`bg-[radial-gradient(circle_at_center,rgba(16,185,129,0.32)_0,transparent_42%),linear-gradient(180deg,#06120f,#040506)]`,other:`bg-[radial-gradient(circle_at_center,rgba(148,163,184,0.28)_0,transparent_42%),linear-gradient(180deg,#0d0c10,#040506)]`};function Qe(e){return Xe[e]}function $e(e){return Ze[e]}var et={class:`relative h-full min-h-0 overflow-hidden bg-[#05060a] text-[#f7f1ea]`},tt={key:0,class:`relative h-full min-h-0`},nt=[`data-item-id`,`data-occurrence-key`,`data-index`,`data-active`,`aria-hidden`],rt={key:0,"data-testid":`vibe-asset-spinner`,class:`pointer-events-none absolute inset-0 z-[2] grid place-items-center`},it={class:`inline-flex h-12 w-12 items-center justify-center rounded-full bg-black/45 shadow-[0_18px_40px_-18px_rgba(0,0,0,0.85)] backdrop-blur-[18px]`},at=[`data-kind`],ot={class:`grid justify-items-center gap-4 border border-white/14 bg-black/45 px-8 py-7 text-center backdrop-blur-[18px]`},st={class:`m-0 text-[0.82rem] font-bold uppercase tracking-[0.28em] text-[#f7f1ea]/70`},ct=[`onClick`],lt=[`src`,`alt`,`onLoad`,`onError`],ut=[`src`,`preload`,`onClick`,`onCanplay`,`onDurationchange`,`onError`,`onLoadstart`,`onLoadedmetadata`,`onPause`,`onPlay`,`onPlaying`,`onSeeking`,`onSeeked`,`onStalled`,`onTimeupdate`,`onWaiting`],dt={class:`relative grid aspect-square w-[clamp(320px,46vw,560px)] max-w-[calc(100vw-2.5rem)] place-items-center`},ft=[`aria-label`,`disabled`,`onClick`],pt={class:`relative z-[1] inline-flex min-h-[4.25rem] min-w-[4.25rem] items-center justify-center border border-white/18 bg-emerald-500/12 p-4 backdrop-blur-[20px]`},mt={class:`pointer-events-none absolute bottom-4 right-4 inline-flex h-10 w-10 items-center justify-center border border-white/14 bg-black/50 backdrop-blur-[18px]`},ht={key:0,"data-testid":`vibe-asset-spinner`,class:`pointer-events-none absolute inset-0 z-[3] grid place-items-center`},gt={class:`inline-flex h-12 w-12 items-center justify-center rounded-full bg-black/45 shadow-[0_18px_40px_-18px_rgba(0,0,0,0.85)] backdrop-blur-[18px]`},_t=[`data-kind`],vt={class:`m-0 text-[0.82rem] font-bold uppercase tracking-[0.28em] text-[#f7f1ea]/70`},yt=[`onClick`],bt=[`src`,`preload`,`onCanplay`,`onDurationchange`,`onError`,`onLoadstart`,`onLoadedmetadata`,`onPause`,`onPlay`,`onPlaying`,`onSeeking`,`onSeeked`,`onStalled`,`onTimeupdate`,`onWaiting`],xt={key:2,class:`relative z-[1] grid w-full max-w-[1100px] justify-items-center gap-6 px-[clamp(2rem,4vw,3rem)] py-[clamp(2rem,4vw,3rem)] text-center`},St={class:`inline-flex min-h-[4.25rem] min-w-[4.25rem] items-center justify-center border border-white/18 bg-white/8 p-4 backdrop-blur-[20px]`},Ct={key:0,class:`pointer-events-none absolute inset-0 z-[4]`},wt={class:`h-full w-full`},Tt={key:0,"data-testid":`vibe-fullscreen-aside`,class:`h-full min-h-0 overflow-hidden border-l border-white/10 bg-black/45 backdrop-blur-[18px]`},Et={class:`h-full min-h-0 overflow-y-auto overscroll-y-contain`},Dt={key:0,"data-testid":`vibe-fullscreen-aside`,class:`absolute inset-y-0 right-0 z-[6] w-full max-w-[22rem] overflow-hidden border-l border-white/10 bg-black/82 backdrop-blur-[18px]`},Ot={class:`h-full min-h-0 overflow-y-auto overscroll-y-contain`},kt=1280,At=(0,e.defineComponent)({__name:`FullscreenSurface`,props:{items:{},activeIndex:{default:0},fillDelayMs:{},fillDelayStepMs:{},initialState:{},loading:{type:Boolean,default:!1},hasNextPage:{type:Boolean,default:!1},mode:{},resolve:{},initialCursor:{},pageSize:{},hasPreviousPage:{type:Boolean},paginationDetail:{default:null},requestNextPage:{},requestPreviousPage:{},active:{type:Boolean,default:!0},reportAssetError:{type:[Function,null],default:null},reportAssetLoad:{type:[Function,null],default:null},showBackToList:{type:Boolean,default:!1}},emits:[`back-to-list`,`update:activeIndex`],setup(t,{emit:n}){let r=t,i=(0,e.useSlots)(),a=n,o=Ge(r,(e,t)=>{a(`update:activeIndex`,t)},{enabled:(0,e.toRef)(r,`active`),onAssetError:r.reportAssetError??void 0,onAssetLoad:r.reportAssetLoad??void 0}),s=(0,e.ref)(typeof window>`u`?kt:window.innerWidth||kt),c=(0,e.computed)(()=>Qe(o.activeItem.value?.type??`image`)),l=(0,e.computed)(()=>o.activeMediaItem.value&&!o.activeAssetErrorKind.value?`bottom-[5.8rem] max-[720px]:bottom-[7.4rem]`:`bottom-[1.8rem] max-[720px]:bottom-[1.3rem]`),u=(0,e.computed)(()=>!!o.activeMediaItem.value&&!o.activeAssetErrorKind.value),d=(0,e.computed)(()=>u.value?`pb-[5.75rem] max-[720px]:pb-[7rem]`:``),f=(0,e.computed)(()=>{let e=o.activeItem.value;return e?{hasNextPage:r.hasNextPage,index:o.resolvedActiveIndex.value,item:e,loading:r.loading,paginationDetail:r.paginationDetail,total:r.items.length}:null}),p=(0,e.computed)(()=>!f.value||!i[`fullscreen-header-actions`]?[]:i[`fullscreen-header-actions`](f.value)),m=(0,e.computed)(()=>!f.value||!i[`fullscreen-aside`]?[]:i[`fullscreen-aside`](f.value)),y=(0,e.computed)(()=>!f.value||!o.statusMessage.value?null:{...f.value,kind:o.isAtEnd.value&&!o.hasNextPage.value&&!o.loading.value?`end`:`loading-more`,message:o.statusMessage.value}),b=(0,e.computed)(()=>!y.value||!i[`fullscreen-status`]?[]:i[`fullscreen-status`](y.value)),x=(0,e.computed)(()=>({gridTemplateColumns:w.value?`minmax(0, 1fr) 22rem`:`minmax(0, 1fr) 0rem`,transition:`grid-template-columns 320ms cubic-bezier(0.22, 1, 0.36, 1)`})),S=(0,e.computed)(()=>X(p.value)),C=(0,e.computed)(()=>X(m.value)),w=(0,e.computed)(()=>C.value&&s.value>=kt),E=(0,e.computed)(()=>C.value&&!w.value),D=(0,e.computed)(()=>X(b.value));(0,e.onMounted)(()=>{window.addEventListener(`resize`,L)}),(0,e.onBeforeUnmount)(()=>{window.removeEventListener(`resize`,L)});function O(e,t){let n=t.title?.trim();return n?`${e} ${n}`:`${e} ${Je(t.type).toLowerCase()}`}function k(e,t){let n=I(t);return!N(e)||e!==o.resolvedActiveIndex.value||o.getAssetErrorKind(n)?!1:t.type===`image`?!o.isImageReady(n):t.type===`video`||t.type===`audio`?!o.isMediaReady(n):!1}function A(e){return o.getAssetErrorKind(I(e))}function j(e){return o.getAssetErrorLabel(I(e))??`Load error`}function M(e,t){return N(e)&&e===o.resolvedActiveIndex.value&&!!A(t)}function N(e){return r.active&&e===o.resolvedActiveIndex.value}function P(e,t){if(N(e))return o.getImageSource(t)}function F(e,t){if(N(e))return t.url}function I(e){return T(e)}function L(){s.value=window.innerWidth||kt}return(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,et,[(0,e.createElementVNode)(`div`,{class:(0,e.normalizeClass)([`absolute inset-0 transition-[background] duration-200`,c.value])},null,2),(0,e.createElementVNode)(`div`,{class:`relative z-[1] grid h-full min-h-0`,style:(0,e.normalizeStyle)(x.value)},[(0,e.createElementVNode)(`div`,{ref:`viewer.stageRef`,"data-testid":`vibe-stage`,class:`relative h-full min-h-0 touch-none overflow-hidden`,onPointerdown:n[1]||=(...t)=>(0,e.unref)(o).onPointerDown&&(0,e.unref)(o).onPointerDown(...t),onPointermove:n[2]||=(...t)=>(0,e.unref)(o).onPointerMove&&(0,e.unref)(o).onPointerMove(...t),onPointerup:n[3]||=(...t)=>(0,e.unref)(o).onPointerUp&&(0,e.unref)(o).onPointerUp(...t),onPointercancel:n[4]||=(...t)=>(0,e.unref)(o).onPointerCancel&&(0,e.unref)(o).onPointerCancel(...t),onWheel:n[5]||=(...t)=>(0,e.unref)(o).onWheel&&(0,e.unref)(o).onWheel(...t)},[(0,e.unref)(o).items.value.length>0?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,tt,[((0,e.openBlock)(!0),(0,e.createElementBlock)(e.Fragment,null,(0,e.renderList)((0,e.unref)(o).renderedItems.value,({item:r,index:i})=>((0,e.openBlock)(),(0,e.createElementBlock)(`article`,{key:I(r),"data-testid":`vibe-slide`,"data-item-id":r.id,"data-occurrence-key":I(r),"data-index":i,"data-active":i===(0,e.unref)(o).resolvedActiveIndex.value,"aria-hidden":i===(0,e.unref)(o).resolvedActiveIndex.value?`false`:`true`,class:(0,e.normalizeClass)([`absolute inset-0 flex h-full min-h-full items-center justify-center will-change-transform`,i===(0,e.unref)(o).resolvedActiveIndex.value?`pointer-events-auto`:`pointer-events-none`]),style:(0,e.normalizeStyle)((0,e.unref)(o).getSlideStyle(i))},[(0,e.createElementVNode)(`div`,{class:(0,e.normalizeClass)([`absolute inset-0 opacity-85`,(0,e.unref)($e)(r.type)])},null,2),(0,e.unref)(o).isVisual(r)?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:0,class:(0,e.normalizeClass)([`relative z-[1] flex h-full w-full items-center justify-center overflow-hidden`,i===(0,e.unref)(o).resolvedActiveIndex.value?d.value:``])},[k(i,r)?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,rt,[(0,e.createElementVNode)(`span`,it,[(0,e.createVNode)((0,e.unref)(h),{class:`h-5 w-5 animate-spin stroke-[1.9] text-[#f7f1ea]/78`,"aria-hidden":`true`})])])):(0,e.createCommentVNode)(``,!0),M(i,r)?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:1,"data-testid":`vibe-asset-error`,"data-kind":A(r),class:`grid h-full w-full place-items-center`},[(0,e.createElementVNode)(`div`,ot,[(0,e.createVNode)((0,e.unref)(v),{class:`h-7 w-7 stroke-[1.9] text-[#f7f1ea]/72`,"aria-hidden":`true`}),(0,e.createElementVNode)(`p`,st,(0,e.toDisplayString)(j(r)),1),(0,e.unref)(o).canRetryAsset(I(r))?((0,e.openBlock)(),(0,e.createElementBlock)(`button`,{key:0,type:`button`,class:`inline-flex items-center justify-center border border-white/14 bg-black/35 px-4 py-2 text-[0.64rem] font-bold uppercase tracking-[0.22em] text-[#f7f1ea]/82 backdrop-blur-[18px] transition hover:border-white/28 hover:bg-black/50`,onClick:(0,e.withModifiers)(t=>(0,e.unref)(o).retryAsset(I(r)),[`stop`])},` Retry `,8,ct)):(0,e.createCommentVNode)(``,!0)])],8,at)):r.type===`image`?((0,e.openBlock)(),(0,e.createElementBlock)(`img`,{key:(0,e.unref)(o).getAssetRenderKey(I(r)),src:P(i,r),alt:r.title??``,draggable:`false`,class:(0,e.normalizeClass)([`block h-auto max-h-full w-auto max-w-full object-contain shadow-[0_40px_120px_-60px_rgba(0,0,0,0.9)] transition-opacity duration-300`,(0,e.unref)(o).isImageReady(I(r))?`opacity-100`:`opacity-0`]),ref_for:!0,ref:t=>(0,e.unref)(o).registerImageElement(I(r),t),onLoad:t=>(0,e.unref)(o).onImageLoad(I(r),r.url),onError:t=>(0,e.unref)(o).onImageError(I(r),r.url)},null,42,lt)):((0,e.openBlock)(),(0,e.createElementBlock)(`video`,{key:(0,e.unref)(o).getAssetRenderKey(I(r)),class:(0,e.normalizeClass)([`block h-auto max-h-full w-auto max-w-full cursor-pointer object-contain shadow-[0_40px_120px_-60px_rgba(0,0,0,0.9)] transition-opacity duration-300`,(0,e.unref)(o).isMediaReady(I(r))?`opacity-100`:`opacity-0`]),playsinline:``,muted:``,src:F(i,r),preload:N(i)?`metadata`:`none`,ref_for:!0,ref:t=>(0,e.unref)(o).registerVideoElement(I(r),t),onClick:(0,e.withModifiers)(t=>(0,e.unref)(o).onVideoClick(t,I(r)),[`stop`]),onCanplay:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onDurationchange:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onError:t=>(0,e.unref)(o).onMediaError(I(r),r.url),onLoadstart:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onLoadedmetadata:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onPause:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onPlay:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onPlaying:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onSeeking:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onSeeked:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onStalled:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onTimeupdate:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onWaiting:t=>(0,e.unref)(o).onMediaEvent(I(r),t)},null,42,ut))],2)):(0,e.unref)(o).isAudio(r)?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:1,class:(0,e.normalizeClass)([`relative z-[1] grid w-full max-w-[1100px] justify-items-center gap-6 px-[clamp(2rem,4vw,3rem)] py-[clamp(2rem,4vw,3rem)] text-center`,i===(0,e.unref)(o).resolvedActiveIndex.value?d.value:``])},[(0,e.createElementVNode)(`div`,dt,[(0,e.createElementVNode)(`button`,{type:`button`,class:`relative grid h-full w-full place-items-center border border-white/12 bg-[linear-gradient(180deg,rgba(255,255,255,0.04),rgba(255,255,255,0.02)),radial-gradient(circle_at_center,rgba(16,185,129,0.14),transparent_58%)] text-[#f7f1ea] transition-[border-color,background] duration-200 hover:border-white/30 hover:bg-[linear-gradient(180deg,rgba(255,255,255,0.07),rgba(255,255,255,0.03)),radial-gradient(circle_at_center,rgba(16,185,129,0.18),transparent_58%)] focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-4 focus-visible:outline-[#f7f1ea]`,"aria-label":(0,e.unref)(o).mediaStates.value[I(r)]?.paused??!0?O(`Play`,r):O(`Pause`,r),disabled:!!A(r),onClick:t=>(0,e.unref)(o).onAudioCoverClick(t,I(r))},[n[6]||=(0,e.createElementVNode)(`span`,{class:`pointer-events-none absolute inset-0 border border-white/8 bg-[radial-gradient(circle,rgba(16,185,129,0.16),transparent_66%)]`},null,-1),n[7]||=(0,e.createElementVNode)(`span`,{class:`pointer-events-none absolute h-[clamp(220px,30vw,360px)] w-[clamp(220px,30vw,360px)] border border-white/8 bg-[radial-gradient(circle,rgba(255,255,255,0.08),transparent_62%)]`},null,-1),(0,e.createElementVNode)(`span`,pt,[(0,e.renderSlot)(t.$slots,`item-icon`,{icon:(0,e.unref)(Y)(r.type),item:r},()=>[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(Y)(r.type)),{class:`h-6 w-6 stroke-[1.9]`,"aria-hidden":`true`}))])]),(0,e.createElementVNode)(`span`,mt,[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(o).mediaStates.value[I(r)]?.paused??!0?(0,e.unref)(_):(0,e.unref)(g)),{class:`h-4 w-4 stroke-2`,"aria-hidden":`true`}))])],8,ft),k(i,r)?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,ht,[(0,e.createElementVNode)(`span`,gt,[(0,e.createVNode)((0,e.unref)(h),{class:`h-5 w-5 animate-spin stroke-[1.9] text-[#f7f1ea]/78`,"aria-hidden":`true`})])])):(0,e.createCommentVNode)(``,!0),A(r)?((0,e.openBlock)(),(0,e.createElementBlock)(e.Fragment,{key:1},[n[8]||=(0,e.createElementVNode)(`div`,{class:`pointer-events-none absolute inset-0 border border-white/8 bg-[radial-gradient(circle,rgba(239,68,68,0.12),transparent_66%)]`},null,-1),(0,e.createElementVNode)(`div`,{"data-testid":`vibe-asset-error`,"data-kind":A(r),class:`relative z-[1] grid justify-items-center gap-4`},[(0,e.createVNode)((0,e.unref)(v),{class:`h-7 w-7 stroke-[1.9] text-[#f7f1ea]/72`,"aria-hidden":`true`}),(0,e.createElementVNode)(`p`,vt,(0,e.toDisplayString)(j(r)),1),(0,e.unref)(o).canRetryAsset(I(r))?((0,e.openBlock)(),(0,e.createElementBlock)(`button`,{key:0,type:`button`,class:`pointer-events-auto inline-flex items-center justify-center border border-white/14 bg-black/35 px-4 py-2 text-[0.64rem] font-bold uppercase tracking-[0.22em] text-[#f7f1ea]/82 backdrop-blur-[18px] transition hover:border-white/28 hover:bg-black/50`,onClick:(0,e.withModifiers)(t=>(0,e.unref)(o).retryAsset(I(r)),[`stop`])},` Retry `,8,yt)):(0,e.createCommentVNode)(``,!0)],8,_t)],64)):(0,e.createCommentVNode)(``,!0)]),((0,e.openBlock)(),(0,e.createElementBlock)(`audio`,{key:(0,e.unref)(o).getAssetRenderKey(I(r)),src:F(i,r),preload:N(i)?`metadata`:`none`,class:`pointer-events-none absolute h-px w-px opacity-0`,ref_for:!0,ref:t=>(0,e.unref)(o).registerAudioElement(I(r),t),onCanplay:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onDurationchange:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onError:t=>(0,e.unref)(o).onMediaError(I(r),r.url),onLoadstart:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onLoadedmetadata:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onPause:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onPlay:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onPlaying:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onSeeking:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onSeeked:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onStalled:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onTimeupdate:t=>(0,e.unref)(o).onMediaEvent(I(r),t),onWaiting:t=>(0,e.unref)(o).onMediaEvent(I(r),t)},null,40,bt))],2)):((0,e.openBlock)(),(0,e.createElementBlock)(`div`,xt,[(0,e.createElementVNode)(`div`,St,[(0,e.renderSlot)(t.$slots,`item-icon`,{icon:(0,e.unref)(Y)(r.type),item:r},()=>[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(Y)(r.type)),{class:`h-6 w-6 stroke-[1.9]`,"aria-hidden":`true`}))])])]))],14,nt))),128)),f.value&&i[`fullscreen-overlay`]?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Ct,[(0,e.createElementVNode)(`div`,wt,[(0,e.renderSlot)(t.$slots,`fullscreen-overlay`,(0,e.normalizeProps)((0,e.guardReactiveProps)(f.value)))])])):(0,e.createCommentVNode)(``,!0),(0,e.unref)(o).activeItem.value?((0,e.openBlock)(),(0,e.createBlock)(Te,{key:1,"current-index":(0,e.unref)(o).resolvedActiveIndex.value,"pagination-detail":(0,e.unref)(o).paginationDetail.value,"show-back-to-list":r.showBackToList,"show-end-badge":(0,e.unref)(o).isAtEnd.value&&!(0,e.unref)(o).hasNextPage.value&&!(0,e.unref)(o).loading.value,title:(0,e.unref)(o).activeItem.value.title??null,total:(0,e.unref)(o).items.value.length,onBackToList:n[0]||=e=>a(`back-to-list`)},(0,e.createSlots)({_:2},[S.value&&f.value?{name:`actions`,fn:(0,e.withCtx)(()=>[(0,e.renderSlot)(t.$slots,`fullscreen-header-actions`,(0,e.normalizeProps)((0,e.guardReactiveProps)(f.value)))]),key:`0`}:void 0]),1032,[`current-index`,`pagination-detail`,`show-back-to-list`,`show-end-badge`,`title`,`total`])):(0,e.createCommentVNode)(``,!0),u.value?((0,e.openBlock)(),(0,e.createBlock)(he,{key:2,"current-time":(0,e.unref)(o).activeMediaState.value.currentTime,"current-time-label":(0,e.unref)(o).formatPlaybackTime((0,e.unref)(o).activeMediaState.value.currentTime),duration:(0,e.unref)(o).activeMediaDuration.value,"duration-label":(0,e.unref)(o).formatPlaybackTime((0,e.unref)(o).activeMediaDuration.value),progress:(0,e.unref)(o).activeMediaProgress.value,onSeekInput:(0,e.unref)(o).onMediaSeekInput},null,8,[`current-time`,`current-time-label`,`duration`,`duration-label`,`progress`,`onSeekInput`])):(0,e.createCommentVNode)(``,!0),y.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:3,class:(0,e.normalizeClass)([`absolute left-1/2 z-[4] -translate-x-1/2`,l.value])},[D.value?(0,e.renderSlot)(t.$slots,`fullscreen-status`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},y.value))):((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:1,class:(0,e.normalizeClass)([`inline-flex w-auto items-center border border-white/14 bg-black/40 px-5 py-3 text-[0.75rem] font-bold uppercase tracking-[0.18em] text-[#f7f1ea]/74 backdrop-blur-[18px] max-[720px]:w-[calc(100%-2.5rem)] max-[720px]:justify-center`,y.value.kind===`end`?`border-amber-300/35 text-amber-200`:``])},(0,e.toDisplayString)(y.value.message),3))],2)):(0,e.createCommentVNode)(``,!0)])):(0,e.createCommentVNode)(``,!0)],544),(0,e.createVNode)(e.Transition,{"enter-active-class":`transform-gpu transition-all duration-320 ease-out`,"enter-from-class":`translate-x-full opacity-0`,"enter-to-class":`translate-x-0 opacity-100`,"leave-active-class":`transform-gpu transition-all duration-260 ease-in`,"leave-from-class":`translate-x-0 opacity-100`,"leave-to-class":`translate-x-full opacity-0`},{default:(0,e.withCtx)(()=>[w.value&&f.value?((0,e.openBlock)(),(0,e.createElementBlock)(`aside`,Tt,[(0,e.createElementVNode)(`div`,Et,[(0,e.renderSlot)(t.$slots,`fullscreen-aside`,(0,e.normalizeProps)((0,e.guardReactiveProps)(f.value)))])])):(0,e.createCommentVNode)(``,!0)]),_:3})],4),(0,e.createVNode)(e.Transition,{"enter-active-class":`transform-gpu transition-all duration-320 ease-out`,"enter-from-class":`translate-x-full opacity-0`,"enter-to-class":`translate-x-0 opacity-100`,"leave-active-class":`transform-gpu transition-all duration-260 ease-in`,"leave-from-class":`translate-x-0 opacity-100`,"leave-to-class":`translate-x-full opacity-0`},{default:(0,e.withCtx)(()=>[E.value&&f.value?((0,e.openBlock)(),(0,e.createElementBlock)(`aside`,Dt,[(0,e.createElementVNode)(`div`,Ot,[(0,e.renderSlot)(t.$slots,`fullscreen-aside`,(0,e.normalizeProps)((0,e.guardReactiveProps)(f.value)))])])):(0,e.createCommentVNode)(``,!0)]),_:3})]))}}),jt=1,Mt=.5;function Nt(e){if(e.type!==`image`&&e.type!==`video`)return{width:jt,height:jt,source:`fallback`};let t=e.preview?.width,n=e.preview?.height;if(Bt(t)&&Bt(n)){let r=Vt(e,t,n);return{width:r.width,height:r.height,source:`preview`}}if(Bt(e.width)&&Bt(e.height)){let t=Vt(e,e.width,e.height);return{width:t.width,height:t.height,source:`original`}}return{width:jt,height:jt,source:`fallback`}}function Pt(e,t){return!e||e<=0||!t||t<=0?1:Math.max(1,Math.floor(e/t))}function Ft(e,t,n,r=0){if(!e||e<=0||!t||t<=0)return n;let i=typeof r==`number`&&r>0?r:0,a=e-Math.max(0,t-1)*i;return!a||a<=0?n:a/t}function It(e,t){let n=Nt(e);return n.height/n.width*t}function Lt(e,t){let n=Array.from({length:t.columnCount},()=>0),r=Array(e.length),i=Array(e.length),a=new Map,o=new Map,s=0;for(let c=0;c<e.length;c+=1){let l=e[c];o.set(T(l),c);let u=0;for(let e=1;e<n.length;e+=1)n[e]<n[u]&&(u=e);let d=u*(t.columnWidth+t.gapX),f=n[u],p=It(l,t.columnWidth);r[c]={x:d,y:f},i[c]=p,n[u]=f+p+t.gapY,s=Math.max(s,f+p);let m=Math.floor(f/t.bucketPx),h=Math.floor((f+p)/t.bucketPx);for(let e=m;e<=h;e+=1){let t=a.get(e);t?t.push(c):a.set(e,[c])}}return{positions:r,heights:i,buckets:a,contentHeight:s,indexById:o}}function Rt(e){if(e.itemCount<=0)return[];if(e.viewportHeight<=0)return Array.from({length:e.itemCount},(e,t)=>t);let t=Math.max(0,e.scrollTop-e.overscanPx),n=e.scrollTop+e.viewportHeight+e.overscanPx,r=Math.floor(t/e.bucketPx),i=Math.floor(n/e.bucketPx),a=new Set;for(let t=r;t<=i;t+=1){let n=e.buckets.get(t);if(n)for(let e of n)a.add(e)}return Array.from(a).sort((e,t)=>e-t)}function zt(e,t,n){let r=new Map;for(let i of e){let e=t.get(T(i));if(e==null)continue;let a=n[e];a&&r.set(T(i),a)}return r}function Bt(e){return typeof e==`number`&&Number.isFinite(e)&&e>0}function Vt(e,t,n){return e.type!==`image`||n/t>=Mt?{width:t,height:n}:{width:t,height:t}}var Ht=300,Ut=600,Wt=40,Gt=400;function Kt(e,t){return t===`top`?[...e].reverse():e}function qt(e){return e<=0?Ut:Ut+Math.min((e-1)*Wt,Gt)}function Jt(e){let t=e.itemHeight>0?e.itemHeight:e.columnWidth;return e.direction===`top`?e.scrollTop-t:e.scrollTop+e.viewportHeight+t}function Yt(t){let n=(0,e.ref)(new Set),r=(0,e.ref)(new Set),i=(0,e.ref)(new Map),a=(0,e.ref)(new Map),o=(0,e.ref)(new Map),s=(0,e.ref)(new Map),c=(0,e.ref)(new Set),l=new Set,u=new Set;(0,e.watch)(t.visibleIndices,e=>{if(!e.length)return;let o=[];for(let r of e){let e=t.items.value[r]?T(t.items.value[r]):null;!e||!n.value.has(e)||l.has(e)||(l.add(e),o.push(e))}if(!o.length)return;let s=Kt(o,a.value.get(o[0])??`bottom`),c=new Map(i.value);for(let e=0;e<s.length;e+=1)c.set(s[e],Math.min(e*Wt,Gt));i.value=c,Z(()=>{let e=new Set(r.value);for(let t of o)e.add(t);r.value=e}),Xt(()=>{let e=new Set(n.value);for(let t of o)e.delete(t);n.value=e,g(()=>{let e=new Set(r.value),t=new Map(i.value),n=new Map(a.value);for(let r of o)e.delete(r),t.delete(r),n.delete(r),l.delete(r);r.value=e,i.value=t,a.value=n},qt(o.length))})},{flush:`post`}),(0,e.onBeforeUnmount)(()=>{for(let e of u)clearTimeout(e);u.clear()});function d(e,t=`bottom`){if(!e.length)return;let r=new Set(n.value),i=new Map(a.value);for(let n of e){let e=T(n);r.add(e),i.set(e,t)}n.value=r,a.value=i}function f(e,n,r=Ht){if(!e.size)return;let i=new Map,a=[];for(let[r,o]of e.entries()){if(n?.has(r))continue;let e=t.indexById.value.get(r);if(e==null)continue;let s=t.positions.value[e];if(!s)continue;let c=o.x-s.x,l=o.y-s.y;!c&&!l||(i.set(r,{dx:c,dy:l}),a.push(r))}if(!i.size)return;o.value=i,c.value=new Set;let l=new Map(s.value);for(let e of a)l.set(e,r);s.value=l,Z(()=>{c.value=new Set(a),Z(()=>{o.value=new Map})}),g(()=>{c.value=new Set;let e=new Map(s.value);for(let t of a)e.delete(t);s.value=e},r)}function p(e){if(r.value.has(e))return`transform ${Ut}ms ease-out`;if(c.value.has(e))return`transform ${s.value.get(e)??Ht}ms ease-out`}function m(e){if(!r.value.has(e))return;let t=i.value.get(e)??0;return t>0?`${t}ms`:void 0}function h(e){let r=t.items.value[e],i=t.positions.value[e]??{x:0,y:0},s=t.heights.value[e]??t.columnWidth.value,c=r?T(r):null,l=c?o.value.get(c)??{dx:0,dy:0}:{dx:0,dy:0},u=c?a.value.get(c)??`bottom`:`bottom`,d=c&&n.value.has(c)?Jt({columnWidth:t.columnWidth.value,direction:u,itemHeight:s,scrollTop:t.scrollTop.value,viewportHeight:t.viewportHeight.value}):i.y;return`translate3d(${i.x+l.dx}px, ${d+l.dy}px, 0)`}function g(e,t){let n=setTimeout(()=>{u.delete(n),e()},t);u.add(n)}return{getCardTransform:h,getCardTransition:p,getCardTransitionDelay:m,markEnter:d,playFlipMoveAnimation:f}}function Z(e){if(typeof requestAnimationFrame==`function`){requestAnimationFrame(()=>e());return}setTimeout(e,0)}function Xt(e){Z(()=>Z(e))}function Zt(e,t){return e?.clientHeight||Math.round(e?.getBoundingClientRect().height??0)||window.innerHeight||t||1}function Qt(e,t,n){return e?.clientWidth||Math.round(e?.getBoundingClientRect().width??0)||window.innerWidth||t||n}function $t(e,t,n,r){return(e?.scrollHeight??r)-(t+n)}function en(e,t){return{height:`${e}px`,transform:`translate3d(0, ${t}px, 0)`}}var tn=250,nn=1e3;function rn(t){let n=(0,e.ref)(!1),r=(0,e.ref)(!1),i=(0,e.ref)(0),a=(0,e.ref)(0),o=(0,e.ref)(!1),s=(0,e.ref)(!1),c=0,l=null;(0,e.onBeforeUnmount)(()=>{b()});function u(){let e=n.value;if(n.value=t.isAtBoundary(),!n.value){!o.value&&!s.value&&(r.value=!0);return}!e&&r.value&&h()}function d(e){if(!x(e)||!t.isAtBoundary())return;let n=Date.now();n<c||(c=n+tn,h())}function f(){if(!_())return;let e=t.requestPage.value;if(typeof e!=`function`)return;a.value=i.value,r.value=!1,o.value=!0,s.value=!0;let n;try{n=e()}catch{v();return}Promise.resolve(n).catch(()=>{}).finally(()=>{!t.loading.value&&s.value&&v()})}function p(e){!e&&s.value&&v()}function m(e){!s.value||e<=0||(s.value=!1,y(t.getAnimationLockMs(e)))}function h(){g()&&(i.value+=1)}function g(){return t.hasPage.value&&!t.loading.value&&!o.value&&typeof t.requestPage.value==`function`}function _(){return t.hasPage.value&&n.value&&i.value>a.value&&!t.loading.value&&!o.value&&typeof t.requestPage.value==`function`}function v(){s.value=!1,y(nn)}function y(e){b(),o.value=!0,l=setTimeout(()=>{l=null,o.value=!1},Math.max(0,e))}function b(){l&&=(clearTimeout(l),null)}function x(e){return t.direction===`top`?e.deltaY<0:e.deltaY>0}return{maybeRequestPage:f,onItemsMutated:m,onLoadingChange:p,onWheel:d,syncBoundary:u}}var an=600,Q=24,$=16,on=300,sn=200,cn=200,ln=200,un=300,dn=24,fn=48,pn=500,mn=1e3;function hn(t){let n=(0,e.ref)(null),r=(0,e.ref)(0),i=(0,e.ref)(typeof window>`u`?0:window.innerHeight||0),a=(0,e.ref)(typeof window>`u`?0:window.innerWidth||on),o=(0,e.ref)([]),s=(0,e.ref)([]),c=(0,e.ref)(new Map),l=(0,e.ref)(0),u=(0,e.ref)(new Map),d=(0,e.ref)(null),f=(0,e.computed)(()=>Math.max(on,a.value-Q*2)),p=(0,e.computed)(()=>Pt(f.value,on)),m=(0,e.computed)(()=>Ft(f.value,p.value,on,$)),h=(0,e.computed)(()=>gn(t.activeIndex.value,0,Math.max(0,t.items.value.length-1))),g=(0,e.computed)(()=>Rt({itemCount:t.items.value.length,viewportHeight:i.value,scrollTop:r.value,overscanPx:sn,bucketPx:an,buckets:c.value})),_=(0,e.computed)(()=>g.value.map(e=>({item:t.items.value[e],index:e}))),v=(0,e.computed)(()=>{let e=l.value+Q*2,t=d.value??0;return Math.max(e,t,i.value)+ln}),y=(0,e.computed)(()=>t.loading.value?t.items.value.length>0?`Loading more items`:`Loading the first page`:!t.hasNextPage.value&&t.items.value.length>0?`End of list`:null),b=(0,e.computed)(()=>`${h.value+1} / ${t.items.value.length}`),x=(0,e.computed)(()=>Math.max(0,i.value-dn*2)),S=(0,e.computed)(()=>v.value>i.value+1&&x.value>0),C=(0,e.computed)(()=>{if(!S.value)return 0;let e=i.value/v.value*x.value;return Math.min(x.value,Math.max(fn,e))}),w=(0,e.computed)(()=>{if(!S.value)return dn;let e=Math.max(0,v.value-i.value);return dn+Math.max(0,x.value-C.value)*(e>0?gn(r.value/e,0,1):0)}),E=Yt({items:t.items,visibleIndices:g,positions:o,heights:s,indexById:u,columnWidth:m,scrollTop:r,viewportHeight:i}),D=rn({direction:`top`,getAnimationLockMs(e){return Math.max(pn,qt(e))+mn},hasPage:t.hasPreviousPage,isAtBoundary(){return r.value<=Q+$},loading:t.loading,requestPage:t.requestPreviousPage}),O=rn({direction:`bottom`,getAnimationLockMs(e){return qt(e)+mn},hasPage:t.hasNextPage,isAtBoundary(){return G()<=cn},loading:t.loading,requestPage:t.requestNextPage}),k=null,A=0,j=null,M=!1;(0,e.watch)([()=>t.items.value.map(e=>T(e)),p,m],async([n],[i=[]])=>{let a=zt(t.items.value,u.value,o.value),s=new Set(i),c=t.items.value.filter(e=>!s.has(T(e))),l=n.length>i.length&&i.length>0&&n[0]!==i[0],d=l&&r.value>Q+$?t.items.value[h.value]:null,f=d?T(d):null;N(),c.length>0&&(E.markEnter(c,l?`top`:`bottom`),l?D.onItemsMutated(c.length):O.onItemsMutated(c.length)),E.playFlipMoveAnimation(a,new Set(c.map(e=>T(e))),l?pn:void 0),f?(await(0,e.nextTick)(),R(f,a)):t.active.value&&i.length>0&&B()},{immediate:!0}),(0,e.watch)([()=>t.pendingAppendItems.value.map(e=>T(e)),p,m,i],([e])=>{q(),e.length&&(d.value=ee([...t.items.value,...t.pendingAppendItems.value]),te())},{immediate:!0}),(0,e.watch)(()=>t.restoreToken.value,async()=>{await(0,e.nextTick)(),L(h.value,`center`)}),(0,e.watch)(()=>t.loading.value,async n=>{!n&&!t.pendingAppendItems.value.length&&!j&&!M&&(d.value=null),D.onLoadingChange(n),O.onLoadingChange(n),await(0,e.nextTick)()}),(0,e.onMounted)(async()=>{H(),await(0,e.nextTick)(),h.value>0?L(h.value,`center`):z(),D.syncBoundary(),O.syncBoundary(),typeof ResizeObserver<`u`?(k=new ResizeObserver(()=>{H()}),n.value&&k.observe(n.value)):window.addEventListener(`resize`,H)}),(0,e.onBeforeUnmount)(()=>{k?.disconnect(),k=null,window.removeEventListener(`resize`,H),q(),A&&=(cancelAnimationFrame(A),0)});function N(){let e=Lt(t.items.value,{columnCount:p.value,columnWidth:m.value,gapX:$,gapY:$,bucketPx:an});o.value=e.positions.map(e=>({x:e.x+Q,y:e.y+Q})),s.value=e.heights,c.value=e.buckets,l.value=e.contentHeight,u.value=e.indexById}function P(){t.active.value&&(r.value=n.value?.scrollTop??0,i.value=U(),D.syncBoundary(),O.syncBoundary(),V(),!B()&&(A||=requestAnimationFrame(()=>{A=0,z()})))}function F(e){t.active.value&&(D.onWheel(e),O.onWheel(e),V())}function I(e){let n=t.items.value[e],r=n?T(n):``;return{height:`${s.value[e]??m.value}px`,width:`${m.value}px`,transition:r?E.getCardTransition(r):void 0,transitionDelay:r?E.getCardTransitionDelay(r):void 0,transform:E.getCardTransform(e)}}function L(e,t){let a=n.value,c=o.value[e],l=s.value[e];if(!a||!c||!l)return;let u=a.scrollTop,d=Math.max(0,v.value-i.value);t===`center`?u=c.y-(i.value-l)/2:c.y<a.scrollTop?u=c.y-Q:c.y+l>a.scrollTop+i.value&&(u=c.y+l-i.value+Q),a.scrollTop=gn(u,0,d),r.value=a.scrollTop,z()}function R(e,t){let i=n.value,a=t.get(e),s=u.value.get(e),c=s==null?null:o.value[s];if(!i||!a||!c)return;let l=c.y-a.y;i.scrollTop+=l,r.value=i.scrollTop}function z(){if(!g.value.length||B())return;let e=r.value+i.value/2,n=h.value,a=1/0;for(let t of g.value){let r=o.value[t],i=s.value[t];if(!r||!i)continue;let c=r.y+i/2,l=Math.abs(c-e);l<a&&(a=l,n=t)}t.setActiveIndex(n)}function B(){let e=r.value<=Q+$,n=G()<=cn;return e?(t.setActiveIndex(0),!0):n?(t.setActiveIndex(Math.max(0,t.items.value.length-1)),!0):!1}function V(){D.maybeRequestPage(),O.maybeRequestPage()}function H(){i.value=U(),a.value=W()}function U(){return Zt(n.value,i.value)}function W(){return Qt(n.value,a.value,on)}function G(){return $t(n.value,r.value,i.value,v.value)}function K(){return en(C.value,w.value)}function ee(e){return e.length?Lt(e,{columnCount:p.value,columnWidth:m.value,gapX:$,gapY:$,bucketPx:an}).contentHeight+Q*2:0}function te(){let n=t.commitPendingAppend.value;typeof n==`function`&&(j=setTimeout(async()=>{j=null,M=!0;try{if(!t.pendingAppendItems.value.length)return;await n(),await(0,e.nextTick)(),await(0,e.nextTick)()}finally{d.value=null,M=!1}},un))}function q(){j&&=(clearTimeout(j),null)}return{columnWidth:m,containerHeight:v,footerStatusMessage:y,getCardStyle:I,getScrollbarThumbStyle:K,onScroll:P,onWheel:F,paginationLabel:b,renderedItems:_,resolvedActiveIndex:h,scrollToIndex:L,showScrollbar:S,scrollViewportRef:n}}function gn(e,t,n){return Math.min(Math.max(e,t),n)}function _n(e){if(e)try{e.removeAttribute(`src`),e.src=``}catch{}}function vn(e){if(e){try{e.currentTime=0}catch{}e.pause();try{e.removeAttribute(`src`),e.load()}catch{}}}function yn(e,t){if(t)return e.bottom>t.top&&e.top<t.bottom;let n=window.innerHeight||document.documentElement.clientHeight||0;return e.bottom>0&&e.top<n}function bn(e){if(!e)return null;try{return new URL(e,window.location.href).href}catch{return e}}var xn=/\.(avif|gif|jpe?g|png|svg|webp)(\?|#|$)/i,Sn=/\.(m4v|mov|mp4|mpeg|ogg|ogv|webm)(\?|#|$)/i;function Cn(e){let t=e.preview?.url??e.url,n=Nt(e),r=e.title?.trim()||Je(e.type);return e.type!==`image`&&e.type!==`video`?{kind:`fallback`,url:null,width:n.width,height:n.height,label:r}:Tn(e,t)?{kind:`video`,url:t,width:n.width,height:n.height,label:r}:wn(e,t)?{kind:`image`,url:t,width:n.width,height:n.height,label:r}:{kind:`fallback`,url:null,width:n.width,height:n.height,label:r}}function wn(e,t){return e.type!==`image`||typeof t!=`string`?!1:xn.test(t)||En(t)}function Tn(e,t){return e.type===`video`&&typeof t==`string`&&Sn.test(t)}function En(e){return/^https?:\/\//i.test(e)}var Dn={maxGlobal:10,maxPerDomain:4,maxVideoPerDomain:2};function On(e=Dn){let t=new Map,n=new Map,r=0;function i(e){let i={...e,domain:jn(e.url),enqueuedAt:r,id:`vibe-asset-load-${r+=1}`};return n.set(i.id,i),a(),{cancel(){(n.delete(i.id)||t.delete(i.id))&&a()},refresh(){a()},release(){(t.delete(i.id)||n.delete(i.id))&&a()}}}function a(){if(n.size===0)return;let r=[...n.values()].sort((e,t)=>{let n=An(e)-An(t);return n===0?e.enqueuedAt-t.enqueuedAt:n});for(let i of r){if(t.size>=e.maxGlobal)return;if(o(i)){n.delete(i.id),t.set(i.id,i);try{i.onGrant()}catch{t.delete(i.id)}}}}function o(n){let r=[...t.values()].filter(e=>e.domain===n.domain);return!(r.length>=e.maxPerDomain||n.assetType===`video`&&r.filter(e=>e.assetType===`video`).length>=e.maxVideoPerDomain)}return{request:i}}var kn=On();function An(e){try{let t=e.getPriority();return Number.isFinite(t)?t:1/0}catch{return 1/0}}function jn(e){try{return new URL(e).hostname||`local`}catch{return`local`}}var Mn=[`aria-label`],Nn={key:0,"data-testid":`vibe-list-card-spinner`,class:`pointer-events-none absolute inset-0 z-[4] grid place-items-center bg-black/18`},Pn={class:`inline-flex h-12 w-12 items-center justify-center rounded-full bg-black/45 shadow-[0_18px_40px_-18px_rgba(0,0,0,0.85)] backdrop-blur-[18px]`},Fn=[`src`,`alt`],In=[`src`],Ln=[`data-kind`],Rn={class:`grid justify-items-center gap-3 px-4 text-center`},zn={class:`text-[0.68rem] font-bold uppercase tracking-[0.22em] text-[#f7f1ea]/72`},Bn={key:4,class:`grid h-full w-full place-items-center bg-[radial-gradient(circle_at_center,rgba(255,255,255,0.08),transparent_65%),linear-gradient(180deg,rgba(255,255,255,0.04),rgba(255,255,255,0.02))]`},Vn={class:`inline-flex h-14 w-14 items-center justify-center border border-white/16 bg-black/20`},Hn={class:`pointer-events-none absolute inset-0 z-[3]`},Un=(0,e.defineComponent)({__name:`ListCard`,props:{active:{type:Boolean,default:!1},index:{default:0},item:{},reportAssetError:{type:[Function,null],default:null},reportAssetLoad:{type:[Function,null],default:null},surfaceActive:{type:Boolean,default:!0}},emits:[`open`],setup(t,{emit:n}){let r=t,i=n,a=(0,e.computed)(()=>Cn(r.item)),o=(0,e.ref)(!1),s=(0,e.ref)(!1),c=(0,e.ref)(!1),l=(0,e.ref)(a.value.kind===`fallback`),u=(0,e.ref)(null),d=(0,e.ref)(null),f=(0,e.ref)(null),p=(0,e.ref)(null),m=(0,e.ref)(null),g=(0,e.ref)(a.value.kind===`fallback`),_=(0,e.computed)(()=>g.value?r.surfaceActive?o.value?a.value.url:null:a.value.url:null),y=(0,e.computed)(()=>r.surfaceActive&&o.value&&(a.value.kind===`image`||a.value.kind===`video`)&&!!a.value.url),b=(0,e.computed)(()=>a.value.kind===`image`&&!!_.value),x=(0,e.computed)(()=>a.value.kind===`video`&&!!_.value),S=(0,e.computed)(()=>!!u.value),C=(0,e.computed)(()=>Fe(u.value)),w=(0,e.computed)(()=>y.value&&!u.value&&(!g.value||!l.value)),E=null,D=null,O=new Set;(0,e.watch)([_,()=>a.value.kind],()=>{let e=a.value.kind===`fallback`;l.value=e,u.value=null,e&&(g.value=!0)}),(0,e.watch)(y,()=>{N()}),(0,e.watch)([o,l,_],()=>{P()}),(0,e.watch)(()=>r.surfaceActive,e=>{if(!e){I(),P();return}requestAnimationFrame(()=>{L(),N(),P()})}),(0,e.onMounted)(()=>{if(!f.value||typeof IntersectionObserver>`u`){p.value=null,o.value=!0,N();return}p.value=f.value.closest(`[data-testid="vibe-list-scroll"]`),E=new IntersectionObserver(e=>{for(let t of e)t.target===f.value&&(r.surfaceActive&&L(t),N(),P())},{root:p.value,threshold:[0,1]}),E.observe(f.value)}),(0,e.onBeforeUnmount)(()=>{F(),E?.disconnect(),E=null});function k(){U(d.value)&&(l.value=!0,u.value=null,R(_.value??r.item.url),I())}async function A(){if(!U(d.value))return;let e=_.value??r.item.url;l.value=!1,u.value=`generic`;let t=await Ie(e);u.value=t,r.reportAssetError?.({item:r.item,occurrenceKey:T(r.item),url:e,kind:t,surface:`grid`}),I()}function j(){U(m.value)&&(l.value=!0,u.value=null,R(_.value??r.item.url),I(),P())}function M(){U(m.value)&&(l.value=!1)}function N(){if(a.value.kind===`fallback`){F(!1);return}if(!r.surfaceActive){I();return}if(!y.value){F();return}if(g.value||D){D?.refresh();return}D=kn.request({assetType:a.value.kind,getPriority:H,onGrant(){g.value=!0,l.value=!1,u.value=null},url:a.value.url??r.item.url})}function P(){let e=m.value;if(!(!e||a.value.kind!==`video`)){if(u.value){e.pause();return}if(_.value&&o.value&&l.value){e.muted=!0,e.loop=!0,e.playsInline=!0,ze(e);return}try{e.currentTime=0}catch{}e.pause()}}function F(e=!0){g.value=a.value.kind===`fallback`,u.value=null,l.value=a.value.kind===`fallback`,e&&(B(),V()),I()}function I(){D?.release(),D=null}function L(e){let t=f.value;if(!t){o.value=!0;return}o.value=yn(e?.boundingClientRect??t.getBoundingClientRect(),e?.rootBounds??p.value?.getBoundingClientRect()??null)}function R(e){if(!e)return;let t=T(r.item),n=`${t}|${e}`;O.has(n)||(O.add(n),r.reportAssetLoad?.({item:r.item,occurrenceKey:t,surface:`grid`,url:e}))}function z(){if(!C.value)return;let e=T(r.item);O.forEach(t=>{t.startsWith(`${e}|`)&&O.delete(t)}),u.value=null,l.value=!1,g.value=!1,I(),N()}function B(){_n(d.value)}function V(){vn(m.value)}function H(){let e=f.value;if(!e)return 1/0;let t=e.getBoundingClientRect();if(p.value){let e=p.value.getBoundingClientRect(),n=e.top+e.height/2;return Math.abs((t.top+t.bottom)/2-n)}let n=window.innerHeight/2;return Math.abs((t.top+t.bottom)/2-n)}function U(e){let t=bn(_.value);return!e||!t?!1:bn(`currentSrc`in e&&e.currentSrc||e.getAttribute(`src`))===t}function W(){i(`open`)}function G(){s.value=!0}function K(e){let t=e.relatedTarget;f.value&&t instanceof Node&&f.value.contains(t)||(s.value=!1)}return(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{ref_key:`rootRef`,ref:f,"data-testid":`vibe-list-card-inner`,class:(0,e.normalizeClass)([`group relative h-full w-full overflow-hidden border bg-[#0a0b0f] text-[#f7f1ea] transition-[border-color,transform] duration-300`,r.active?`border-white/28`:`border-white/12 hover:border-white/24`]),onFocusin:G,onFocusout:K,onPointerenter:n[0]||=e=>c.value=!0,onPointerleave:n[1]||=e=>c.value=!1},[(0,e.createElementVNode)(`button`,{type:`button`,"data-testid":`vibe-list-card-open`,class:`absolute inset-0 z-[1] block h-full w-full cursor-pointer text-left focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-4 focus-visible:outline-[#f7f1ea]`,"aria-label":r.item.title||`Open item ${r.index+1}`,onClick:W},null,8,Mn),w.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Nn,[(0,e.createElementVNode)(`span`,Pn,[(0,e.createVNode)((0,e.unref)(h),{class:`h-5 w-5 animate-spin stroke-[1.9] text-[#f7f1ea]/78`,"aria-hidden":`true`})])])):(0,e.createCommentVNode)(``,!0),b.value&&_.value&&!S.value?((0,e.openBlock)(),(0,e.createElementBlock)(`img`,{key:1,ref_key:`imageRef`,ref:d,src:_.value,alt:a.value.label,draggable:`false`,class:(0,e.normalizeClass)([`block h-full w-full object-cover transition-opacity duration-300`,l.value?`pointer-events-none opacity-100`:`pointer-events-none opacity-0`]),onLoad:k,onError:A},null,42,Fn)):x.value&&_.value&&!S.value?((0,e.openBlock)(),(0,e.createElementBlock)(`video`,{key:2,ref_key:`videoRef`,ref:m,src:_.value,muted:``,loop:``,playsinline:``,preload:`metadata`,class:(0,e.normalizeClass)([`block h-full w-full object-cover transition-opacity duration-300`,l.value?`pointer-events-none opacity-100`:`pointer-events-none opacity-0`]),onCanplay:j,onError:A,onLoadstart:M,onPlaying:j,onStalled:M,onWaiting:M},null,42,In)):S.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:3,"data-testid":`vibe-list-card-error`,"data-kind":u.value,class:`relative z-[2] grid h-full w-full place-items-center bg-[radial-gradient(circle_at_center,rgba(239,68,68,0.12),transparent_65%),linear-gradient(180deg,rgba(255,255,255,0.04),rgba(255,255,255,0.02))]`},[(0,e.createElementVNode)(`div`,Rn,[(0,e.createVNode)((0,e.unref)(v),{class:`h-6 w-6 stroke-[1.8] text-[#f7f1ea]/78`,"aria-hidden":`true`}),(0,e.createElementVNode)(`span`,zn,(0,e.toDisplayString)((0,e.unref)(Pe)(u.value)),1),C.value?((0,e.openBlock)(),(0,e.createElementBlock)(`button`,{key:0,type:`button`,class:`pointer-events-auto inline-flex items-center justify-center border border-white/14 bg-black/35 px-3 py-2 text-[0.62rem] font-bold uppercase tracking-[0.22em] text-[#f7f1ea]/82 backdrop-blur-[18px] transition hover:border-white/28 hover:bg-black/50`,onClick:(0,e.withModifiers)(z,[`stop`])},` Retry `)):(0,e.createCommentVNode)(``,!0)])],8,Ln)):((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Bn,[(0,e.createElementVNode)(`div`,Vn,[(0,e.renderSlot)(t.$slots,`item-icon`,{icon:(0,e.unref)(Y)(r.item.type),item:r.item},()=>[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(Y)(r.item.type)),{class:`h-6 w-6 stroke-[1.8] text-[#f7f1ea]/78`,"aria-hidden":`true`}))])])])),(0,e.createElementVNode)(`div`,Hn,[(0,e.renderSlot)(t.$slots,`grid-item-overlay`,{active:r.active,focused:s.value,hovered:c.value,index:r.index,item:r.item,openFullscreen:W})])],34))}}),Wn={class:`relative h-full min-h-0 bg-[radial-gradient(circle_at_top_center,rgba(255,255,255,0.04),transparent_28%),linear-gradient(180deg,#06070b,#05060a)]`},Gn={class:`pointer-events-none absolute inset-x-0 top-0 z-[2] flex justify-end p-6`},Kn={"data-testid":`vibe-pagination`,class:`inline-flex shrink-0 items-center gap-2 whitespace-nowrap border border-white/14 bg-black/40 px-3 py-2 text-[0.63rem] font-bold uppercase tracking-[0.12em] text-[#f7f1ea]/72 backdrop-blur-[18px] min-[721px]:gap-3 min-[721px]:px-4 min-[721px]:py-3 min-[721px]:text-[0.74rem] min-[721px]:tracking-[0.2em]`},qn={class:`whitespace-nowrap`},Jn={key:0,class:`whitespace-nowrap border-l border-white/12 pl-2 text-[#f7f1ea]/56 min-[721px]:pl-3`},Yn=[`data-active`,`data-index`,`data-item-id`,`data-occurrence-key`],Xn={key:0,class:`pointer-events-none absolute inset-y-0 right-0 z-[3] hidden w-8 min-[1024px]:block`},Zn={key:1,class:`pointer-events-none absolute inset-x-0 bottom-0 z-[2] px-5 pb-5 sm:px-6`},Qn={class:`mx-auto flex w-full max-w-[1600px] justify-center`},$n={key:1,class:`inline-flex items-center border border-white/14 bg-black/55 px-4 py-3 text-[0.7rem] font-bold uppercase tracking-[0.18em] text-[#f7f1ea]/72 backdrop-blur-[18px]`},er=(0,e.defineComponent)({__name:`ListSurface`,props:{active:{type:Boolean,default:!0},activeIndex:{default:0},commitPendingAppend:{type:[Function,null],default:null},hasNextPage:{type:Boolean,default:!1},hasPreviousPage:{type:Boolean,default:!1},items:{},loading:{type:Boolean,default:!1},pendingAppendItems:{default:()=>[]},paginationDetail:{default:null},reportAssetError:{type:[Function,null],default:null},reportAssetLoad:{type:[Function,null],default:null},requestNextPage:{type:[Function,null],default:null},requestPreviousPage:{type:[Function,null],default:null},restoreToken:{}},emits:[`open-fullscreen`,`update:activeIndex`],setup(t,{emit:n}){let r=t,i=(0,e.useSlots)(),a=n,o=hn({active:(0,e.toRef)(r,`active`),items:(0,e.toRef)(r,`items`),activeIndex:(0,e.toRef)(r,`activeIndex`),loading:(0,e.toRef)(r,`loading`),hasNextPage:(0,e.toRef)(r,`hasNextPage`),hasPreviousPage:(0,e.toRef)(r,`hasPreviousPage`),paginationDetail:(0,e.toRef)(r,`paginationDetail`),pendingAppendItems:(0,e.toRef)(r,`pendingAppendItems`),commitPendingAppend:(0,e.toRef)(r,`commitPendingAppend`),requestNextPage:(0,e.toRef)(r,`requestNextPage`),requestPreviousPage:(0,e.toRef)(r,`requestPreviousPage`),restoreToken:(0,e.toRef)(r,`restoreToken`),setActiveIndex(e){a(`update:activeIndex`,e)}}),s=(0,e.computed)(()=>o.footerStatusMessage.value?{activeIndex:o.resolvedActiveIndex.value,kind:r.loading?`loading-more`:`end`,loading:r.loading,message:o.footerStatusMessage.value,paginationDetail:r.paginationDetail,total:r.items.length}:null),c=(0,e.computed)(()=>!s.value||!i[`grid-status`]?[]:i[`grid-status`](s.value)),l=(0,e.computed)(()=>X(c.value));return(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Wn,[(0,e.createElementVNode)(`div`,Gn,[(0,e.createElementVNode)(`span`,Kn,[(0,e.createElementVNode)(`span`,qn,(0,e.toDisplayString)((0,e.unref)(o).paginationLabel.value),1),r.paginationDetail?((0,e.openBlock)(),(0,e.createElementBlock)(`span`,Jn,(0,e.toDisplayString)(r.paginationDetail),1)):(0,e.createCommentVNode)(``,!0)])]),(0,e.createElementVNode)(`div`,{ref:(0,e.unref)(o).scrollViewportRef,"data-testid":`vibe-list-scroll`,class:`h-full min-h-0 overflow-y-auto overflow-x-hidden [overflow-anchor:none] [scrollbar-width:none] [-ms-overflow-style:none] [&::-webkit-scrollbar]:hidden`,onScroll:n[0]||=(...t)=>(0,e.unref)(o).onScroll&&(0,e.unref)(o).onScroll(...t),onWheel:n[1]||=(...t)=>(0,e.unref)(o).onWheel&&(0,e.unref)(o).onWheel(...t)},[(0,e.createElementVNode)(`div`,{"data-testid":`vibe-list-content`,class:`relative`,style:(0,e.normalizeStyle)({height:`${(0,e.unref)(o).containerHeight.value}px`})},[((0,e.openBlock)(!0),(0,e.createElementBlock)(e.Fragment,null,(0,e.renderList)((0,e.unref)(o).renderedItems.value,({item:n,index:s})=>((0,e.openBlock)(),(0,e.createElementBlock)(`article`,{key:(0,e.unref)(T)(n),"data-testid":`vibe-list-card`,"data-active":s===(0,e.unref)(o).resolvedActiveIndex.value?`true`:`false`,"data-index":s,"data-item-id":n.id,"data-occurrence-key":(0,e.unref)(T)(n),class:`absolute will-change-transform`,style:(0,e.normalizeStyle)((0,e.unref)(o).getCardStyle(s))},[(0,e.createVNode)(Un,{active:s===(0,e.unref)(o).resolvedActiveIndex.value,index:s,item:n,"report-asset-error":r.reportAssetError,"report-asset-load":r.reportAssetLoad,"surface-active":r.active,onOpen:e=>a(`open-fullscreen`,s)},(0,e.createSlots)({_:2},[i[`grid-item-overlay`]?{name:`grid-item-overlay`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`grid-item-overlay`,(0,e.mergeProps)({ref_for:!0},n))]),key:`0`}:void 0,i[`item-icon`]?{name:`item-icon`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`item-icon`,(0,e.mergeProps)({ref_for:!0},n))]),key:`1`}:void 0]),1032,[`active`,`index`,`item`,`report-asset-error`,`report-asset-load`,`surface-active`,`onOpen`])],12,Yn))),128))],4)],544),(0,e.unref)(o).showScrollbar.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Xn,[n[2]||=(0,e.createElementVNode)(`div`,{class:`absolute bottom-6 right-3 top-6 w-px bg-white/8`},null,-1),(0,e.createElementVNode)(`div`,{"data-testid":`vibe-list-scrollbar-thumb`,class:(0,e.normalizeClass)([`absolute right-[0.625rem] w-1 bg-white/34 transition-[height,transform,background-color,opacity] duration-300 ease-out`,r.loading?`bg-white/52`:`bg-white/34`]),style:(0,e.normalizeStyle)((0,e.unref)(o).getScrollbarThumbStyle())},null,6)])):(0,e.createCommentVNode)(``,!0),i[`grid-footer`]?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Zn,[(0,e.createElementVNode)(`div`,Qn,[(0,e.renderSlot)(t.$slots,`grid-footer`)])])):(0,e.createCommentVNode)(``,!0),s.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:2,class:(0,e.normalizeClass)([`pointer-events-none absolute inset-x-0 bottom-0 z-[3] flex justify-center px-6`,i[`grid-footer`]?`pb-24`:`pb-6`])},[l.value?(0,e.renderSlot)(t.$slots,`grid-status`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},s.value))):((0,e.openBlock)(),(0,e.createElementBlock)(`span`,$n,(0,e.toDisplayString)(s.value.message),1))],2)):(0,e.createCommentVNode)(``,!0)]))}}),tr=[`data-surface-mode`],nr={key:1,class:`absolute left-5 top-5 z-30 border border-amber-400/45 bg-black/35 px-4 py-2 text-xs font-medium uppercase tracking-[0.24em] text-amber-100 backdrop-blur`},rr={key:2,class:`relative z-[1] grid h-full w-full content-center justify-items-center gap-6 px-[clamp(2rem,4vw,3rem)] py-[clamp(2rem,4vw,3rem)] text-center`},ir=[`data-visible`,`inert`],ar=[`data-visible`,`inert`],or=(0,e.defineComponent)({name:`VibeLayout`,__name:`Layout`,props:{items:{},activeIndex:{},fillDelayMs:{},fillDelayStepMs:{},initialState:{},loading:{type:Boolean},hasNextPage:{type:Boolean},mode:{},resolve:{type:Function},initialCursor:{},pageSize:{},hasPreviousPage:{type:Boolean},paginationDetail:{},requestNextPage:{type:[Function,null]},requestPreviousPage:{type:[Function,null]}},emits:[`asset-errors`,`asset-loads`,`update:activeIndex`],setup(t,{expose:n,emit:r}){let i=t,a=(0,e.useSlots)(),o=r,s=ce(i,o),c=y(e=>{o(`asset-errors`,e)}),l=b(e=>{o(`asset-loads`,e)});return(0,e.onBeforeUnmount)(()=>{c.stop(),l.stop()}),n({cancel:s.cancel,clearRemoved:s.clearRemoved,getRemovedIds:s.getRemovedIds,loadNext:s.loadNext,loadPrevious:s.loadPrevious,remove:s.remove,restore:s.restore,retry:s.retry,status:s.status,undo:s.undo}),(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`section`,{"data-testid":`vibe`,"data-surface-mode":(0,e.unref)(s).surfaceMode.value,class:`relative h-full min-h-0 overflow-hidden bg-[#05060a] text-[#f7f1ea]`},[(0,e.unref)(s).canRetryInitialLoad.value?((0,e.openBlock)(),(0,e.createElementBlock)(`button`,{key:0,type:`button`,class:`absolute left-5 top-5 z-30 inline-flex items-center border border-rose-400/55 bg-rose-500/18 px-4 py-2 text-xs font-medium uppercase tracking-[0.24em] text-white backdrop-blur transition hover:bg-rose-500/28`,onClick:n[0]||=(...t)=>(0,e.unref)(s).retryInitialLoad&&(0,e.unref)(s).retryInitialLoad(...t)},` Retry `)):(0,e.unref)(s).errorMessage.value&&(0,e.unref)(s).items.value.length>0?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,nr,(0,e.toDisplayString)((0,e.unref)(s).errorMessage.value),1)):(0,e.createCommentVNode)(``,!0),(0,e.unref)(s).items.value.length===0?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,rr,[(0,e.unref)(s).loading.value?((0,e.openBlock)(),(0,e.createElementBlock)(e.Fragment,{key:0},[(0,e.createVNode)((0,e.unref)(h),{class:`size-10 animate-spin text-[#f7f1ea]/82`,"aria-hidden":`true`}),n[1]||=(0,e.createElementVNode)(`p`,{class:`m-0 text-[0.9rem] font-semibold uppercase tracking-[0.22em] text-[#f7f1ea]/72`},` Loading... `,-1)],64)):((0,e.openBlock)(),(0,e.createElementBlock)(e.Fragment,{key:1},[n[2]||=(0,e.createElementVNode)(`p`,{class:`m-0 text-[0.78rem] font-bold uppercase tracking-[0.28em] text-[#f7f1ea]/68`},` Viewer ready `,-1),n[3]||=(0,e.createElementVNode)(`h2`,{class:`m-0 text-[clamp(2rem,4.4vw,3.6rem)] leading-[0.95] tracking-[-0.05em]`},` No items available `,-1),n[4]||=(0,e.createElementVNode)(`p`,{class:`m-0 text-[clamp(0.98rem,1.3vw,1.12rem)] leading-[1.8] text-[#f7f1ea]/70`},` Attach items to VibeLayout to turn this screen into the viewer. `,-1)],64))])):(0,e.unref)(s).isDesktop.value?((0,e.openBlock)(),(0,e.createElementBlock)(e.Fragment,{key:3},[(0,e.createVNode)(e.Transition,{appear:``,"enter-active-class":`transition-[opacity,transform] duration-300 ease-out`,"enter-from-class":`translate-y-3 opacity-0`,"enter-to-class":`translate-y-0 opacity-100`,"leave-active-class":`transition-[opacity,transform] duration-300 ease-out`,"leave-from-class":`translate-y-0 opacity-100`,"leave-to-class":`translate-y-3 opacity-0`},{default:(0,e.withCtx)(()=>[(0,e.withDirectives)((0,e.createElementVNode)(`div`,{"data-testid":`vibe-list-surface`,"data-visible":(0,e.unref)(s).surfaceMode.value===`list`?`true`:`false`,inert:(0,e.unref)(s).surfaceMode.value!==`list`,class:`absolute inset-0 z-[2]`},[(0,e.createVNode)(er,{active:(0,e.unref)(s).surfaceMode.value===`list`,items:(0,e.unref)(s).items.value,"active-index":(0,e.unref)(s).activeIndex.value,loading:(0,e.unref)(s).loading.value,"has-next-page":(0,e.unref)(s).hasNextPage.value,"has-previous-page":(0,e.unref)(s).hasPreviousPage.value,"pending-append-items":(0,e.unref)(s).pendingAppendItems.value,"commit-pending-append":(0,e.unref)(s).commitPendingAppend,"pagination-detail":(0,e.unref)(s).paginationDetail.value,"report-asset-error":(0,e.unref)(c).report,"report-asset-load":(0,e.unref)(l).report,"request-next-page":(0,e.unref)(s).prefetchNextPage,"request-previous-page":(0,e.unref)(s).prefetchPreviousPage,"restore-token":(0,e.unref)(s).listRestoreToken.value,onOpenFullscreen:(0,e.unref)(s).openFullscreen,"onUpdate:activeIndex":(0,e.unref)(s).setActiveIndex},(0,e.createSlots)({_:2},[a[`grid-footer`]?{name:`grid-footer`,fn:(0,e.withCtx)(()=>[(0,e.renderSlot)(t.$slots,`grid-footer`)]),key:`0`}:void 0,a[`grid-item-overlay`]?{name:`grid-item-overlay`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`grid-item-overlay`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`1`}:void 0,a[`grid-status`]?{name:`grid-status`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`grid-status`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`2`}:void 0,a[`item-icon`]?{name:`item-icon`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`item-icon`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`3`}:void 0]),1032,[`active`,`items`,`active-index`,`loading`,`has-next-page`,`has-previous-page`,`pending-append-items`,`commit-pending-append`,`pagination-detail`,`report-asset-error`,`report-asset-load`,`request-next-page`,`request-previous-page`,`restore-token`,`onOpenFullscreen`,`onUpdate:activeIndex`])],8,ir),[[e.vShow,(0,e.unref)(s).surfaceMode.value===`list`]])]),_:3}),(0,e.createVNode)(e.Transition,{appear:``,"enter-active-class":`transition-[opacity,transform] duration-300 ease-out`,"enter-from-class":`-translate-y-3 opacity-0`,"enter-to-class":`translate-y-0 opacity-100`,"leave-active-class":`transition-[opacity,transform] duration-300 ease-out`,"leave-from-class":`translate-y-0 opacity-100`,"leave-to-class":`-translate-y-3 opacity-0`},{default:(0,e.withCtx)(()=>[(0,e.withDirectives)((0,e.createElementVNode)(`div`,{"data-testid":`vibe-fullscreen-surface`,"data-visible":(0,e.unref)(s).surfaceMode.value===`fullscreen`?`true`:`false`,inert:(0,e.unref)(s).surfaceMode.value!==`fullscreen`,class:`absolute inset-0 z-[3]`},[(0,e.createVNode)(At,{items:(0,e.unref)(s).items.value,active:(0,e.unref)(s).surfaceMode.value===`fullscreen`,"active-index":(0,e.unref)(s).activeIndex.value,loading:(0,e.unref)(s).loading.value,"has-next-page":(0,e.unref)(s).hasNextPage.value,"pagination-detail":(0,e.unref)(s).paginationDetail.value,"report-asset-error":(0,e.unref)(c).report,"report-asset-load":(0,e.unref)(l).report,"show-back-to-list":(0,e.unref)(s).showBackToList.value,onBackToList:(0,e.unref)(s).returnToList,"onUpdate:activeIndex":(0,e.unref)(s).setActiveIndex},(0,e.createSlots)({_:2},[a[`fullscreen-overlay`]?{name:`fullscreen-overlay`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`fullscreen-overlay`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`0`}:void 0,a[`fullscreen-aside`]?{name:`fullscreen-aside`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`fullscreen-aside`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`1`}:void 0,a[`fullscreen-header-actions`]?{name:`fullscreen-header-actions`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`fullscreen-header-actions`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`2`}:void 0,a[`fullscreen-status`]?{name:`fullscreen-status`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`fullscreen-status`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`3`}:void 0,a[`item-icon`]?{name:`item-icon`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`item-icon`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`4`}:void 0]),1032,[`items`,`active`,`active-index`,`loading`,`has-next-page`,`pagination-detail`,`report-asset-error`,`report-asset-load`,`show-back-to-list`,`onBackToList`,`onUpdate:activeIndex`])],8,ar),[[e.vShow,(0,e.unref)(s).surfaceMode.value===`fullscreen`]])]),_:3})],64)):((0,e.openBlock)(),(0,e.createBlock)(At,{key:4,items:(0,e.unref)(s).items.value,active:!0,"active-index":(0,e.unref)(s).activeIndex.value,loading:(0,e.unref)(s).loading.value,"has-next-page":(0,e.unref)(s).hasNextPage.value,"pagination-detail":(0,e.unref)(s).paginationDetail.value,"report-asset-error":(0,e.unref)(c).report,"report-asset-load":(0,e.unref)(l).report,"show-back-to-list":!1,onBackToList:(0,e.unref)(s).returnToList,"onUpdate:activeIndex":(0,e.unref)(s).setActiveIndex},(0,e.createSlots)({_:2},[a[`fullscreen-overlay`]?{name:`fullscreen-overlay`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`fullscreen-overlay`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`0`}:void 0,a[`fullscreen-aside`]?{name:`fullscreen-aside`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`fullscreen-aside`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`1`}:void 0,a[`fullscreen-header-actions`]?{name:`fullscreen-header-actions`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`fullscreen-header-actions`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`2`}:void 0,a[`fullscreen-status`]?{name:`fullscreen-status`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`fullscreen-status`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`3`}:void 0,a[`item-icon`]?{name:`item-icon`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`item-icon`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`4`}:void 0]),1032,[`items`,`active-index`,`loading`,`has-next-page`,`pagination-detail`,`report-asset-error`,`report-asset-load`,`onBackToList`,`onUpdate:activeIndex`]))],8,tr))}}),sr={install(e){e.component(`VibeLayout`,or)}};exports.VibeLayout=or,exports.VibePlugin=sr,exports.default=sr;
package/lib/index.d.ts CHANGED
@@ -1,7 +1,60 @@
1
1
  import type { Plugin } from 'vue';
2
- import Masonry from './components/Masonry.vue';
3
- import MasonryItem from './components/MasonryItem.vue';
4
- import MasonryVideoControls from './components/MasonryVideoControls.vue';
5
- export { Masonry, MasonryItem, MasonryVideoControls };
6
- export * from './masonry/types';
2
+ import './style.css';
3
+ export type { VibeViewerAsset, VibeViewerItem, VibeViewerType } from './components/viewer';
4
+ export type { VibeAssetErrorEvent, VibeAssetErrorKind, VibeAssetErrorSurface, VibeAssetLoadEvent, VibeAssetLoadSurface, VibeResolveParams, VibeResolveResult, VibeAutoProps, VibeControlledProps, VibeFeedMode, VibeHandle, VibeInitialState, VibeLoadPhase, VibeProps, VibeStatus, } from './components/viewer-core/useViewer';
5
+ export declare const VibeLayout: {
6
+ new (...args: any[]): import("vue").CreateComponentPublicInstanceWithMixins<Readonly<import(".").VibeControlledProps | import(".").VibeAutoProps> & Readonly<{
7
+ "onUpdate:activeIndex"?: ((value: number) => any) | undefined;
8
+ "onAsset-errors"?: ((errors: import(".").VibeAssetErrorEvent[]) => any) | undefined;
9
+ "onAsset-loads"?: ((loads: import(".").VibeAssetLoadEvent[]) => any) | undefined;
10
+ }>, import(".").VibeHandle, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
11
+ "update:activeIndex": (value: number) => any;
12
+ "asset-errors": (errors: import(".").VibeAssetErrorEvent[]) => any;
13
+ "asset-loads": (loads: import(".").VibeAssetLoadEvent[]) => any;
14
+ }, import("vue").PublicProps, {}, false, {}, {}, import("vue").GlobalComponents, import("vue").GlobalDirectives, string, {}, any, import("vue").ComponentProvideOptions, {
15
+ P: {};
16
+ B: {};
17
+ D: {};
18
+ C: {};
19
+ M: {};
20
+ Defaults: {};
21
+ }, {} & (Readonly<import(".").VibeControlledProps | import(".").VibeAutoProps> & Readonly<{
22
+ "onUpdate:activeIndex"?: ((value: number) => any) | undefined;
23
+ "onAsset-errors"?: ((errors: import(".").VibeAssetErrorEvent[]) => any) | undefined;
24
+ "onAsset-loads"?: ((loads: import(".").VibeAssetLoadEvent[]) => any) | undefined;
25
+ }>), import(".").VibeHandle, {}, {}, {}, {}>;
26
+ __isFragment?: never;
27
+ __isTeleport?: never;
28
+ __isSuspense?: never;
29
+ } & import("vue").ComponentOptionsBase<Readonly<import(".").VibeControlledProps | import(".").VibeAutoProps> & Readonly<{
30
+ "onUpdate:activeIndex"?: ((value: number) => any) | undefined;
31
+ "onAsset-errors"?: ((errors: import(".").VibeAssetErrorEvent[]) => any) | undefined;
32
+ "onAsset-loads"?: ((loads: import(".").VibeAssetLoadEvent[]) => any) | undefined;
33
+ }>, import(".").VibeHandle, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
34
+ "update:activeIndex": (value: number) => any;
35
+ "asset-errors": (errors: import(".").VibeAssetErrorEvent[]) => any;
36
+ "asset-loads": (loads: import(".").VibeAssetLoadEvent[]) => any;
37
+ }, string, {}, {}, string, {}, import("vue").GlobalComponents, import("vue").GlobalDirectives, string, import("vue").ComponentProvideOptions> & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps & (new () => {
38
+ $slots: {
39
+ 'fullscreen-aside'?: (props: import("./components/viewer-core/surfaceSlots").VibeSurfaceSlotProps) => unknown;
40
+ 'fullscreen-header-actions'?: (props: import("./components/viewer-core/surfaceSlots").VibeSurfaceSlotProps) => unknown;
41
+ 'fullscreen-overlay'?: (props: import("./components/viewer-core/surfaceSlots").VibeSurfaceSlotProps) => unknown;
42
+ 'fullscreen-status'?: (props: import("./components/viewer-core/surfaceSlots").VibeFullscreenStatusSlotProps) => unknown;
43
+ 'grid-footer'?: () => unknown;
44
+ 'grid-item-overlay'?: (props: {
45
+ active: boolean;
46
+ focused: boolean;
47
+ hovered: boolean;
48
+ index: number;
49
+ item: import(".").VibeViewerItem;
50
+ openFullscreen: () => void;
51
+ }) => unknown;
52
+ 'grid-status'?: (props: import("./components/viewer-core/surfaceSlots").VibeGridStatusSlotProps) => unknown;
53
+ 'item-icon'?: (props: {
54
+ icon: import("vue").Component;
55
+ item: import(".").VibeViewerItem;
56
+ }) => unknown;
57
+ };
58
+ });
7
59
  export declare const VibePlugin: Plugin;
60
+ export default VibePlugin;