@wyxos/vibe 3.1.12 → 3.1.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
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`}]]),y=l(`volume-1`,[[`path`,{d:`M11 4.702a.705.705 0 0 0-1.203-.498L6.413 7.587A1.4 1.4 0 0 1 5.416 8H3a1 1 0 0 0-1 1v6a1 1 0 0 0 1 1h2.416a1.4 1.4 0 0 1 .997.413l3.383 3.384A.705.705 0 0 0 11 19.298z`,key:`uqj9uw`}],[`path`,{d:`M16 9a5 5 0 0 1 0 6`,key:`1q6k2b`}]]),b=l(`volume-2`,[[`path`,{d:`M11 4.702a.705.705 0 0 0-1.203-.498L6.413 7.587A1.4 1.4 0 0 1 5.416 8H3a1 1 0 0 0-1 1v6a1 1 0 0 0 1 1h2.416a1.4 1.4 0 0 1 .997.413l3.383 3.384A.705.705 0 0 0 11 19.298z`,key:`uqj9uw`}],[`path`,{d:`M16 9a5 5 0 0 1 0 6`,key:`1q6k2b`}],[`path`,{d:`M19.364 18.364a9 9 0 0 0 0-12.728`,key:`ijwkga`}]]),x=l(`volume-x`,[[`path`,{d:`M11 4.702a.705.705 0 0 0-1.203-.498L6.413 7.587A1.4 1.4 0 0 1 5.416 8H3a1 1 0 0 0-1 1v6a1 1 0 0 0 1 1h2.416a1.4 1.4 0 0 1 .997.413l3.383 3.384A.705.705 0 0 0 11 19.298z`,key:`uqj9uw`}],[`line`,{x1:`22`,x2:`16`,y1:`9`,y2:`15`,key:`1ewh16`}],[`line`,{x1:`16`,x2:`22`,y1:`9`,y2:`15`,key:`5ykzw1`}]]);function S(e,t=150){return w(e,e=>`${e.surface}|${e.occurrenceKey}|${e.url}|${e.kind}`,t)}function C(e,t=150){return w(e,e=>`${e.surface}|${e.occurrenceKey}|${e.url}`,t)}function w(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 T(e){return e instanceof HTMLElement&&[`INPUT`,`TEXTAREA`,`SELECT`].includes(e.tagName)}function E(e){return e instanceof HTMLElement&&!!e.closest(`[data-swipe-lock], input, textarea, select, a`)}function D(e){return e===`filling`||e===`initializing`||e===`loading`||e===`refreshing`}function O(e){return!e||!Number.isFinite(e)||e<1?25:Math.floor(e)}function k(e){return e??`__vibe_initial_cursor__`}function A(e,t,n){return Math.min(Math.max(e,t),n)}function j(){let t=(0,e.ref)(new Set),n=(0,e.ref)([]);function r(e){let r=M(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=M(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 M(e){let t=Array.isArray(e)?e:[e];return Array.from(new Set(t.filter(e=>typeof e==`string`&&e.length>0)))}var N=`__vibeOccurrenceKey`;function P(e){let t=e[N];return typeof t==`string`&&t.length>0?t:e.id}function F(e,t,n){let r=new Map,i=[],a=n;for(let e of t){let t=r.get(e.id),n=P(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(I(t,e))}return{items:i,nextSequence:a}}function I(e,t){return P(e)===t?e:{...e,[N]:t}}function L(e){return e.flatMap(e=>e.items)}function R(e,t){return t.size?e.filter(e=>!t.has(e.id)):e}function z(e,t){return R(e.items,t)}function B(e,t){return z(e,t).length}function V(e,t,n){if(n<0)return null;let r=0;for(let i of e){let e=z(i,t),a=r+e.length;if(n<a)return i.cursor;r=a}return null}function H(e,t,n){let r=[...e],i=r.findIndex(e=>e.cursor===t);return i>=0&&r.splice(i,1,n),r}function U(e,t,n){let r=F(e,t,n);return{items:r.items,nextSequence:r.nextSequence}}function W(e,t,n,r){let i=new Map,a=e.map(e=>({item:e,matchIndex:null,occurrenceKey:null})),o=new Map,s=new Map,c=n;for(let[e,n]of t.entries()){let t=i.get(n.id),r={index:e,occurrenceKey:P(n)};t?t.push(r):i.set(n.id,[r])}for(let e of a){let t=i.get(e.item.id)?.shift();t&&(e.matchIndex=t.index,e.occurrenceKey=t.occurrenceKey)}let l=[],u=null;for(let e of a)l.push(u),e.matchIndex!==null&&(u=e.matchIndex);let d=Array(a.length).fill(null),f=null;for(let e=a.length-1;e>=0;--e)d[e]=f,a[e].matchIndex!==null&&(f=a[e].matchIndex);for(let[e,n]of a.entries()){if(n.matchIndex!==null&&n.occurrenceKey){o.set(n.matchIndex,G(n.item,n.occurrenceKey));continue}let i=d[e]??(l[e]===null?null:l[e]+1)??(r===`leading`?0:t.length),a=G(n.item,`vibe-occurrence-${c+=1}`),u=s.get(i);u?u.push(a):s.set(i,[a])}let p=[];for(let e=0;e<=t.length;e+=1){let n=s.get(e);n?.length&&p.push(...n),!(e>=t.length)&&p.push(o.get(e)??t[e])}return{items:p,nextSequence:c}}function G(e,t){return P(e)===t?e:{...e,__vibeOccurrenceKey:t}}function K(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 q(e){let t=U(e.nextItems,e.previousItems,e.sequence);return{bucket:{cursor:e.cursor,items:t.items,nextCursor:e.nextCursor,previousCursor:e.previousCursor},nextSequence:t.nextSequence}}function J(e){let t=W(e.nextItems,e.previousItems,e.sequence,e.edge);return{bucket:{cursor:e.cursor,items:t.items,nextCursor:e.nextCursor,previousCursor:e.previousCursor},nextSequence:t.nextSequence}}function Y(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+B(t,n),0)}}function X(e){let t=q({cursor:e.initialState.cursor,nextCursor:e.initialState.nextCursor??null,nextItems:e.initialState.items,previousCursor:e.initialState.previousCursor??null,previousItems:[],sequence:e.sequence}),n=R(t.bucket.items,e.removedIds);return{activeIndex:A(e.initialState.activeIndex??0,0,Math.max(0,n.length-1)),buckets:[t.bucket],nextSequence:t.nextSequence}}function ee(e,t){let n=e[A(t,0,Math.max(0,e.length-1))];return n?P(n):null}function te(e,t,n=null){if(!e.length)return 0;let r=n?e.findIndex(e=>P(e)===n):-1;return r>=0?r:A(t,0,e.length-1)}function ne(e,t,n){return e?B(e,t)<n:!1}var re=2e3,ie=1e3,ae=100;function oe(e,t=re,n=ie){return t+Math.max(0,e-1)*n}function se(e,t){return!Number.isFinite(e)||e==null||e<0?t:Math.floor(e)}function ce(){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,ae),r=setTimeout(l,e),u()}))}return{clear:a,remainingMs:t,wait:o}}function le(t){let n=!!t.initialState?.items.length,r=(0,e.ref)([]),i=(0,e.ref)(0),a=(0,e.ref)([]),o=(0,e.ref)(!1),s=(0,e.ref)(null),c=(0,e.ref)(!n&&typeof t.resolve==`function`?`initializing`:`idle`),l=(0,e.ref)(null),u=(0,e.ref)(null),d=ce(),f=d.remainingMs,p=(0,e.ref)(null),m=(0,e.ref)(!1),h=(0,e.ref)(!0),g=(0,e.ref)(!1),_=new Set,v=null,y=null,b=0,x=0,S=(0,e.computed)(()=>se(t.fillDelayMs,re)),C=(0,e.computed)(()=>se(t.fillDelayStepMs,ie)),w=(0,e.computed)(()=>typeof t.resolve==`function`),T=(0,e.computed)(()=>O(t.pageSize)),E=(0,e.computed)(()=>L(r.value)),j=(0,e.computed)(()=>R(E.value,t.removedIds.value)),M=(0,e.computed)(()=>i.value),N=(0,e.computed)(()=>D(c.value)||m.value),F=(0,e.computed)(()=>ue(r.value,t.removedIds.value)),I=(0,e.computed)(()=>de(r.value,t.removedIds.value)),z=(0,e.computed)(()=>I.value?.nextCursor??null),U=(0,e.computed)(()=>o.value?null:F.value?.previousCursor??null),W=(0,e.computed)(()=>!!z.value),G=(0,e.computed)(()=>!!U.value),ae=(0,e.computed)(()=>w.value&&r.value.length>0),le=(0,e.computed)(()=>R(L(a.value),t.removedIds.value)),fe=(0,e.computed)(()=>V(r.value,t.removedIds.value,M.value)),pe=(0,e.computed)(()=>!j.value.length&&!N.value&&!!s.value);(0,e.watch)(()=>j.value.length,e=>{if(e===0){i.value=0;return}o.value&&=(Le(),!1),i.value>e-1&&(i.value=e-1)}),(0,e.watch)(()=>i.value,()=>{h.value&&Oe()}),(0,e.onMounted)(()=>{Pe()||t.resolve&&me()}),(0,e.onBeforeUnmount)(()=>{v?.abort(),v=null,d.clear(!0)});async function me(){y=me;let e=await Me({continueUntilFilled:!0,cursor:t.initialCursor??null,direction:`forward`,phase:`initializing`});e&&(r.value=e.buckets,i.value=0,Z())}async function he(){if(!(g.value||N.value)){if(Ie(`trailing`)||!W.value){if(!ae.value)return;let e=await je(`trailing`);e?.followCursor&&Ie(`trailing`)&&await ke(e.followCursor);return}await ke(z.value)}}async function ge(){if(!(g.value||!G.value||N.value)){if(Ie(`leading`)){let e=await je(`leading`);e?.itemsLoaded===0&&e.followCursor&&await Ae(e.followCursor);return}await Ae(U.value)}}async function _e(){if(pe.value){if(r.value=[],i.value=0,a.value=[],o.value=!1,s.value=null,c.value=w.value?`initializing`:`idle`,l.value=null,u.value=null,p.value=null,m.value=!1,_.clear(),v?.abort(),v=null,d.clear(!0),Pe()){Z();return}await me()}}async function ve(){if(pe.value)return _e();g.value||c.value!==`failed`||!y||(s.value=null,await y())}async function ye(){if(!a.value.length)return m.value=!1,Z();r.value=[...r.value,...a.value],a.value=[],m.value=!1,Z()}function be(e){let n=j.value;if(!n.length)return;let r=A(e,0,n.length-1);r!==i.value&&(i.value=r,t.emit(`update:activeIndex`,r))}function xe(e){h.value=e}function Se(){g.value=!0,d.clear(!0)}function Ce(){g.value=!1}function we(){b+=1,v?.abort(),v=null,d.clear(!0),_.clear(),s.value=null,l.value=null,u.value=null,p.value=null,a.value.length>0&&(r.value=[...r.value,...a.value],a.value=[]),m.value=!1,o.value=!1,Z()}function Te(){return ee(j.value,M.value)}function Ee(e=null,t={}){if(j.value.length===0){i.value=0,!t.preserveTrailingPlaceholder&&r.value.length>0&&(o.value=!0);return}if(e){let t=j.value.findIndex(t=>P(t)===e);if(t>=0){i.value=t;return}}if(t.preserveTrailingPlaceholder&&i.value>=j.value.length){i.value=j.value.length;return}i.value=te(j.value,M.value,e)}function De(){a.value.length>0&&!le.value.length&&ye()}async function Oe(){if(!(!h.value||Fe())){if(!j.value.length){W.value&&await he();return}G.value&&i.value<3&&await ge(),W.value&&i.value>=j.value.length-3&&await he()}}async function ke(e){y=async()=>{await ke(e)};let t=await Me({continueUntilFilled:!0,cursor:e,direction:`forward`,phase:`loading`});if(t){if(t.canceled)return r.value=[...r.value,...t.buckets],a.value=[],m.value=!1,Z();if(a.value=t.buckets,!le.value.length)return r.value=[...r.value,...a.value],a.value=[],m.value=!1,Z();m.value=!0}}async function Ae(e){y=async()=>{await Ae(e)};let t=await Me({continueUntilFilled:!0,cursor:e,direction:`backward`,phase:`loading`});if(!t)return;let n=Te();r.value=[...t.buckets,...r.value],Ee(n),Z()}async function je(e){if(y=async()=>{await je(e)},!t.resolve)return null;let n=e===`leading`?F.value:I.value;if(!n)return null;let i=k(n.cursor);if(_.has(i))return null;_.add(i),s.value=null,c.value=`refreshing`,l.value=null,u.value=null,p.value=null;let a=++b,o=typeof AbortController>`u`?null:new AbortController;v=o;try{let i=await t.resolve({cursor:n.cursor,pageSize:T.value,signal:o?.signal});if(a!==b)return Z(),null;let s=J({cursor:n.cursor,edge:e,nextCursor:i.nextPage,nextItems:i.items,previousCursor:i.previousPage??null,previousItems:n.items,sequence:x});x=s.nextSequence;let c=Te();return r.value=H(r.value,n.cursor,s.bucket),Ee(c),Z(),{followCursor:e===`leading`?i.previousPage??null:i.nextPage,itemsLoaded:i.items.length}}catch(e){return K(e)||a!==b?(Z(),null):(s.value=e instanceof Error?e.message:`The viewer could not load items.`,c.value=`failed`,l.value=null,u.value=null,p.value=null,null)}finally{v===o&&(v=null),_.delete(i)}}async function Me(e){if(!t.resolve)return null;let n=++b,r=new Set,i=[],a=e.cursor,o=0;for(s.value=null,c.value=e.phase,l.value=null,u.value=null,p.value=null;;){if(n!==b)return Y(i,e.direction,t.removedIds.value,!0);if(i.length>0&&g.value)return Y(i,e.direction,t.removedIds.value,!1);let f=k(a);if(r.has(f)||_.has(f))break;r.add(f),_.add(f);let m=typeof AbortController>`u`?null:new AbortController;v=m;try{let r=await t.resolve({cursor:a,pageSize:T.value,signal:m?.signal});if(n!==b)return Y(i,e.direction,t.removedIds.value,!0);let s=Ne({cursor:a,nextCursor:r.nextPage,nextItems:r.items,previousCursor:r.previousPage??null,previousItems:[]});i.push(s);let f=i.reduce((e,n)=>e+B(n,t.removedIds.value),0),h=e.direction===`forward`?s.nextCursor:s.previousCursor;if(!e.continueUntilFilled||f>=T.value||!h)return u.value=null,{canceled:!1,buckets:e.direction===`backward`?[...i].reverse():i,visibleCount:f};if(g.value)return Y(i,e.direction,t.removedIds.value,!1);c.value=`filling`,l.value=f,u.value=h,p.value=T.value,o+=1;let _=oe(o,S.value,C.value);if(await d.wait(_),n!==b)return Y(i,e.direction,t.removedIds.value,!0);a=h}catch(r){return K(r)||n!==b?Y(i,e.direction,t.removedIds.value,!0):(s.value=r instanceof Error?r.message:`The viewer could not load items.`,c.value=`failed`,l.value=null,u.value=null,p.value=null,null)}finally{v===m&&(v=null),_.delete(f)}}return Y(i,e.direction,t.removedIds.value,!1)}function Ne(e){let t=q({cursor:e.cursor,nextCursor:e.nextCursor,nextItems:e.nextItems,previousCursor:e.previousCursor,previousItems:e.previousItems,sequence:x});return x=t.nextSequence,t.bucket}function Z(){c.value=`idle`,l.value=null,u.value=null,p.value=null,d.clear()}function Pe(){if(!t.initialState||!t.initialState.items.length)return!1;let e=X({initialState:t.initialState,removedIds:t.removedIds.value,sequence:x});return r.value=e.buckets,i.value=e.activeIndex,x=e.nextSequence,o.value=!1,s.value=null,a.value=[],m.value=!1,!0}function Fe(){return c.value===`initializing`}function Ie(e){return ne(e===`leading`?F.value:I.value,t.removedIds.value,T.value)}function Le(){let e=r.value.findIndex(e=>B(e,t.removedIds.value)>0);if(e<0)return;let n=e;for(let i=r.value.length-1;i>=e;--i)if(B(r.value[i],t.removedIds.value)>0){n=i;break}r.value=r.value.slice(e,n+1)}return{activeIndex:M,canRetryInitialLoad:pe,cancel:we,canRefreshTrailingBoundary:ae,commitPendingAppend:ye,currentCursor:fe,errorMessage:s,fillCollectedCount:l,fillCursor:u,fillDelayRemainingMs:f,fillTargetCount:p,hasNextPage:W,hasPreviousPage:G,isAutoPrefetchEnabled:h,isPageLoadingLocked:g,items:j,lockPageLoading:Se,loading:N,maybePrefetchAround:Oe,nextCursor:z,pendingAppendItems:le,phase:c,prefetchNextPage:he,prefetchPreviousPage:ge,previousCursor:U,retryInitialLoad:_e,retry:ve,setActiveIndex:be,setAutoPrefetchEnabled:xe,syncActiveIndexAfterVisibilityChange:Ee,unlockPageLoading:Ce,getActiveOccurrenceKey:Te,maybeCommitPendingAppendWhenFilteredOut:De}}function ue(e,t){return e.find(e=>B(e,t)>0)??e[0]??null}function de(e,t){for(let n=e.length-1;n>=0;--n){let r=e[n];if(B(r,t)>0)return r}return e[e.length-1]??null}function fe(t,n){let{clearRemoved:r,getRemovedIds:i,remove:a,removedIds:o,restore:s,undo:c}=j(),l=le({emit:n,fillDelayMs:t.fillDelayMs,fillDelayStepMs:t.fillDelayStepMs,initialCursor:t.initialCursor,initialState:t.initialState,pageSize:t.pageSize,removedIds:o,resolve:t.resolve}),u=l.items,d=l.activeIndex,f=l.loading,p=l.hasNextPage,m=l.hasPreviousPage,h=(0,e.computed)(()=>o.value.size),g=(0,e.computed)(()=>t.paginationDetail??null),_=(0,e.computed)(()=>!l.hasNextPage.value&&l.canRefreshTrailingBoundary.value);function v(e){let t=u.value;t.length&&l.setActiveIndex(C(e,0,t.length-1))}function y(e){let t=l.getActiveOccurrenceKey(),n=u.value[d.value]??null,r=Array.isArray(e)?e:[e],i=!!(n&&r.includes(n.id)&&l.isAutoPrefetchEnabled.value&&d.value>=u.value.length-3),o=!!(n&&r.includes(n.id)&&l.hasNextPage.value&&d.value===u.value.length-1),s=a(e);return s.ids.length?(l.maybeCommitPendingAppendWhenFilteredOut(),l.syncActiveIndexAfterVisibilityChange(t,{preserveTrailingPlaceholder:o}),i&&l.maybePrefetchAround(),s):s}function b(e){let t=l.getActiveOccurrenceKey(),n=s(e);return n.ids.length&&l.syncActiveIndexAfterVisibilityChange(t),n}function x(){let e=l.getActiveOccurrenceKey(),t=c();return t?.ids.length&&l.syncActiveIndexAfterVisibilityChange(e),t}function S(){let e=l.getActiveOccurrenceKey();r(),l.syncActiveIndexAfterVisibilityChange(e)}function C(e,t,n){return Math.min(Math.max(e,t),n)}function w(){l.cancel()}async function T(){await l.prefetchNextPage()}async function E(){await l.prefetchPreviousPage()}async function D(){await l.retry()}return{activeIndex:d,canRefreshExhaustedNextPage:_,canRetryInitialLoad:l.canRetryInitialLoad,cancel:w,clearRemoved:S,commitPendingAppend:l.commitPendingAppend,currentCursor:l.currentCursor,errorMessage:l.errorMessage,fillCollectedCount:l.fillCollectedCount,fillCursor:l.fillCursor,fillDelayRemainingMs:l.fillDelayRemainingMs,fillTargetCount:l.fillTargetCount,getRemovedIds:i,hasNextPage:p,hasPreviousPage:m,isPageLoadingLocked:l.isPageLoadingLocked,items:u,lockPageLoading:l.lockPageLoading,loading:f,loadNext:T,loadPrevious:E,nextCursor:l.nextCursor,paginationDetail:g,pendingAppendItems:l.pendingAppendItems,phase:l.phase,prefetchNextPage:l.prefetchNextPage,prefetchPreviousPage:l.prefetchPreviousPage,previousCursor:l.previousCursor,removedCount:h,remove:y,restore:b,retry:D,retryInitialLoad:l.retryInitialLoad,setActiveIndex:v,setAutoPrefetchEnabled:l.setAutoPrefetchEnabled,undo:x,unlockPageLoading:l.unlockPageLoading}}var pe=1024;function me(t,n){let r=fe(t,n),i=(0,e.reactive)({nextBoundaryLoadProgress:0,previousBoundaryLoadProgress:0}),a=(0,e.ref)(0),o=(0,e.ref)(`list`),s=(0,e.reactive)({activeIndex:0,currentCursor:null,errorMessage:null,fillCollectedCount:null,fillCursor:null,fillDelayRemainingMs:null,fillTargetCount:null,hasNextPage:!1,hasPreviousPage:!1,itemCount:0,loadState:`loaded`,nextBoundaryLoadProgress:0,nextCursor:null,pageLoadingLocked:!1,phase:`idle`,previousBoundaryLoadProgress:0,previousCursor:null,removedCount:0,removedIds:[],surfaceMode:`list`}),c=(0,e.computed)(()=>a.value>=pe),l=(0,e.computed)(()=>c.value?o.value:`fullscreen`),u=(0,e.computed)(()=>c.value&&l.value===`fullscreen`);(0,e.watch)(c,e=>{e&&h()}),(0,e.watch)(()=>t.surfaceMode,()=>{h()}),(0,e.watch)([l,()=>r.pendingAppendItems.value.length],([e,t])=>{e===`list`||t<=0||r.commitPendingAppend()}),(0,e.watch)([()=>r.items.value.length,()=>r.loading.value,()=>r.hasNextPage.value,()=>r.pendingAppendItems.value.length],([e,t,r,i])=>{!c.value||e>0||o.value===`list`||t||r||i>0||(o.value=`list`,n(`update:surfaceMode`,`list`))}),(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.fillCursor=r.fillCursor.value,s.fillDelayRemainingMs=r.fillDelayRemainingMs.value,s.fillTargetCount=r.fillTargetCount.value,s.hasNextPage=r.hasNextPage.value,s.hasPreviousPage=r.hasPreviousPage.value,s.itemCount=r.items.value.length,s.loadState=r.loading.value?`loading`:r.errorMessage.value?`failed`:`loaded`,s.nextBoundaryLoadProgress=i.nextBoundaryLoadProgress,s.nextCursor=r.nextCursor.value,s.pageLoadingLocked=r.isPageLoadingLocked.value,s.phase=r.phase.value,s.previousBoundaryLoadProgress=i.previousBoundaryLoadProgress,s.previousCursor=r.previousCursor.value,s.removedCount=r.removedCount.value,s.removedIds=r.getRemovedIds(),s.surfaceMode=l.value}),(0,e.onMounted)(()=>{m(),h(),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&&o.value!==`fullscreen`&&(o.value=`fullscreen`,n(`update:surfaceMode`,`fullscreen`))}function f(){!c.value||o.value===`list`||(o.value=`list`,n(`update:surfaceMode`,`list`))}function p(e){e.defaultPrevented||e.key!==`Escape`||!c.value||l.value!==`fullscreen`||T(e.target)||(e.preventDefault(),f())}function m(){a.value=window.innerWidth||0}function h(){!c.value||!t.surfaceMode||t.surfaceMode===o.value||(o.value=t.surfaceMode)}function g(e){i.nextBoundaryLoadProgress=he(e.nextBoundaryLoadProgress),i.previousBoundaryLoadProgress=he(e.previousBoundaryLoadProgress)}return{...r,cancel:r.cancel,isDesktop:c,lockPageLoading:r.lockPageLoading,loadNext:r.loadNext,loadPrevious:r.loadPrevious,openFullscreen:d,returnToList:f,retry:r.retry,setBoundaryLoadProgress:g,showBackToList:u,status:(0,e.readonly)(s),surfaceMode:l,unlockPageLoading:r.unlockPageLoading}}function he(e){return Math.min(Math.max(e,0),1)}var ge={"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]`},_e={class:`grid grid-cols-[auto_minmax(0,1fr)_auto_auto] items-center gap-3 border-t border-white/12 bg-black/70 px-4 py-3 backdrop-blur-[18px]`},ve={class:`text-[0.76rem] font-bold uppercase tracking-[0.18em] text-[#f7f1ea]/74`},ye={class:`relative h-4 w-full`},be=[`max`,`value`,`disabled`],xe={class:`text-[0.76rem] font-bold uppercase tracking-[0.18em] text-[#f7f1ea]/74`},Se=[`data-layout`],Ce={key:0,"data-testid":`vibe-media-volume-popover`,class:`absolute bottom-[calc(100%+0.8rem)] right-0 grid justify-items-center gap-3 border border-white/12 bg-black/82 px-3 py-4 shadow-[0_20px_50px_-20px_rgba(0,0,0,0.85)] backdrop-blur-[18px]`},we={class:`relative flex h-28 w-4 items-center justify-center`},Te=[`value`],Ee={class:`flex items-center gap-3`},De=[`aria-label`],Oe={key:0,class:`relative h-4 w-24`},ke=[`value`],Ae=(0,e.defineComponent)({__name:`FullscreenMediaBar`,props:{currentTime:{},currentTimeLabel:{},duration:{},durationLabel:{},muted:{type:Boolean},progress:{},volume:{},volumeControlLayout:{}},emits:[`seek-input`,`volume-input`,`volume-toggle`],setup(t,{emit:n}){let r=t,i=n,a=(0,e.ref)(null),o=(0,e.ref)(!1),s=(0,e.computed)(()=>r.volumeControlLayout===`vertical`),c=(0,e.computed)(()=>g(r.volume,0,1)),l=(0,e.computed)(()=>Math.round(c.value*100)),u=(0,e.computed)(()=>r.muted||c.value<=0?x:c.value<.5?y:b),d=(0,e.computed)(()=>r.muted||c.value<=0?`Unmute active media`:`Mute active media`),f=(0,e.computed)(()=>s.value&&!o.value?`Show volume controls`:d.value),p=(0,e.computed)(()=>r.volumeControlLayout===`vertical`?{height:`${l.value}%`}:{width:`${l.value}%`});(0,e.watch)(s,e=>{e||(o.value=!1)}),(0,e.onMounted)(()=>{document.addEventListener(`pointerdown`,m)}),(0,e.onBeforeUnmount)(()=>{document.removeEventListener(`pointerdown`,m)});function m(e){!s.value||!o.value||a.value&&e.target instanceof Node&&!a.value.contains(e.target)&&(o.value=!1)}function h(){if(!s.value){i(`volume-toggle`);return}if(!o.value){o.value=!0;return}i(`volume-toggle`)}function g(e,t,n){return Math.min(Math.max(e,t),n)}return(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,ge,[(0,e.createElementVNode)(`div`,_e,[(0,e.createElementVNode)(`span`,ve,(0,e.toDisplayString)(r.currentTimeLabel),1),(0,e.createElementVNode)(`div`,ye,[n[3]||=(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,be)]),(0,e.createElementVNode)(`span`,xe,(0,e.toDisplayString)(r.durationLabel),1),(0,e.createElementVNode)(`div`,{ref_key:`rootRef`,ref:a,"data-testid":`vibe-media-volume`,"data-layout":r.volumeControlLayout,class:`relative flex items-center justify-end`},[s.value&&o.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Ce,[(0,e.createElementVNode)(`div`,we,[n[4]||=(0,e.createElementVNode)(`div`,{class:`absolute bottom-0 left-1/2 h-full w-px -translate-x-1/2 bg-white/12`},null,-1),(0,e.createElementVNode)(`div`,{class:`absolute bottom-0 left-1/2 w-px -translate-x-1/2 bg-[#f7f1ea]`,style:(0,e.normalizeStyle)(p.value)},null,4),(0,e.createElementVNode)(`input`,{"data-testid":`vibe-media-volume-slider`,"data-swipe-lock":`true`,type:`range`,"aria-label":`Adjust active media volume`,min:`0`,max:`1`,step:`0.05`,value:c.value,class:`vibe-media-slider absolute left-1/2 top-1/2 h-4 w-28 -translate-x-1/2 -translate-y-1/2 -rotate-90 bg-transparent`,onInput:n[1]||=e=>i(`volume-input`,e)},null,40,Te)])])):(0,e.createCommentVNode)(``,!0),(0,e.createElementVNode)(`div`,Ee,[(0,e.createElementVNode)(`button`,{type:`button`,"data-testid":`vibe-media-volume-button`,"aria-label":f.value,class:`inline-flex h-10 w-10 items-center justify-center border border-white/14 bg-black/50 text-[#f7f1ea]/82 backdrop-blur-[18px] transition hover:border-white/28 hover:bg-black/65`,onClick:h},[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)(u.value),{class:`h-4 w-4 stroke-[1.9]`,"aria-hidden":`true`}))],8,De),r.volumeControlLayout===`horizontal`?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Oe,[n[5]||=(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)(p.value)},null,4),(0,e.createElementVNode)(`input`,{"data-testid":`vibe-media-volume-slider`,"data-swipe-lock":`true`,type:`range`,"aria-label":`Adjust active media volume`,min:`0`,max:`1`,step:`0.05`,value:c.value,class:`vibe-media-slider absolute inset-0 z-10 h-4 w-full cursor-pointer bg-transparent`,onInput:n[2]||=e=>i(`volume-input`,e)},null,40,ke)])):(0,e.createCommentVNode)(``,!0)])],8,Se)])]))}}),je={class:`pointer-events-none absolute inset-0 z-[3] flex flex-col justify-between p-[clamp(1.25rem,2.6vw,2.25rem)]`},Me={class:`grid gap-4`},Ne={class:`flex min-h-11 items-center justify-between gap-4`},Z={class:`min-w-0 flex flex-1 items-center gap-3`},Pe={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]`},Fe={class:`pointer-events-auto flex shrink-0 items-center gap-2`},Ie={"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]`},Le={class:`whitespace-nowrap`},Re={key:1,class:`whitespace-nowrap border-l border-white/12 pl-2 text-[#f7f1ea]/56 min-[721px]:pl-3`},ze={key:0,class:`grid gap-2 max-[720px]:justify-items-start`},Be=(0,e.defineComponent)({__name:`FullscreenHeader`,props:{currentIndex:{},loading:{type:Boolean},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`,je,[(0,e.createElementVNode)(`div`,Me,[(0,e.createElementVNode)(`div`,Ne,[(0,e.createElementVNode)(`div`,Z,[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`,Pe,(0,e.toDisplayString)(r.title),1)):(0,e.createCommentVNode)(``,!0)]),(0,e.createElementVNode)(`div`,Fe,[(0,e.createElementVNode)(`span`,Ie,[r.loading?((0,e.openBlock)(),(0,e.createBlock)((0,e.unref)(h),{key:0,"data-testid":`vibe-pagination-spinner`,class:`h-3.5 w-3.5 animate-spin stroke-[1.9]`,"aria-hidden":`true`})):(0,e.createCommentVNode)(``,!0),(0,e.createElementVNode)(`span`,Le,(0,e.toDisplayString)(r.currentIndex+1)+` / `+(0,e.toDisplayString)(r.total),1),r.paginationDetail?((0,e.openBlock)(),(0,e.createElementBlock)(`span`,Re,(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`,ze,[...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)]))}}),Ve={image:m,video:f,audio:d,other:p},He={image:`Image`,video:`Video`,audio:`Audio`,other:`File`};function Ue(e){return Ve[e]}function We(e){return He[e]}var Ge={maxGlobal:10,maxPerDomain:4,maxVideoPerDomain:2};function Ke(e=Ge){let t=new Map,n=new Map,r=0;function i(e){let i={...e,domain:Xe(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=Je(e)-Je(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){if(!Ye(n))return!1;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 qe=Ke();function Je(e){try{let t=e.getPriority();return Number.isFinite(t)?t:1/0}catch{return 1/0}}function Ye(e){try{return e.canGrant?.()??!0}catch{return!1}}function Xe(e){try{return new URL(e).hostname||`local`}catch{return`local`}}var Ze=[-1,1,2],Qe=[-1,1],$e={[-1]:0,1:0,2:1};function et(t){let n=(0,e.ref)({}),r=Ke({maxGlobal:2,maxPerDomain:2,maxVideoPerDomain:2}),i=new Map,a=new Map,o=new Map,s=new Set,c=new Set;(0,e.watch)([t.active,t.items,t.resolvedActiveIndex],()=>{m()},{immediate:!0}),(0,e.getCurrentScope)()&&(0,e.onScopeDispose)(()=>{p()});function l(e){if(!t.active.value)return!1;let r=t.items.value[e];if(!r||!it(r))return!1;let i=t.getItemKey(r);return i===g()||!!n.value[i]}function u(e,t){if(t instanceof HTMLImageElement){a.set(e,t),nt(t)&&b(e);return}a.delete(e)}function d(e,t){if(t instanceof HTMLMediaElement){o.set(e,t),rt(t)&&b(e);return}o.delete(e)}function f(e){s.add(e);let t=i.get(e);if(!t){x();return}t.lease.release(),i.delete(e)}function p(){for(let e of i.values())e.lease.release();i.clear(),n.value={},S()}function m(){if(!t.active.value){p();return}let e=h(),s=new Set(e.map(e=>e.key)),l=g();for(let e of c)e!==l&&s.has(e)&&C(e,!0);for(let e of Object.keys(n.value))s.has(e)||C(e,!1);for(let[t,n]of i.entries()){if(!s.has(t)){n.lease.release(),i.delete(t);continue}let r=e.find(e=>e.key===t);r&&(n.index=r.index)}for(let t of e){if(i.has(t.key)||n.value[t.key])continue;let e;e={index:t.index,key:t.key,lease:r.request({assetType:t.item.type===`image`?`image`:`video`,canGrant:()=>v(e.index),getPriority:()=>_(e.index),onGrant:()=>{C(t.key,!0),tt(t.key,a,o)&&f(t.key)},url:t.item.url})},i.set(t.key,e)}for(let e of i.values())e.lease.refresh();S()}function h(){let e=t.resolvedActiveIndex.value;return Ze.map(t=>y(e+t)).filter(e=>!!e)}function g(){let e=t.items.value[t.resolvedActiveIndex.value];return!t.active.value||!e||!it(e)?null:t.getItemKey(e)}function _(e){return t.active.value?$e[e-t.resolvedActiveIndex.value]??1/0:1/0}function v(e){return e-t.resolvedActiveIndex.value===2?Qe.every(e=>{let n=y(t.resolvedActiveIndex.value+e);return n?s.has(n.key):!0}):!0}function y(e){let n=t.items.value[e];return!n||!it(n)?null:{index:e,item:n,key:t.getItemKey(n)}}function b(e){f(e)}function x(){for(let e of i.values())e.lease.refresh()}function S(){let e=new Set,r=g();r&&e.add(r);for(let t of Object.keys(n.value))e.add(t);for(let n of c)e.has(n)||(s.delete(n),w(n),t.onResetAssetState(n));c=e}function C(e,t){if(t){if(n.value[e])return;n.value={...n.value,[e]:!0};return}if(!n.value[e])return;let r={...n.value};delete r[e],n.value=r}function w(e){let t=a.get(e);if(t)try{t.removeAttribute(`src`),t.src=``}catch{}let n=o.get(e);if(n){try{n.currentTime=0}catch{}n.pause();try{n.removeAttribute(`src`),n.load()}catch{}}}return{clearBackgroundPreloads:p,registerImageElement:u,registerMediaElement:d,settleBackgroundPreload:f,shouldAttachSlideAsset:l}}function tt(e,t,n){let r=t.get(e);if(r)return nt(r);let i=n.get(e);return i?rt(i):!1}function nt(e){return e.complete&&!!(e.currentSrc||e.getAttribute(`src`))}function rt(e){let t=typeof HTMLMediaElement>`u`?1:HTMLMediaElement.HAVE_METADATA;return e.readyState>=t}function it(e){return e.type===`image`||e.type===`video`||e.type===`audio`}function at(e){let t=et({active:e.active,getItemKey:r,items:e.items,onResetAssetState:e.viewer.resetAssetState,resolvedActiveIndex:e.resolvedActiveIndex});function n(e,t){let n=t.title?.trim();return n?`${e} ${n}`:`${e} ${We(t.type).toLowerCase()}`}function r(e){return P(e)}function i(e){return t.shouldAttachSlideAsset(e)}function a(t,n){let a=r(n);return!i(t)||t!==e.resolvedActiveIndex.value||e.viewer.getAssetErrorKind(a)?!1:n.type===`image`?!e.viewer.isImageReady(a):n.type===`video`||n.type===`audio`?!e.viewer.isMediaReady(a):!1}function o(t){return e.viewer.getAssetErrorKind(r(t))}function s(t){return e.viewer.getAssetErrorLabel(r(t))??`Load error`}function c(t,n){return i(t)&&t===e.resolvedActiveIndex.value&&!!o(n)}function l(t,n){return i(t)?e.viewer.getImageSource(n):void 0}function u(e){return i(e)?`metadata`:`none`}function d(e,t){return i(e)?t.url:void 0}return{getAssetErrorKind:o,getAssetErrorLabel:s,getFullscreenImageSource:l,getFullscreenMediaPreload:u,getFullscreenMediaSource:d,getItemKey:r,getMediaActionLabel:n,isAssetErrored:c,isAssetLoading:a,registerImageElement:t.registerImageElement,registerMediaElement:t.registerMediaElement,settleBackgroundPreload:t.settleBackgroundPreload,shouldPreloadSlideAsset:i}}function ot(t){if(!Array.isArray(t))return!1;for(let n of t){if(Array.isArray(n)){if(ot(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(!st(n))return!0}return!1}function st(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?!ot(t.children):!1}var ct=`no items available`;function lt(t){let n=(0,e.computed)(()=>t.loading.value||t.itemCount.value>0||t.emptyStateMode.value===`hidden`?null:{loading:!!t.loading.value,message:ct,mode:t.emptyStateMode.value===`badge`?`badge`:`inline`,surface:t.surface,total:t.itemCount.value}),r=(0,e.computed)(()=>!n.value||!t.renderSlot?[]:t.renderSlot(n.value));return{emptyStateProps:n,showBadgeEmptyState:(0,e.computed)(()=>n.value?.mode===`badge`),showCustomEmptyState:(0,e.computed)(()=>ot(r.value)),showInlineEmptyState:(0,e.computed)(()=>n.value?.mode===`inline`)}}function ut(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 dt(e){return e.phase?e.phase:e.loading?e.itemCount>0?`loading`:`initializing`:`idle`}function ft(e){return e.phase===`failed`?{kind:`failed`,message:e.errorMessage??(e.hasItems?`The viewer could not load more items.`:`The viewer could not load items.`)}:e.phase===`initializing`?{kind:`initializing`,message:`Loading the first page`}:e.phase===`loading`?{kind:`loading-more`,message:e.hasItems?`Loading more items`:`Loading the first page`}:e.phase===`filling`?{kind:`filling`,message:`Filling the view`}:e.phase===`refreshing`?{kind:`refreshing`,message:!e.hasNextPage&&e.hasItems?e.surface===`grid`?`Refreshing the end of the list`:`Refreshing the end of the feed`:`Refreshing visible items`}:!e.hasItems||e.hasNextPage?null:{kind:`end`,message:e.surface===`grid`?`End of list`:`End of feed`}}function pt(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 mt={currentTime:0,duration:0,errorKind:null,muted:!1,paused:!0,ready:!1,volume:1};function ht(){return{...mt}}function gt(e){return e.complete&&!!(e.currentSrc||e.getAttribute(`src`))}function _t(e,t,n){e.currentTime=Number.isFinite(t.currentTime)?t.currentTime:0,e.duration=Number.isFinite(t.duration)?t.duration:0,e.muted=t.muted,e.paused=t.paused,e.volume=Number.isFinite(t.volume)?t.volume:e.volume,n&&n!==`error`&&(e.errorKind=null),e.ready=vt(t,n)}function vt(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 yt=new Map;function bt(e){return e===`not-found`?`404`:`Load error`}function xt(e){return e===`generic`}function St(e){return Ct(e).then(e=>e??`generic`)}function Ct(e){let t=yt.get(e);if(t)return t;let n=wt(e);return yt.set(e,n),n}async function wt(e){if(!Tt(e))return null;try{let t=await fetch(e,{method:`HEAD`});return t.ok?null:t.status===404?`not-found`:`generic`}catch{return`generic`}}function Tt(e){return/^(https?:\/\/|\/)/i.test(e)}function Et(e){try{let t=e.play();t&&typeof t.catch==`function`&&t.catch(()=>{})}catch{}}function Dt(t){let n=(0,e.ref)({}),r=(0,e.ref)({}),i=(0,e.ref)({}),a=(0,e.ref)({}),o=(0,e.ref)({}),s=new Map,c=new Map,l=new Set,u=(0,e.computed)(()=>t.activeItem.value?P(t.activeItem.value):null),d=(0,e.computed)(()=>t.activeMediaItem.value?P(t.activeMediaItem.value):null),f=(0,e.computed)(()=>{let e=new Map;for(let n of t.items.value)e.set(P(n),n);return e}),p=(0,e.computed)(()=>d.value?i.value[d.value]??mt:mt),m=(0,e.computed)(()=>d.value?p.value.duration:0),h=(0,e.computed)(()=>m.value<=0?0:Ot(p.value.currentTime/m.value*100,0,100)),g=(0,e.computed)(()=>u.value?I(u.value):null);(0,e.watch)(()=>u.value,async()=>{await S()}),(0,e.watch)(()=>t.itemCount.value,async()=>{await S()}),(0,e.watch)(()=>t.loopFullscreenVideo.value,async()=>{await S()});function _(e,t){if(t instanceof HTMLVideoElement){s.set(e,t),W(e,t);return}s.delete(e)}function v(e,t){if(t instanceof HTMLAudioElement){c.set(e,t),W(e,t);return}c.delete(e)}function y(e,t){t instanceof HTMLImageElement&>(t)&&(n.value[e]=!0,r.value[e]=null,X(e,t.currentSrc||t.src||te(e)))}function b(){H(),a.value={},r.value={},n.value={},o.value={},i.value={},l.clear()}function x(e){delete n.value[e],delete r.value[e],delete o.value[e],delete i.value[e],l.forEach(t=>{t.startsWith(`${e}|`)&&l.delete(t)})}async function S(){if(!t.isEnabled.value){H();return}await(0,e.nextTick)();let n=u.value;for(let[e,r]of s.entries()){if(e!==n||i.value[e]?.errorKind){V(r,e);continue}r.muted=!1,r.loop=t.loopFullscreenVideo.value,r.playsInline=!0,Et(r),W(e,r)}for(let[e,t]of c.entries()){if(e!==n||i.value[e]?.errorKind){V(t,e);continue}Et(t),W(e,t)}}function C(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;W(e,n,t.type);let a=i.value[e]?.ready??!1;!r&&a&&X(e,n.currentSrc||n.src||te(e))}}function w(e,t){n.value[e]=!0,r.value[e]=null,X(e,t)}async function T(e,i){let a=ee(e)??t.activeItem.value;n.value[e]=!1,r.value[e]=`generic`;let o=await St(i);r.value[e]=o,a&&t.onAssetError?.({item:a,occurrenceKey:e,url:i,kind:o,surface:`fullscreen`})}async function E(e,n){let r=q(e),i=U(e),a=ee(e)??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 St(n);i.errorKind=o,a&&t.onAssetError?.({item:a,occurrenceKey:e,url:n,kind:o,surface:`fullscreen`})}function D(e,t,n){e.button!==0||Date.now()<n||Y(s.get(t)??null)}function O(e,t,n){e.button!==0||Date.now()<n||Y(q(t))}function k(e){let t=J(),n=d.value;if(!t||!n||!(e.target instanceof HTMLInputElement))return;let r=Number.parseFloat(e.target.value);if(!Number.isFinite(r))return;let i=Ot(r,0,m.value||0);G(n,i,t),t.currentTime=i}function A(e){let t=J(),n=d.value;if(!t||!n||!(e.target instanceof HTMLInputElement))return;let r=Ot(Number.parseFloat(e.target.value),0,1);t.volume=r,t.muted=r<=0,r>0&&(o.value[n]=r),W(n,t)}function j(){let e=J(),t=d.value;!e||!t||(e.muted||e.volume<=0?(e.volume=K(t),e.muted=!1,o.value[t]=e.volume):(o.value[t]=e.volume,e.muted=!0),W(t,e))}function M(e){return!!n.value[e]&&!r.value[e]}function N(e){return(i.value[e]?.ready??!1)&&!i.value[e]?.errorKind}function F(e){return e.url}function I(e){return r.value[e]??i.value[e]?.errorKind??null}function L(e){let t=I(e);return t?bt(t):null}function R(e){return xt(I(e))}function z(e){return`${e}:${a.value[e]??0}`}async function B(t){if(!R(t))return;n.value[t]=!1,r.value[t]=null;let i=U(t);i.currentTime=0,i.duration=0,i.paused=!0,i.ready=!1,i.errorKind=null;let o=q(t);o&&V(o,t),l.forEach(e=>{e.startsWith(`${t}|`)&&l.delete(e)}),a.value[t]=(a.value[t]??0)+1,await(0,e.nextTick)(),await S()}function V(e,t){e.pause();try{e.currentTime=0}catch{}W(t,e)}function H(){for(let[e,t]of s.entries())V(t,e);for(let[e,t]of c.entries())V(t,e)}function U(e){return i.value[e]||(i.value[e]=ht()),i.value[e]}function W(e,t,n){_t(U(e),t,n),!t.muted&&t.volume>0&&(o.value[e]=t.volume)}function G(e,t,n){let r=U(e);r.currentTime=t,r.duration=Number.isFinite(n.duration)?n.duration:r.duration,r.muted=n.muted,r.paused=n.paused,r.volume=Number.isFinite(n.volume)?n.volume:r.volume}function K(e){return Ot(o.value[e]??1,0,1)}function q(e){return s.get(e)??c.get(e)??null}function J(){return d.value?q(d.value):null}function Y(e){if(e){if(e.paused){Et(e);return}e.pause()}}function X(e,n){let r=ee(e)??t.activeMediaItem.value??t.activeItem.value;if(!r||!n)return;let i=`${e}|${n}`;l.has(i)||(l.add(i),t.onAssetLoad?.({item:r,occurrenceKey:e,surface:`fullscreen`,url:n}))}function ee(e){return f.value.get(e)??null}function te(e){return ee(e)?.url??null}return{activeAssetErrorKind:g,activeMediaDuration:m,activeMediaProgress:h,activeMediaState:p,getAssetErrorKind:I,getAssetErrorLabel:L,getAssetRenderKey:z,getImageSource:F,isImageReady:M,isMediaReady:N,canRetryAsset:R,mediaStates:i,onAudioCoverClick:O,onImageError:T,onImageLoad:w,onMediaError:E,onMediaEvent:C,onMediaSeekInput:k,onMediaVolumeInput:A,onMediaVolumeToggle:j,onVideoClick:D,registerAudioElement:v,registerImageElement:y,registerVideoElement:_,resetAssetState:x,resetMediaState:b,retryAsset:B,syncMediaPlayback:S}}function Ot(e,t,n){return Math.min(Math.max(e,t),n)}function kt(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 At(e,t,n=2){let r=kt(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 jt(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 Mt(t,n,r={}){let i=(0,e.computed)(()=>t.items),a=(0,e.computed)(()=>t.activeIndex??0),o=(0,e.computed)(()=>t.errorMessage??null),s=(0,e.computed)(()=>t.loading??!1),c=(0,e.computed)(()=>t.hasNextPage??!1),l=(0,e.computed)(()=>t.loopFullscreenVideo??!0),u=(0,e.computed)(()=>t.paginationDetail??null),d=(0,e.computed)(()=>dt({itemCount:i.value.length,loading:s.value,phase:t.phase})),f=(0,e.computed)(()=>!1),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,S=(0,e.computed)(()=>i.value.length===0?0:F(a.value,0,i.value.length-1)),C=(0,e.computed)(()=>i.value[S.value]??null),w=(0,e.computed)(()=>C.value?.type===`audio`||C.value?.type===`video`?C.value:null),D=Dt({items:i,activeItem:C,activeMediaItem:w,isEnabled:_,itemCount:(0,e.computed)(()=>i.value.length),loopFullscreenVideo:l,onAssetError:r.onAssetError,onAssetLoad:r.onAssetLoad}),O=(0,e.computed)(()=>i.value.length>0&&S.value===i.value.length-1),k=(0,e.computed)(()=>ft({errorMessage:o.value,hasItems:i.value.length>0,hasNextPage:c.value,phase:d.value,surface:`fullscreen`})),A=(0,e.computed)(()=>k.value?.kind??null),j=(0,e.computed)(()=>k.value?.message??null),M=(0,e.computed)(()=>Math.min(96,g.value*.15||96)),N=(0,e.computed)(()=>kt(S.value,i.value.length)),P=(0,e.computed)(()=>At(i.value,S.value));pt({enabled:_,onDisable(){G(),D.resetMediaState()},onEnable(){return D.syncMediaPlayback()},onKeydown:q,onResize:I});function F(e,t,n){return Math.min(Math.max(e,t),n)}function I(){g.value=p.value?.clientHeight||window.innerHeight||1}function L(e){return i.value.length===0?!1:F(S.value+e,0,i.value.length-1)!==S.value}function R(e){if(i.value.length===0)return;let t=F(S.value+e,0,i.value.length-1);t!==S.value&&n(`update:activeIndex`,t)}function z(e){let t=e>0,n=e<0;return t&&!L(-1)||n&&!L(1)?e*.24:e}function B(e){!_.value||i.value.length===0||e.pointerType===`mouse`||E(e.target)||(v=e.pointerId,y=e.clientY,m.value=0,h.value=!0,p.value?.setPointerCapture?.(e.pointerId))}function V(e){!_.value||!h.value||v!==e.pointerId||(m.value=z(e.clientY-y))}function H(e){!_.value||v!==e.pointerId||(p.value?.releasePointerCapture?.(e.pointerId),W())}function U(e){!_.value||v!==e.pointerId||(p.value?.releasePointerCapture?.(e.pointerId),G())}function W(){Math.abs(m.value)>=M.value&&(x=Date.now()+250,R(m.value<0?1:-1)),G()}function G(){m.value=0,h.value=!1,v=null}function K(e){if(!_.value||i.value.length===0||h.value||E(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,R(e.deltaY>0?1:-1))}function q(e){!_.value||i.value.length===0||T(e.target)||((e.key===`ArrowDown`||e.key===`PageDown`)&&(e.preventDefault(),R(1)),(e.key===`ArrowUp`||e.key===`PageUp`)&&(e.preventDefault(),R(-1)))}function J(e,t){D.onVideoClick(e,t,x)}function Y(e,t){D.onAudioCoverClick(e,t,x)}function X(e){D.onMediaSeekInput(e)}function ee(e){D.onMediaVolumeInput(e)}function te(){D.onMediaVolumeToggle()}function ne(e){return e.type===`image`||e.type===`video`}function re(e){return e.type===`audio`}function ie(e){return jt(e,S.value,g.value,m.value,h.value)}return{activeItem:C,activeAssetErrorKind:D.activeAssetErrorKind,activeMediaDuration:D.activeMediaDuration,activeMediaItem:w,activeMediaProgress:D.activeMediaProgress,activeMediaState:D.activeMediaState,canRetryAsset:D.canRetryAsset,canRetryInitialLoad:f,errorMessage:o,getAssetErrorKind:D.getAssetErrorKind,getAssetErrorLabel:D.getAssetErrorLabel,getAssetRenderKey:D.getAssetRenderKey,formatPlaybackTime:ut,getImageSource:D.getImageSource,getSlideStyle:ie,hasNextPage:c,isAtEnd:O,isAudio:re,isVisual:ne,items:i,loading:s,mediaStates:D.mediaStates,isImageReady:D.isImageReady,isMediaReady:D.isMediaReady,onAudioCoverClick:Y,onImageError:D.onImageError,onImageLoad:D.onImageLoad,onMediaEvent:D.onMediaEvent,onMediaError:D.onMediaError,onMediaSeekInput:X,onMediaVolumeInput:ee,onMediaVolumeToggle:te,onPointerCancel:U,onPointerDown:B,onPointerMove:V,onPointerUp:H,onVideoClick:J,onWheel:K,registerAudioElement:D.registerAudioElement,registerImageElement:D.registerImageElement,registerVideoElement:D.registerVideoElement,renderedItems:P,renderedRange:N,resolvedActiveIndex:S,resetAssetState:D.resetAssetState,retryInitialLoad:async()=>{},retryAsset:D.retryAsset,stageRef:p,statusKind:A,statusMessage:j,paginationDetail:u,phase:d}}var Nt=`bg-[linear-gradient(180deg,#0a0b10,#05060a)]`,Pt=`bg-[linear-gradient(180deg,#0b0c11,#06070b)]`,Ft={image:!0,video:!0,audio:!0,other:!0};function It(e){return Ft[e],Nt}function Lt(e){return Ft[e],Pt}function Rt(e){if(e.naturalWidth<=0||e.naturalHeight<=0)return null;let t=document.createElement(`canvas`),n=t.getContext(`2d`,{willReadFrequently:!0});if(!n)return null;t.width=24,t.height=24;try{n.drawImage(e,0,0,24,24);let{data:t}=n.getImageData(0,0,24,24),r=0,i=0,a=0,o=0;for(let e=0;e<t.length;e+=4){let n=t[e+3]/255;if(n<=.05)continue;let s=t[e],c=t[e+1],l=t[e+2],u=Math.max(s,c,l),d=n*(.65+(u===0?0:(u-Math.min(s,c,l))/u)*.7);r+=d,i+=s*d,a+=c*d,o+=l*d}return r<=0?null:{r:zt(Math.round(i/r)),g:zt(Math.round(a/r)),b:zt(Math.round(o/r))}}catch{return null}}function zt(e){return Math.min(235,Math.max(26,e))}function Bt(t){let n=(0,e.ref)({}),r=(0,e.computed)(()=>t.activeItem.value?t.getItemKey(t.activeItem.value):null),i=(0,e.computed)(()=>!t.showDominantImageTone.value||t.activeItem.value?.type!==`image`||!r.value||!t.isImageReady(r.value)?null:n.value[r.value]??null),a=(0,e.computed)(()=>{if(!i.value)return;let{r:e,g:t,b:n}=i.value;return{background:`radial-gradient(circle at top center, rgba(${e},${t},${n},0.34) 0%, transparent 44%), linear-gradient(180deg,#0a0b10,#05060a)`}}),o=(0,e.computed)(()=>{if(!i.value)return;let{r:e,g:t,b:n}=i.value;return{background:`radial-gradient(circle at center, rgba(${e},${t},${n},0.42) 0%, transparent 44%), linear-gradient(180deg,#0b0c11,#06070b)`}});(0,e.watch)(()=>t.showDominantImageTone.value,e=>{e||(n.value={})});function s(e,r){if(!t.showDominantImageTone.value)return;let i=Rt(r);i&&(n.value[e]=i)}return{activeStageToneStyle:a,activeSlideToneStyle:o,updateFromImageElement:s}}var Vt=[`data-surface`],Ht=[`data-surface`],Ut=(0,e.defineComponent)({inheritAttrs:!1,__name:`SurfaceEmptyState`,props:{message:{},mode:{},surface:{}},setup(t){let n=(0,e.useAttrs)();return(r,i)=>t.mode===`inline`?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,(0,e.mergeProps)({key:0},(0,e.unref)(n),{"data-testid":`vibe-empty-state-inline`,"data-surface":t.surface,class:[`pointer-events-none absolute z-[4] text-center`,t.surface===`grid`?`inset-x-0 top-[clamp(6rem,22vh,11rem)] flex justify-center px-6`:`inset-0 grid place-items-center px-[clamp(2rem,4vw,3rem)] py-[clamp(2rem,4vw,3rem)]`]}),[(0,e.renderSlot)(r.$slots,`default`,{},()=>[(0,e.createElementVNode)(`p`,{class:(0,e.normalizeClass)([`m-0 text-[0.82rem] font-medium tracking-[0.08em]`,t.surface===`grid`?`text-[#f7f1ea]/58`:`text-[#f7f1ea]/64`])},(0,e.toDisplayString)(t.message),3)])],16,Vt)):((0,e.openBlock)(),(0,e.createElementBlock)(`div`,(0,e.mergeProps)({key:1},(0,e.unref)(n),{class:[`pointer-events-none absolute z-[4]`,t.surface===`grid`?`inset-x-0 bottom-0 flex justify-center px-6`:`bottom-[1.8rem] left-1/2 -translate-x-1/2 max-[720px]:bottom-[1.3rem]`]}),[(0,e.renderSlot)(r.$slots,`default`,{},()=>[(0,e.createElementVNode)(`span`,{"data-testid":`vibe-empty-state-badge`,"data-surface":t.surface,class:(0,e.normalizeClass)([`inline-flex items-center border border-white/14 backdrop-blur-[18px]`,t.surface===`grid`?`bg-black/55 px-4 py-3 text-[0.82rem] font-medium tracking-[0.08em] text-[#f7f1ea]/72`:`w-auto bg-black/40 px-5 py-3 text-[0.82rem] font-medium tracking-[0.08em] text-[#f7f1ea]/74 max-[720px]:w-[calc(100%-2.5rem)] max-[720px]:justify-center`])},(0,e.toDisplayString)(t.message),11,Ht)])],16))}}),Wt={class:`relative h-full min-h-0 overflow-hidden bg-[#05060a] text-[#f7f1ea]`},Gt={key:0,class:`relative h-full min-h-0`},Kt=[`data-item-id`,`data-occurrence-key`,`data-index`,`data-active`,`aria-hidden`],qt={key:0,"data-testid":`vibe-asset-spinner`,class:`pointer-events-none absolute inset-0 z-[2] grid place-items-center`},Jt={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]`},Yt=[`data-kind`],Xt={class:`grid justify-items-center gap-4 border border-white/14 bg-black/45 px-8 py-7 text-center backdrop-blur-[18px]`},Zt={class:`m-0 text-[0.82rem] font-bold uppercase tracking-[0.28em] text-[#f7f1ea]/70`},Qt=[`onClick`],$t=[`src`,`alt`,`onLoad`,`onError`],en=[`loop`,`src`,`preload`,`onClick`,`onCanplay`,`onDurationchange`,`onEnded`,`onError`,`onLoadstart`,`onLoadedmetadata`,`onPause`,`onPlay`,`onPlaying`,`onSeeking`,`onSeeked`,`onStalled`,`onTimeupdate`,`onWaiting`],tn={class:`relative grid aspect-square w-[clamp(320px,46vw,560px)] max-w-[calc(100vw-2.5rem)] place-items-center`},nn=[`aria-label`,`disabled`,`onClick`],rn={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]`},an={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]`},on={key:0,"data-testid":`vibe-asset-spinner`,class:`pointer-events-none absolute inset-0 z-[3] grid place-items-center`},sn={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]`},cn=[`data-kind`],ln={class:`m-0 text-[0.82rem] font-bold uppercase tracking-[0.28em] text-[#f7f1ea]/70`},un=[`onClick`],dn=[`src`,`preload`,`onCanplay`,`onDurationchange`,`onError`,`onLoadstart`,`onLoadedmetadata`,`onPause`,`onPlay`,`onPlaying`,`onSeeking`,`onSeeked`,`onStalled`,`onTimeupdate`,`onWaiting`],fn={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`},pn={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]`},mn={key:0,"data-testid":`vibe-fullscreen-overlay`,class:`pointer-events-none absolute inset-0 z-[6]`},hn={class:`h-full w-full`},gn={key:1,"data-testid":`vibe-forward-fill-placeholder`,class:`grid h-full min-h-0 place-items-center px-6 text-center`},_n={class:`grid justify-items-center gap-4 border border-white/14 bg-black/40 px-8 py-7 backdrop-blur-[18px]`},vn={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)]`},yn={class:`m-0 text-[0.78rem] font-bold uppercase tracking-[0.24em] text-[#f7f1ea]/72`},bn={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]`},xn={class:`h-full min-h-0 overflow-y-auto overscroll-y-contain`},Sn={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]`},Cn={class:`h-full min-h-0 overflow-y-auto overscroll-y-contain`},wn=1280,Tn=768,En=(0,e.defineComponent)({__name:`FullscreenSurface`,props:{active:{type:Boolean,default:!0},activeIndex:{default:0},emptyStateMode:{default:`inline`},errorMessage:{default:null},hasNextPage:{type:Boolean,default:!1},items:{},loading:{type:Boolean,default:!1},loopFullscreenVideo:{type:Boolean,default:!0},paginationDetail:{default:null},phase:{default:null},reportAssetError:{type:[Function,null],default:null},reportAssetLoad:{type:[Function,null],default:null},showDominantImageTone:{type:Boolean,default:!0},showBackToList:{type:Boolean,default:!1},showEndBadge:{type:Boolean,default:!0},showStatusBadges:{type:Boolean,default:!0}},emits:[`back-to-list`,`update:activeIndex`],setup(t,{emit:n}){let r=t,i=(0,e.useSlots)(),a=n,o=Mt(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`?wn:window.innerWidth||wn),c=at({active:(0,e.toRef)(r,`active`),items:o.items,resolvedActiveIndex:o.resolvedActiveIndex,viewer:o}),l=(0,e.computed)(()=>It(o.activeItem.value?.type??`image`)),{activeSlideToneStyle:u,activeStageToneStyle:d,updateFromImageElement:f}=Bt({activeItem:o.activeItem,getItemKey:c.getItemKey,isImageReady:o.isImageReady,showDominantImageTone:(0,e.toRef)(r,`showDominantImageTone`)}),p=(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]`),m=(0,e.computed)(()=>!!o.activeMediaItem.value&&!o.activeAssetErrorKind.value),y=(0,e.computed)(()=>s.value<Tn?`vertical`:`horizontal`),b=(0,e.computed)(()=>m.value?`pb-[5.75rem] max-[720px]:pb-[7rem]`:``),x=(0,e.computed)(()=>r.activeIndex>=r.items.length&&(r.loading||r.hasNextPage)),S=(0,e.computed)(()=>r.hasNextPage?`Loading more items`:o.statusMessage.value??`Loading more items`),C=(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}),w=(0,e.computed)(()=>!C.value||!i[`fullscreen-header-actions`]?[]:i[`fullscreen-header-actions`](C.value)),T=(0,e.computed)(()=>!C.value||!i[`fullscreen-aside`]?[]:i[`fullscreen-aside`](C.value)),E=(0,e.computed)(()=>!r.showStatusBadges||!C.value||!o.statusKind.value||!o.statusMessage.value?null:{...C.value,kind:o.statusKind.value,message:o.statusMessage.value}),D=(0,e.computed)(()=>!E.value||!i[`fullscreen-status`]?[]:i[`fullscreen-status`](E.value)),O=(0,e.computed)(()=>({gridTemplateColumns:j.value?`minmax(0, 1fr) 22rem`:`minmax(0, 1fr) 0rem`,transition:`grid-template-columns 320ms cubic-bezier(0.22, 1, 0.36, 1)`})),k=(0,e.computed)(()=>ot(w.value)),A=(0,e.computed)(()=>ot(T.value)),j=(0,e.computed)(()=>A.value&&s.value>=wn),M=(0,e.computed)(()=>A.value&&!j.value),N=(0,e.computed)(()=>ot(D.value)),{emptyStateProps:P,showBadgeEmptyState:F,showCustomEmptyState:I,showInlineEmptyState:L}=lt({emptyStateMode:(0,e.toRef)(r,`emptyStateMode`),itemCount:(0,e.computed)(()=>r.items.length),loading:(0,e.toRef)(r,`loading`),renderSlot:i[`empty-state`],surface:`fullscreen`});(0,e.onMounted)(()=>{window.addEventListener(`resize`,R)}),(0,e.onBeforeUnmount)(()=>{window.removeEventListener(`resize`,R)});function R(){s.value=window.innerWidth||wn}function z(e,t,n){c.settleBackgroundPreload(t),o.onImageLoad(t,n);let r=e.currentTarget;r instanceof HTMLImageElement&&K(t,r)}async function B(e,t){c.settleBackgroundPreload(e),await o.onImageError(e,t)}function V(e,t){c.registerImageElement(e,t),o.registerImageElement(e,t),t instanceof HTMLImageElement&&K(e,t)}function H(e,t){c.registerMediaElement(e,t),o.registerVideoElement(e,t)}function U(e,t){c.registerMediaElement(e,t),o.registerAudioElement(e,t)}async function W(e,t){c.settleBackgroundPreload(e),await o.onMediaError(e,t)}function G(e,t){o.onMediaEvent(e,t);let n=t.currentTarget,r=typeof HTMLMediaElement>`u`?1:HTMLMediaElement.HAVE_METADATA;n instanceof HTMLMediaElement&&n.readyState>=r&&c.settleBackgroundPreload(e)}function K(e,t){f(e,t)}function q(e,t){if(G(t,e),!r.loopFullscreenVideo)return;let n=e.currentTarget;if(!(n instanceof HTMLVideoElement))return;try{n.currentTime=0}catch{}let i=n.play();i&&typeof i.catch==`function`&&i.catch(()=>{})}return(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Wt,[(0,e.createElementVNode)(`div`,{class:(0,e.normalizeClass)([`absolute inset-0 transition-[background] duration-200`,l.value]),style:(0,e.normalizeStyle)((0,e.unref)(d))},null,6),(0,e.createElementVNode)(`div`,{class:`relative z-[1] grid h-full min-h-0`,style:(0,e.normalizeStyle)(O.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).activeItem.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Gt,[((0,e.openBlock)(!0),(0,e.createElementBlock)(e.Fragment,null,(0,e.renderList)((0,e.unref)(o).renderedItems.value,({item:i,index:a})=>((0,e.openBlock)(),(0,e.createElementBlock)(`article`,{key:(0,e.unref)(c).getItemKey(i),"data-testid":`vibe-slide`,"data-item-id":i.id,"data-occurrence-key":(0,e.unref)(c).getItemKey(i),"data-index":a,"data-active":a===(0,e.unref)(o).resolvedActiveIndex.value,"aria-hidden":a===(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`,a===(0,e.unref)(o).resolvedActiveIndex.value?`pointer-events-auto`:`pointer-events-none`]),style:(0,e.normalizeStyle)((0,e.unref)(o).getSlideStyle(a))},[(0,e.createElementVNode)(`div`,{class:(0,e.normalizeClass)([`absolute inset-0 opacity-85`,(0,e.unref)(Lt)(i.type)]),style:(0,e.normalizeStyle)(a===(0,e.unref)(o).resolvedActiveIndex.value&&i.type===`image`?(0,e.unref)(u):void 0)},null,6),(0,e.unref)(o).isVisual(i)?((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`,a===(0,e.unref)(o).resolvedActiveIndex.value?b.value:``])},[(0,e.unref)(c).isAssetLoading(a,i)?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,qt,[(0,e.createElementVNode)(`span`,Jt,[(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),(0,e.unref)(c).isAssetErrored(a,i)?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:1,"data-testid":`vibe-asset-error`,"data-kind":(0,e.unref)(c).getAssetErrorKind(i),class:`grid h-full w-full place-items-center`},[(0,e.createElementVNode)(`div`,Xt,[(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`,Zt,(0,e.toDisplayString)((0,e.unref)(c).getAssetErrorLabel(i)),1),(0,e.unref)(o).canRetryAsset((0,e.unref)(c).getItemKey(i))?((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((0,e.unref)(c).getItemKey(i)),[`stop`])},` Retry `,8,Qt)):(0,e.createCommentVNode)(``,!0)])],8,Yt)):i.type===`image`?((0,e.openBlock)(),(0,e.createElementBlock)(`img`,{key:(0,e.unref)(o).getAssetRenderKey((0,e.unref)(c).getItemKey(i)),src:(0,e.unref)(c).getFullscreenImageSource(a,i),alt:i.title??``,crossorigin:`anonymous`,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((0,e.unref)(c).getItemKey(i))?`opacity-100`:`opacity-0`]),ref_for:!0,ref:t=>V((0,e.unref)(c).getItemKey(i),t),onLoad:t=>z(t,(0,e.unref)(c).getItemKey(i),i.url),onError:t=>B((0,e.unref)(c).getItemKey(i),i.url)},null,42,$t)):((0,e.openBlock)(),(0,e.createElementBlock)(`video`,{key:(0,e.unref)(o).getAssetRenderKey((0,e.unref)(c).getItemKey(i)),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((0,e.unref)(c).getItemKey(i))?`opacity-100`:`opacity-0`]),playsinline:``,loop:r.loopFullscreenVideo,src:(0,e.unref)(c).getFullscreenMediaSource(a,i),preload:(0,e.unref)(c).getFullscreenMediaPreload(a),ref_for:!0,ref:t=>H((0,e.unref)(c).getItemKey(i),t),onClick:(0,e.withModifiers)(t=>(0,e.unref)(o).onVideoClick(t,(0,e.unref)(c).getItemKey(i)),[`stop`]),onCanplay:t=>G((0,e.unref)(c).getItemKey(i),t),onDurationchange:t=>G((0,e.unref)(c).getItemKey(i),t),onEnded:t=>q(t,(0,e.unref)(c).getItemKey(i)),onError:t=>W((0,e.unref)(c).getItemKey(i),i.url),onLoadstart:t=>G((0,e.unref)(c).getItemKey(i),t),onLoadedmetadata:t=>G((0,e.unref)(c).getItemKey(i),t),onPause:t=>G((0,e.unref)(c).getItemKey(i),t),onPlay:t=>G((0,e.unref)(c).getItemKey(i),t),onPlaying:t=>G((0,e.unref)(c).getItemKey(i),t),onSeeking:t=>G((0,e.unref)(c).getItemKey(i),t),onSeeked:t=>G((0,e.unref)(c).getItemKey(i),t),onStalled:t=>G((0,e.unref)(c).getItemKey(i),t),onTimeupdate:t=>G((0,e.unref)(c).getItemKey(i),t),onWaiting:t=>G((0,e.unref)(c).getItemKey(i),t)},null,42,en))],2)):(0,e.unref)(o).isAudio(i)?((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`,a===(0,e.unref)(o).resolvedActiveIndex.value?b.value:``])},[(0,e.createElementVNode)(`div`,tn,[(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[(0,e.unref)(c).getItemKey(i)]?.paused??!0?(0,e.unref)(c).getMediaActionLabel(`Play`,i):(0,e.unref)(c).getMediaActionLabel(`Pause`,i),disabled:!!(0,e.unref)(c).getAssetErrorKind(i),onClick:t=>(0,e.unref)(o).onAudioCoverClick(t,(0,e.unref)(c).getItemKey(i))},[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`,rn,[(0,e.renderSlot)(t.$slots,`item-icon`,{icon:(0,e.unref)(Ue)(i.type),item:i},()=>[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(Ue)(i.type)),{class:`h-6 w-6 stroke-[1.9]`,"aria-hidden":`true`}))])]),(0,e.createElementVNode)(`span`,an,[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(o).mediaStates.value[(0,e.unref)(c).getItemKey(i)]?.paused??!0?(0,e.unref)(_):(0,e.unref)(g)),{class:`h-4 w-4 stroke-2`,"aria-hidden":`true`}))])],8,nn),(0,e.unref)(c).isAssetLoading(a,i)?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,on,[(0,e.createElementVNode)(`span`,sn,[(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),(0,e.unref)(c).getAssetErrorKind(i)?((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":(0,e.unref)(c).getAssetErrorKind(i),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`,ln,(0,e.toDisplayString)((0,e.unref)(c).getAssetErrorLabel(i)),1),(0,e.unref)(o).canRetryAsset((0,e.unref)(c).getItemKey(i))?((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((0,e.unref)(c).getItemKey(i)),[`stop`])},` Retry `,8,un)):(0,e.createCommentVNode)(``,!0)],8,cn)],64)):(0,e.createCommentVNode)(``,!0)]),((0,e.openBlock)(),(0,e.createElementBlock)(`audio`,{key:(0,e.unref)(o).getAssetRenderKey((0,e.unref)(c).getItemKey(i)),src:(0,e.unref)(c).getFullscreenMediaSource(a,i),preload:(0,e.unref)(c).getFullscreenMediaPreload(a),class:`pointer-events-none absolute h-px w-px opacity-0`,ref_for:!0,ref:t=>U((0,e.unref)(c).getItemKey(i),t),onCanplay:t=>G((0,e.unref)(c).getItemKey(i),t),onDurationchange:t=>G((0,e.unref)(c).getItemKey(i),t),onError:t=>W((0,e.unref)(c).getItemKey(i),i.url),onLoadstart:t=>G((0,e.unref)(c).getItemKey(i),t),onLoadedmetadata:t=>G((0,e.unref)(c).getItemKey(i),t),onPause:t=>G((0,e.unref)(c).getItemKey(i),t),onPlay:t=>G((0,e.unref)(c).getItemKey(i),t),onPlaying:t=>G((0,e.unref)(c).getItemKey(i),t),onSeeking:t=>G((0,e.unref)(c).getItemKey(i),t),onSeeked:t=>G((0,e.unref)(c).getItemKey(i),t),onStalled:t=>G((0,e.unref)(c).getItemKey(i),t),onTimeupdate:t=>G((0,e.unref)(c).getItemKey(i),t),onWaiting:t=>G((0,e.unref)(c).getItemKey(i),t)},null,40,dn))],2)):((0,e.openBlock)(),(0,e.createElementBlock)(`div`,fn,[(0,e.createElementVNode)(`div`,pn,[(0,e.renderSlot)(t.$slots,`item-icon`,{icon:(0,e.unref)(Ue)(i.type),item:i},()=>[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(Ue)(i.type)),{class:`h-6 w-6 stroke-[1.9]`,"aria-hidden":`true`}))])])]))],14,Kt))),128)),C.value&&i[`fullscreen-overlay`]?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,mn,[(0,e.createElementVNode)(`div`,hn,[(0,e.renderSlot)(t.$slots,`fullscreen-overlay`,(0,e.normalizeProps)((0,e.guardReactiveProps)(C.value)))])])):(0,e.createCommentVNode)(``,!0),(0,e.unref)(o).activeItem.value?((0,e.openBlock)(),(0,e.createBlock)(Be,{key:1,"current-index":(0,e.unref)(o).resolvedActiveIndex.value,loading:r.loading,"pagination-detail":(0,e.unref)(o).paginationDetail.value,"show-back-to-list":r.showBackToList,"show-end-badge":r.showEndBadge&&(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},[k.value&&C.value?{name:`actions`,fn:(0,e.withCtx)(()=>[(0,e.renderSlot)(t.$slots,`fullscreen-header-actions`,(0,e.normalizeProps)((0,e.guardReactiveProps)(C.value)))]),key:`0`}:void 0]),1032,[`current-index`,`loading`,`pagination-detail`,`show-back-to-list`,`show-end-badge`,`title`,`total`])):(0,e.createCommentVNode)(``,!0),m.value?((0,e.openBlock)(),(0,e.createBlock)(Ae,{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),muted:(0,e.unref)(o).activeMediaState.value.muted,progress:(0,e.unref)(o).activeMediaProgress.value,volume:(0,e.unref)(o).activeMediaState.value.volume,"volume-control-layout":y.value,onSeekInput:(0,e.unref)(o).onMediaSeekInput,onVolumeInput:(0,e.unref)(o).onMediaVolumeInput,onVolumeToggle:(0,e.unref)(o).onMediaVolumeToggle},null,8,[`current-time`,`current-time-label`,`duration`,`duration-label`,`muted`,`progress`,`volume`,`volume-control-layout`,`onSeekInput`,`onVolumeInput`,`onVolumeToggle`])):(0,e.createCommentVNode)(``,!0),E.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:3,class:(0,e.normalizeClass)([`absolute left-1/2 z-[4] -translate-x-1/2`,p.value])},[N.value?(0,e.renderSlot)(t.$slots,`fullscreen-status`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},E.value))):((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:1,"data-testid":`vibe-fullscreen-status-badge`,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`,E.value.kind===`end`?`border-amber-300/35 text-amber-200`:E.value.kind===`failed`?`border-rose-400/45 text-rose-100`:``])},(0,e.toDisplayString)(E.value.message),3))],2)):(0,e.createCommentVNode)(``,!0)])):x.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,gn,[(0,e.createElementVNode)(`div`,_n,[(0,e.createElementVNode)(`span`,vn,[(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.createElementVNode)(`p`,yn,(0,e.toDisplayString)(S.value),1)])])):(0,e.unref)(L)&&(0,e.unref)(P)?((0,e.openBlock)(),(0,e.createBlock)(Ut,{key:2,message:(0,e.unref)(P).message,mode:(0,e.unref)(P).mode,surface:(0,e.unref)(P).surface},{default:(0,e.withCtx)(()=>[(0,e.unref)(I)?(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},(0,e.unref)(P)))):(0,e.createCommentVNode)(``,!0)]),_:3},8,[`message`,`mode`,`surface`])):(0,e.createCommentVNode)(``,!0),(0,e.unref)(F)&&(0,e.unref)(P)?((0,e.openBlock)(),(0,e.createBlock)(Ut,{key:3,message:(0,e.unref)(P).message,mode:(0,e.unref)(P).mode,surface:(0,e.unref)(P).surface},{default:(0,e.withCtx)(()=>[(0,e.unref)(I)?(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},(0,e.unref)(P)))):(0,e.createCommentVNode)(``,!0)]),_:3},8,[`message`,`mode`,`surface`])):(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)(()=>[j.value&&C.value?((0,e.openBlock)(),(0,e.createElementBlock)(`aside`,bn,[(0,e.createElementVNode)(`div`,xn,[(0,e.renderSlot)(t.$slots,`fullscreen-aside`,(0,e.normalizeProps)((0,e.guardReactiveProps)(C.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)(()=>[M.value&&C.value?((0,e.openBlock)(),(0,e.createElementBlock)(`aside`,Sn,[(0,e.createElementVNode)(`div`,Cn,[(0,e.renderSlot)(t.$slots,`fullscreen-aside`,(0,e.normalizeProps)((0,e.guardReactiveProps)(C.value)))])])):(0,e.createCommentVNode)(``,!0)]),_:3})]))}}),Dn=1,On=.5;function kn(e){if(e.type!==`image`&&e.type!==`video`)return{width:Dn,height:Dn,source:`fallback`};let t=e.preview?.width,n=e.preview?.height;if(In(t)&&In(n)){let r=Ln(e,t,n);return{width:r.width,height:r.height,source:`preview`}}if(In(e.width)&&In(e.height)){let t=Ln(e,e.width,e.height);return{width:t.width,height:t.height,source:`original`}}return{width:Dn,height:Dn,source:`fallback`}}function An(e,t){return!e||e<=0||!t||t<=0?1:Math.max(1,Math.floor(e/t))}function jn(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 Mn(e,t){let n=kn(e);return n.height/n.width*t}function Nn(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(P(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=Mn(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 Pn(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 Fn(e,t,n){let r=new Map;for(let i of e){let e=t.get(P(i));if(e==null)continue;let a=n[e];a&&r.set(P(i),a)}return r}function In(e){return typeof e==`number`&&Number.isFinite(e)&&e>0}function Ln(e,t,n){return e.type!==`image`||n/t>=On?{width:t,height:n}:{width:t,height:t}}var Rn=300,zn=600,Bn=40,Vn=300,Hn=400;function Un(e,t){return t===`top`?[...e].reverse():e}function Wn(e){return e<=0?zn:zn+Math.min((e-1)*Bn,Hn)}function Gn(){return Vn}function Kn(e){let t=e.itemHeight>0?e.itemHeight:e.columnWidth;return e.direction===`top`?e.scrollTop-t:e.scrollTop+e.viewportHeight+t}function qn(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 Set),c=(0,e.ref)(new Map),l=(0,e.ref)(new Map),u=(0,e.ref)(new Set),d=new Set,f=new Set,p=(0,e.computed)(()=>Array.from(o.value.values()));(0,e.watch)(t.visibleIndices,e=>{if(!e.length)return;let o=[];for(let r of e){let e=t.items.value[r]?P(t.items.value[r]):null;!e||!n.value.has(e)||d.has(e)||(d.add(e),o.push(e))}if(!o.length)return;let s=Un(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*Bn,Hn));i.value=c,Jn(()=>{let e=new Set(r.value);for(let t of o)e.add(t);r.value=e}),Yn(()=>{let e=new Set(n.value);for(let t of o)e.delete(t);n.value=e,x(()=>{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),d.delete(r);r.value=e,i.value=t,a.value=n},Wn(o.length))})},{flush:`post`}),(0,e.watch)(()=>t.items.value.map(e=>P(e)),e=>{if(!e.length||!o.value.size)return;let t=new Set(e),n=null,r=null;for(let e of o.value.keys())t.has(e)&&(n||=new Map(o.value),r||=new Set(s.value),n.delete(e),r.delete(e));n&&(o.value=n),r&&(s.value=r)}),(0,e.onBeforeUnmount)(()=>{for(let e of f)clearTimeout(e);f.clear()});function m(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=P(n);r.add(e),i.set(e,t)}n.value=r,a.value=i}function h(e){if(!e.length)return;let t=new Map(o.value),c=new Set(n.value),l=new Set(r.value),u=new Map(i.value),f=new Map(a.value),p=[];for(let n of e){let e=P(n.item);p.push(e),t.set(e,n),c.delete(e),l.delete(e),u.delete(e),f.delete(e),d.delete(e)}o.value=t,n.value=c,r.value=l,i.value=u,a.value=f,Jn(()=>{let e=new Set(s.value);for(let t of p)e.add(t);s.value=e}),x(()=>{let e=new Map(o.value),t=new Set(s.value);for(let n of p)e.delete(n),t.delete(n);o.value=e,s.value=t},Vn)}function g(e,n,r=Rn){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;c.value=i,u.value=new Set;let o=new Map(l.value);for(let e of a)o.set(e,r);l.value=o,Jn(()=>{u.value=new Set(a),Jn(()=>{c.value=new Map})}),x(()=>{u.value=new Set;let e=new Map(l.value);for(let t of a)e.delete(t);l.value=e},r)}function _(e){if(r.value.has(e))return`transform ${zn}ms ease-out`;if(u.value.has(e))return`transform ${l.value.get(e)??Rn}ms ease-out`}function v(e){if(!r.value.has(e))return;let t=i.value.get(e)??0;return t>0?`${t}ms`:void 0}function y(e){let r=t.items.value[e],i=t.positions.value[e]??{x:0,y:0},o=t.heights.value[e]??t.columnWidth.value,s=r?P(r):null,l=s?c.value.get(s)??{dx:0,dy:0}:{dx:0,dy:0},u=s?a.value.get(s)??`bottom`:`bottom`,d=s&&n.value.has(s)?Kn({columnWidth:t.columnWidth.value,direction:u,itemHeight:o,scrollTop:t.scrollTop.value,viewportHeight:t.viewportHeight.value}):i.y;return`translate3d(${i.x+l.dx}px, ${d+l.dy}px, 0)`}function b(e){let n=P(e),r=o.value.get(n);if(!r)return{opacity:`0`,transform:`translate3d(0, 0, 0) scale(0.96)`,transition:`opacity ${Vn}ms ease-out, transform ${Vn}ms ease-out`};let i=s.value.has(n);return{height:`${r.height}px`,opacity:i?`0`:`1`,transform:`translate3d(${r.position.x}px, ${r.position.y}px, 0) scale(${i?`0.96`:`1`})`,transition:`opacity ${Vn}ms ease-out, transform ${Vn}ms ease-out`,width:`${t.columnWidth.value}px`}}function x(e,t){let n=setTimeout(()=>{f.delete(n),e()},t);f.add(n)}return{getCardTransform:y,getCardTransition:_,getCardTransitionDelay:v,getLeavingCardStyle:b,leavingItems:p,markEnter:m,markLeave:h,playFlipMoveAnimation:g}}function Jn(e){if(typeof requestAnimationFrame==`function`){requestAnimationFrame(()=>e());return}setTimeout(e,0)}function Yn(e){Jn(()=>Jn(e))}function Xn(e,t){return e?.clientHeight||Math.round(e?.getBoundingClientRect().height??0)||t||window.innerHeight||1}function Zn(e,t,n){return e?.clientWidth||Math.round(e?.getBoundingClientRect().width??0)||t||window.innerWidth||n}function Qn(e,t,n,r){return(e?.scrollHeight??r)-(t+n)}function $n(e,t){return{height:`${e}px`,transform:`translate3d(0, ${t}px, 0)`}}var er=250,tr=1e3;function nr(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+er,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.interactionLocked?.value&&!t.loading.value&&!o.value&&typeof t.requestPage.value==`function`}function _(){return t.hasPage.value&&n.value&&i.value>a.value&&!t.interactionLocked?.value&&!t.loading.value&&!o.value&&typeof t.requestPage.value==`function`}function v(){s.value=!1,y(tr)}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 rr=600,Q=24,$=16,ir=300,ar=200,or=200,sr=Q+$,cr=200,lr=300,ur=24,dr=48,fr=500,pr=1e3;function mr(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||ir),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.ref)(null),p=(0,e.ref)(!1),m=(0,e.computed)(()=>Math.max(ir,a.value-Q*2)),h=(0,e.computed)(()=>An(m.value,ir)),g=(0,e.computed)(()=>jn(m.value,h.value,ir,$)),_=(0,e.computed)(()=>hr(t.activeIndex.value,0,Math.max(0,t.items.value.length-1))),v=(0,e.computed)(()=>Pn({itemCount:t.items.value.length,viewportHeight:i.value,scrollTop:r.value,overscanPx:ar,bucketPx:rr,buckets:c.value})),y=(0,e.computed)(()=>v.value.map(e=>({item:t.items.value[e],index:e}))),b=(0,e.computed)(()=>{let e=l.value+Q*2,t=d.value??0;return Math.max(e,t,i.value)+cr}),x=(0,e.computed)(()=>t.hasNextPage.value||t.allowExhaustedNextPageRefresh.value),S=(0,e.computed)(()=>_r({active:t.active.value,maxScrollTop:ne(),progressDistancePx:r.value,thresholdPx:or,triggerEnabled:x.value})),C=(0,e.computed)(()=>t.items.value.length>0?`${_.value+1} / ${t.items.value.length}`:`0 / 0`),w=(0,e.computed)(()=>gr({active:t.active.value,maxScrollTop:ne(),progressDistancePx:r.value,thresholdPx:sr,triggerEnabled:t.hasPreviousPage.value})),T=(0,e.computed)(()=>Math.max(0,i.value-ur*2)),E=(0,e.computed)(()=>b.value>i.value+1&&T.value>0),D=(0,e.computed)(()=>{if(!E.value)return 0;let e=i.value/b.value*T.value;return Math.min(T.value,Math.max(dr,e))}),O=(0,e.computed)(()=>{if(!E.value)return ur;let e=Math.max(0,b.value-i.value);return ur+Math.max(0,T.value-D.value)*(e>0?hr(r.value/e,0,1):0)}),k=qn({items:t.items,visibleIndices:v,positions:o,heights:s,indexById:u,columnWidth:g,scrollTop:r,viewportHeight:i}),A=nr({direction:`top`,getAnimationLockMs(e){return Math.max(fr,Wn(e))+pr},hasPage:t.hasPreviousPage,interactionLocked:p,isAtBoundary(){return r.value<=sr},loading:t.loading,requestPage:t.requestPreviousPage}),j=nr({direction:`bottom`,getAnimationLockMs(e){return Wn(e)+pr},hasPage:x,interactionLocked:p,isAtBoundary(){return te()<=or},loading:t.loading,requestPage:t.requestNextPage}),M=null,N=0,F=null,I=null,L=!1;(0,e.watch)([()=>t.items.value,h,g],async([n],[i=[]])=>{let a=n.map(e=>P(e)),s=i??[],c=s.map(e=>P(e)),l=Fn(s,u.value,o.value),d=ae(s),f=new Set(c),p=new Set(a),m=n.filter(e=>!f.has(P(e))),h=s.flatMap(e=>{let t=P(e);if(p.has(t))return[];let n=l.get(t),r=d.get(t);return!n||r==null?[]:[{height:r,item:e,position:n}]}),g=a.length>c.length&&c.length>0&&a[0]!==c[0],v=n.length===0&&s.length>0&&h.length>0&&r.value>0,y=h.length>0&&r.value>Q+$,b=g&&r.value>Q+$?n[_.value]:null,x=b?P(b):null;y&&G(Gn()+pr),v&&W(),R(),h.length>0&&k.markLeave(h),m.length>0&&(k.markEnter(m,g?`top`:`bottom`),g?A.onItemsMutated(m.length):j.onItemsMutated(m.length)),k.playFlipMoveAnimation(l,new Set(m.map(e=>P(e))),g?fr:void 0),x?(await(0,e.nextTick)(),U(x,l)):t.active.value&&c.length>0&&q()},{immediate:!0}),(0,e.watch)([()=>t.pendingAppendItems.value.map(e=>P(e)),h,g,i],([e])=>{se(),e.length&&(d.value=ie([...t.items.value,...t.pendingAppendItems.value]),oe())},{immediate:!0}),(0,e.watch)(()=>t.active.value,async(t,a)=>{let o=n.value;if(!o)return;if(!t){f.value=o.scrollTop;return}if(a!==!1||f.value==null)return;await(0,e.nextTick)();let s=Math.max(0,b.value-i.value),c=hr(f.value,0,s);o.scrollTop=c,r.value=c,A.syncBoundary(),j.syncBoundary()}),(0,e.watch)(()=>t.loading.value,async n=>{!n&&!t.pendingAppendItems.value.length&&!F&&!L&&(d.value=null),A.onLoadingChange(n),j.onLoadingChange(n),await(0,e.nextTick)()}),(0,e.onMounted)(async()=>{Y(),await(0,e.nextTick)(),_.value>0?H(_.value,`center`):K(),A.syncBoundary(),j.syncBoundary(),typeof ResizeObserver<`u`?(M=new ResizeObserver(()=>{Y()}),n.value&&M.observe(n.value)):window.addEventListener(`resize`,Y)}),(0,e.onBeforeUnmount)(()=>{M?.disconnect(),M=null,window.removeEventListener(`resize`,Y),se(),ce(),N&&=(cancelAnimationFrame(N),0)});function R(){let e=Nn(t.items.value,{columnCount:h.value,columnWidth:g.value,gapX:$,gapY:$,bucketPx:rr});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 z(){t.active.value&&(r.value=n.value?.scrollTop??0,i.value=X(),A.syncBoundary(),j.syncBoundary(),J(),!q()&&(N||=requestAnimationFrame(()=>{N=0,K()})))}function B(e){t.active.value&&(A.onWheel(e),j.onWheel(e),J())}function V(e){let n=t.items.value[e],r=n?P(n):``;return{height:`${s.value[e]??g.value}px`,width:`${g.value}px`,transition:r?k.getCardTransition(r):void 0,transitionDelay:r?k.getCardTransitionDelay(r):void 0,transform:k.getCardTransform(e)}}function H(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,b.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=hr(u,0,d),r.value=a.scrollTop,K()}function U(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 W(){let e=n.value;if(!e){r.value=0;return}e.scrollTop=0,r.value=0,A.syncBoundary(),j.syncBoundary()}function G(e){ce(),p.value=!0,I=setTimeout(()=>{I=null,p.value=!1},Math.max(0,e))}function K(){if(!v.value.length||q())return;let e=r.value+i.value/2,n=_.value,a=1/0;for(let t of v.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 q(){let e=r.value<=sr,n=te()<=or;return e?(t.setActiveIndex(0),!0):n?(t.setActiveIndex(Math.max(0,t.items.value.length-1)),!0):!1}function J(){A.maybeRequestPage(),j.maybeRequestPage()}function Y(){i.value=X(),a.value=ee()}function X(){return Xn(n.value,i.value)}function ee(){return Zn(n.value,a.value,ir)}function te(){return Qn(n.value,r.value,i.value,b.value)}function ne(){let e=Math.max(n.value?.scrollHeight??0,b.value);return Math.max(0,e-i.value)}function re(){return $n(D.value,O.value)}function ie(e){return e.length?Nn(e,{columnCount:h.value,columnWidth:g.value,gapX:$,gapY:$,bucketPx:rr}).contentHeight+Q*2:0}function ae(e){let t=new Map;for(let n of e){let e=P(n),r=u.value.get(e);if(r==null)continue;let i=s.value[r];i!=null&&t.set(e,i)}return t}function oe(){let n=t.commitPendingAppend.value;typeof n==`function`&&(F=setTimeout(async()=>{F=null,L=!0;try{if(!t.pendingAppendItems.value.length)return;await n(),await(0,e.nextTick)(),await(0,e.nextTick)()}finally{d.value=null,L=!1}},lr))}function se(){F&&=(clearTimeout(F),null)}function ce(){I&&(clearTimeout(I),I=null,p.value=!1)}return{columnWidth:g,containerHeight:b,getCardStyle:V,getLeavingCardStyle:k.getLeavingCardStyle,getScrollbarThumbStyle:re,leavingItems:k.leavingItems,nextBoundaryLoadProgress:S,onScroll:z,onWheel:B,paginationLabel:C,previousBoundaryLoadProgress:w,renderedItems:y,resolvedActiveIndex:_,scrollToIndex:H,showScrollbar:E,scrollViewportRef:n}}function hr(e,t,n){return Math.min(Math.max(e,t),n)}function gr(e){if(!e.active||!e.triggerEnabled)return 0;let t=Math.max(0,e.maxScrollTop-e.thresholdPx);return t<=0?1:hr(1-(e.progressDistancePx-e.thresholdPx)/t,0,1)}function _r(e){if(!e.active||!e.triggerEnabled)return 0;let t=Math.max(0,e.maxScrollTop-e.thresholdPx);return t<=0?1:hr(e.progressDistancePx/t,0,1)}function vr(e){if(e)try{e.removeAttribute(`src`),e.src=``}catch{}}function yr(e){if(e){try{e.currentTime=0}catch{}e.pause();try{e.removeAttribute(`src`),e.load()}catch{}}}function br(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 xr(e){if(!e)return null;try{return new URL(e,window.location.href).href}catch{return e}}var Sr=/\.(avif|gif|jpe?g|png|svg|webp)(\?|#|$)/i,Cr=/\.(m4v|mov|mp4|mpeg|ogg|ogv|webm)(\?|#|$)/i,wr=/^(?:(?:https?:)?\/\/[^/]+)?\/api\/files\/[^/?#]+\/(?:preview|downloaded)(?:\?|#|$)/i;function Tr(e){let t=Er(e),n=t?.url,r=kn(e),i=e.title?.trim()||We(e.type);return t?.mediaType===`video`&&typeof n==`string`?{kind:`video`,url:n,width:r.width,height:r.height,label:i}:t?.mediaType===`image`&&typeof n==`string`?{kind:`image`,url:n,width:r.width,height:r.height,label:i}:e.type!==`image`&&e.type!==`video`?{kind:`fallback`,url:null,width:r.width,height:r.height,label:i}:typeof n==`string`&&Or(e,n)?{kind:`video`,url:n,width:r.width,height:r.height,label:i}:typeof n==`string`&&Dr(e,n)?{kind:`image`,url:n,width:r.width,height:r.height,label:i}:{kind:`fallback`,url:null,width:r.width,height:r.height,label:i}}function Er(e){return e.preview?.url?e.preview:typeof e.url!=`string`||e.url.trim()===``?null:{url:e.url}}function Dr(e,t){return e.type!==`image`||typeof t!=`string`?!1:Sr.test(t)||kr(t)}function Or(e,t){return e.type!==`video`||typeof t!=`string`?!1:Cr.test(t)||Ar(t)}function kr(e){return/^(https?:\/\/|\/\/|\/(?!\/)|\.{1,2}\/|blob:|data:)/i.test(e)}function Ar(e){return wr.test(e)||/^blob:/i.test(e)||/^data:video\//i.test(e)}function jr(t){let n=(0,e.ref)(null),r=(0,e.computed)(()=>{let e=typeof t.item.value.healthCheck?.url==`string`?xr(t.item.value.healthCheck.url):null;return!e||e===t.attachedAssetUrl.value?null:e}),i=null,a=0,o=new Map;(0,e.watch)(r,(e,t)=>{e!==t&&(n.value=null,l(),a+=1)}),(0,e.watch)([r,t.surfaceActive,t.isInView,t.isReady,t.loadErrorKind],()=>{s()});function s(){let e=r.value;if(!e){l();return}if(!t.surfaceActive.value||!t.isInView.value||!t.isReady.value||t.loadErrorKind.value){l();return}if(o.has(e)){n.value=o.get(e)??null;return}if(i){i.refresh();return}i=qe.request({assetType:`probe`,getPriority:t.getPriority,onGrant(){let e=r.value;if(!e){l();return}let i=++a;Ct(e).then(s=>{if(!(i!==a||r.value!==e)){if(o.set(e,s??null),!s){n.value=null;return}n.value=s,t.reportAssetError?.({item:t.item.value,occurrenceKey:P(t.item.value),url:e,kind:s,surface:`grid`})}}).finally(()=>{i===a&&l()})},url:e})}function c(){let e=r.value;return!n.value||!e?!1:(o.delete(e),n.value=null,l(),s(),!0)}function l(){i?.release(),i=null}return{errorKind:n,release:l,retry:c}}var Mr=[`aria-label`],Nr={key:0,"data-testid":`vibe-list-card-spinner`,class:`pointer-events-none absolute inset-0 z-[4] grid place-items-center bg-black/18`},Pr={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]`},Fr=[`src`,`alt`],Ir=[`src`],Lr=[`data-kind`],Rr={class:`grid justify-items-center gap-3 px-4 text-center`},zr={class:`text-[0.68rem] font-bold uppercase tracking-[0.22em] text-[#f7f1ea]/72`},Br={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))]`},Vr={class:`inline-flex h-14 w-14 items-center justify-center border border-white/16 bg-black/20`},Hr={class:`pointer-events-none absolute inset-0 z-[3]`},Ur=(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)(()=>Tr(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)(!1),d=(0,e.ref)(null),f=(0,e.ref)(null),p=(0,e.ref)(null),m=(0,e.ref)(null),g=(0,e.ref)(null),_=(0,e.ref)(a.value.kind===`fallback`),y=(0,e.computed)(()=>_.value?r.surfaceActive?o.value?a.value.url:null:a.value.url:null),b=(0,e.computed)(()=>r.surfaceActive&&o.value&&(a.value.kind===`image`||a.value.kind===`video`)&&!!a.value.url),x=(0,e.computed)(()=>a.value.kind===`image`&&!!y.value),S=(0,e.computed)(()=>a.value.kind===`video`&&!!y.value),C=jr({attachedAssetUrl:y,getPriority:G,isInView:o,isReady:l,item:(0,e.computed)(()=>r.item),loadErrorKind:d,reportAssetError:r.reportAssetError,surfaceActive:(0,e.computed)(()=>r.surfaceActive)}),w=(0,e.computed)(()=>C.errorKind.value??d.value),T=(0,e.computed)(()=>!!w.value),E=(0,e.computed)(()=>xt(w.value)),D=(0,e.computed)(()=>b.value&&!d.value&&(!_.value||!l.value)),O=null,k=null,A=new Set;(0,e.watch)([y,()=>a.value.kind],()=>{let e=a.value.kind===`fallback`;l.value=e,u.value=!1,d.value=null,e&&(_.value=!0)}),(0,e.watch)(b,()=>{I()}),(0,e.watch)([o,l,y],()=>{L()}),(0,e.watch)(()=>r.surfaceActive,e=>{if(!e){z(),L();return}requestAnimationFrame(()=>{B(),I(),L()})}),(0,e.onMounted)(()=>{if(!p.value||typeof IntersectionObserver>`u`){m.value=null,o.value=!0,I();return}m.value=p.value.closest(`[data-testid="vibe-list-scroll"]`),O=new IntersectionObserver(e=>{for(let t of e)t.target===p.value&&(r.surfaceActive&&B(t),I(),L())},{root:m.value,threshold:[0,1]}),O.observe(p.value)}),(0,e.onBeforeUnmount)(()=>{R(),C.release(),O?.disconnect(),O=null});function j(){K(f.value)&&(l.value=!0,d.value=null,V(y.value??r.item.url),z())}async function M(){if(!K(f.value))return;let e=y.value??r.item.url;l.value=!1,d.value=`generic`;let t=await St(e);d.value=t,r.reportAssetError?.({item:r.item,occurrenceKey:P(r.item),url:e,kind:t,surface:`grid`}),z()}function N(){K(g.value)&&(u.value=!0,l.value=!0,d.value=null,V(y.value??r.item.url),z(),L())}function F(){K(g.value)&&(u.value||(l.value=!1))}function I(){if(a.value.kind===`fallback`){R(!1);return}if(!r.surfaceActive){z();return}if(!b.value){R();return}if(_.value||k){k?.refresh();return}k=qe.request({assetType:a.value.kind,getPriority:G,onGrant(){_.value=!0,l.value=!1,d.value=null},url:a.value.url??r.item.url})}function L(){let e=g.value;if(!(!e||a.value.kind!==`video`)){if(w.value){e.pause();return}if(y.value&&o.value&&l.value){e.muted=!0,e.loop=!0,e.playsInline=!0,Et(e);return}try{e.currentTime=0}catch{}e.pause()}}function R(e=!0){_.value=a.value.kind===`fallback`,d.value=null,l.value=a.value.kind===`fallback`,e&&(U(),W()),z()}function z(){k?.release(),k=null}function B(e){let t=p.value;if(!t){o.value=!0;return}o.value=br(e?.boundingClientRect??t.getBoundingClientRect(),e?.rootBounds??m.value?.getBoundingClientRect()??null)}function V(e){if(!e)return;let t=P(r.item),n=`${t}|${e}`;A.has(n)||(A.add(n),r.reportAssetLoad?.({item:r.item,occurrenceKey:t,surface:`grid`,url:e}))}function H(){if(!E.value||C.retry())return;let e=P(r.item);A.forEach(t=>{t.startsWith(`${e}|`)&&A.delete(t)}),d.value=null,l.value=!1,_.value=!1,z(),I()}function U(){vr(f.value)}function W(){yr(g.value)}function G(){let e=p.value;if(!e)return 1/0;let t=e.getBoundingClientRect();if(m.value){let e=m.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 K(e){let t=xr(y.value);return!e||!t?!1:xr(`currentSrc`in e&&e.currentSrc||e.getAttribute(`src`))===t}function q(){i(`open`)}function J(){s.value=!0}function Y(e){let t=e.relatedTarget;p.value&&t instanceof Node&&p.value.contains(t)||(s.value=!1)}return(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{ref_key:`rootRef`,ref:p,"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:J,onFocusout:Y,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:q},null,8,Mr),D.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Nr,[(0,e.createElementVNode)(`span`,Pr,[(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),x.value&&y.value&&!T.value?((0,e.openBlock)(),(0,e.createElementBlock)(`img`,{key:1,ref_key:`imageRef`,ref:f,src:y.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:j,onError:M},null,42,Fr)):S.value&&y.value&&!T.value?((0,e.openBlock)(),(0,e.createElementBlock)(`video`,{key:2,ref_key:`videoRef`,ref:g,src:y.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:N,onError:M,onLoadstart:F,onPlaying:N,onStalled:F,onWaiting:F},null,42,Ir)):T.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:3,"data-testid":`vibe-list-card-error`,"data-kind":w.value,class:`pointer-events-none 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`,Rr,[(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`,zr,(0,e.toDisplayString)((0,e.unref)(bt)(w.value)),1),E.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)(H,[`stop`])},` Retry `)):(0,e.createCommentVNode)(``,!0)])],8,Lr)):((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Br,[(0,e.createElementVNode)(`div`,Vr,[(0,e.renderSlot)(t.$slots,`item-icon`,{icon:(0,e.unref)(Ue)(r.item.type),item:r.item},()=>[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(Ue)(r.item.type)),{class:`h-6 w-6 stroke-[1.8] text-[#f7f1ea]/78`,"aria-hidden":`true`}))])])])),(0,e.createElementVNode)(`div`,Hr,[(0,e.renderSlot)(t.$slots,`grid-item-overlay`,{active:r.active,focused:s.value,hovered:c.value,index:r.index,item:r.item,openFullscreen:q})])],34))}}),Wr={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)]`},Gr={class:`pointer-events-none absolute inset-x-0 top-0 z-[2] flex justify-end p-6`},Kr={"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]`},qr={class:`whitespace-nowrap`},Jr={key:0,class:`whitespace-nowrap border-l border-white/12 pl-2 text-[#f7f1ea]/56 min-[721px]:pl-3`},Yr=[`data-active`,`data-index`,`data-item-id`,`data-occurrence-key`],Xr=[`data-item-id`],Zr={key:0,class:`pointer-events-none absolute inset-y-0 right-0 z-[3] hidden w-8 min-[1024px]:block`},Qr={key:1,class:`pointer-events-none absolute inset-x-0 bottom-0 z-[2] px-5 pb-5 sm:px-6`},$r={class:`mx-auto flex w-full justify-center`},ei=(0,e.defineComponent)({__name:`ListSurface`,props:{active:{type:Boolean,default:!0},activeIndex:{default:0},allowExhaustedNextPageRefresh:{type:Boolean,default:!1},commitPendingAppend:{type:[Function,null],default:null},emptyStateMode:{default:`inline`},errorMessage:{default:null},hasNextPage:{type:Boolean,default:!1},hasPreviousPage:{type:Boolean,default:!1},items:{},loading:{type:Boolean,default:!1},pendingAppendItems:{default:()=>[]},paginationDetail:{default:null},phase:{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},showStatusBadges:{type:Boolean,default:!0}},emits:[`boundary-load-progress`,`open-fullscreen`,`update:activeIndex`],setup(t,{emit:n}){let r=t,i=(0,e.useSlots)(),a=n,o=mr({active:(0,e.toRef)(r,`active`),allowExhaustedNextPageRefresh:(0,e.toRef)(r,`allowExhaustedNextPageRefresh`),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`),setActiveIndex(e){a(`update:activeIndex`,e)}}),s=(0,e.computed)(()=>dt({itemCount:r.items.length,loading:r.loading,phase:r.phase})),c=(0,e.computed)(()=>ft({errorMessage:r.errorMessage,hasItems:r.items.length>0,hasNextPage:r.hasNextPage,phase:s.value,surface:`grid`})),l=(0,e.computed)(()=>!r.showStatusBadges||!c.value?null:{activeIndex:o.resolvedActiveIndex.value,kind:c.value.kind,loading:r.loading,message:c.value.message,paginationDetail:r.paginationDetail,total:r.items.length}),u=(0,e.computed)(()=>!l.value||!i[`grid-status`]?[]:i[`grid-status`](l.value)),d=(0,e.computed)(()=>ot(u.value)),f=(0,e.computed)(()=>r.items.length+o.leavingItems.value.length),{emptyStateProps:p,showBadgeEmptyState:m,showCustomEmptyState:h,showInlineEmptyState:g}=lt({emptyStateMode:(0,e.toRef)(r,`emptyStateMode`),itemCount:f,loading:(0,e.toRef)(r,`loading`),renderSlot:i[`empty-state`],surface:`grid`});return(0,e.watch)([o.nextBoundaryLoadProgress,o.previousBoundaryLoadProgress],([e,t])=>{a(`boundary-load-progress`,{nextBoundaryLoadProgress:e,previousBoundaryLoadProgress:t})},{immediate:!0}),(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Wr,[(0,e.createElementVNode)(`div`,Gr,[(0,e.createElementVNode)(`span`,Kr,[(0,e.createElementVNode)(`span`,qr,(0,e.toDisplayString)((0,e.unref)(o).paginationLabel.value),1),r.paginationDetail?((0,e.openBlock)(),(0,e.createElementBlock)(`span`,Jr,(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)(P)(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)(P)(n),class:`absolute will-change-transform`,style:(0,e.normalizeStyle)((0,e.unref)(o).getCardStyle(s))},[(0,e.createVNode)(Ur,{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,Yr))),128)),((0,e.openBlock)(!0),(0,e.createElementBlock)(e.Fragment,null,(0,e.renderList)((0,e.unref)(o).leavingItems.value,n=>((0,e.openBlock)(),(0,e.createElementBlock)(`article`,{key:`leaving-${(0,e.unref)(P)(n.item)}`,"data-testid":`vibe-list-card-leaving`,"data-item-id":n.item.id,class:`pointer-events-none absolute z-[2] will-change-[opacity,transform]`,style:(0,e.normalizeStyle)((0,e.unref)(o).getLeavingCardStyle(n.item))},[(0,e.createVNode)(Ur,{active:!1,index:-1,item:n.item,"report-asset-error":r.reportAssetError,"report-asset-load":r.reportAssetLoad,"surface-active":!1},(0,e.createSlots)({_:2},[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:`0`}:void 0]),1032,[`item`,`report-asset-error`,`report-asset-load`])],12,Xr))),128)),(0,e.unref)(g)&&(0,e.unref)(p)?((0,e.openBlock)(),(0,e.createBlock)(Ut,{key:0,message:(0,e.unref)(p).message,mode:(0,e.unref)(p).mode,surface:(0,e.unref)(p).surface},{default:(0,e.withCtx)(()=>[(0,e.unref)(h)?(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},(0,e.unref)(p)))):(0,e.createCommentVNode)(``,!0)]),_:3},8,[`message`,`mode`,`surface`])):(0,e.createCommentVNode)(``,!0)],4)],544),(0,e.unref)(o).showScrollbar.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Zr,[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`,Qr,[(0,e.createElementVNode)(`div`,$r,[(0,e.renderSlot)(t.$slots,`grid-footer`)])])):(0,e.createCommentVNode)(``,!0),l.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`])},[d.value?(0,e.renderSlot)(t.$slots,`grid-status`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},l.value))):((0,e.openBlock)(),(0,e.createElementBlock)(`span`,{key:1,"data-testid":`vibe-grid-status-badge`,class:(0,e.normalizeClass)([`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]`,l.value.kind===`end`?`border-amber-300/35 text-amber-200`:l.value.kind===`failed`?`border-rose-400/45 text-rose-100`:``])},(0,e.toDisplayString)(l.value.message),3))],2)):(0,e.createCommentVNode)(``,!0),(0,e.unref)(m)&&(0,e.unref)(p)?((0,e.openBlock)(),(0,e.createBlock)(Ut,{key:3,class:(0,e.normalizeClass)([`z-[3]`,i[`grid-footer`]?`pb-24`:`pb-6`]),message:(0,e.unref)(p).message,mode:(0,e.unref)(p).mode,surface:(0,e.unref)(p).surface},{default:(0,e.withCtx)(()=>[(0,e.unref)(h)?(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},(0,e.unref)(p)))):(0,e.createCommentVNode)(``,!0)]),_:3},8,[`class`,`message`,`mode`,`surface`])):(0,e.createCommentVNode)(``,!0)]))}}),ti=[`data-surface-mode`],ni={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`},ri=[`data-visible`,`inert`],ii=[`data-visible`,`inert`],ai={key:3,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`},oi=(0,e.defineComponent)({name:`VibeLayout`,__name:`Layout`,props:{emptyStateMode:{},fillDelayMs:{},fillDelayStepMs:{},initialCursor:{},initialState:{},loopFullscreenVideo:{type:Boolean},pageSize:{},paginationDetail:{},resolve:{type:Function},showDominantImageTone:{type:Boolean},showEndBadge:{type:Boolean},showStatusBadges:{type:Boolean},surfaceMode:{}},emits:[`asset-errors`,`asset-loads`,`update:activeIndex`,`update:surfaceMode`],setup(t,{expose:n,emit:r}){let i=t,a=(0,e.useSlots)(),o=r,s=me(i,o),c=S(e=>{o(`asset-errors`,e)}),l=C(e=>{o(`asset-loads`,e)});return(0,e.onBeforeUnmount)(()=>{c.stop(),l.stop()}),n({cancel:s.cancel,clearRemoved:s.clearRemoved,getRemovedIds:s.getRemovedIds,lockPageLoading:s.lockPageLoading,loadNext:s.loadNext,loadPrevious:s.loadPrevious,remove:s.remove,restore:s.restore,retry:s.retry,status:s.status,undo:s.undo,unlockPageLoading:s.unlockPageLoading}),(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`,ni,(0,e.toDisplayString)((0,e.unref)(s).errorMessage.value),1)):(0,e.createCommentVNode)(``,!0),(0,e.unref)(s).isDesktop.value?((0,e.openBlock)(),(0,e.createElementBlock)(e.Fragment,{key:2},[(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)(ei,{active:(0,e.unref)(s).surfaceMode.value===`list`,"allow-exhausted-next-page-refresh":(0,e.unref)(s).canRefreshExhaustedNextPage.value,items:(0,e.unref)(s).items.value,"active-index":(0,e.unref)(s).activeIndex.value,"error-message":(0,e.unref)(s).errorMessage.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,phase:(0,e.unref)(s).phase.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,"empty-state-mode":i.emptyStateMode,"show-status-badges":i.showStatusBadges??!0,onBoundaryLoadProgress:(0,e.unref)(s).setBoundaryLoadProgress,onOpenFullscreen:(0,e.unref)(s).openFullscreen,"onUpdate:activeIndex":(0,e.unref)(s).setActiveIndex},(0,e.createSlots)({_:2},[a[`empty-state`]?{name:`empty-state`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`0`}:void 0,a[`grid-footer`]?{name:`grid-footer`,fn:(0,e.withCtx)(()=>[(0,e.renderSlot)(t.$slots,`grid-footer`)]),key:`1`}: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:`2`}: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:`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,[`active`,`allow-exhausted-next-page-refresh`,`items`,`active-index`,`error-message`,`loading`,`has-next-page`,`has-previous-page`,`pending-append-items`,`phase`,`commit-pending-append`,`pagination-detail`,`report-asset-error`,`report-asset-load`,`request-next-page`,`request-previous-page`,`empty-state-mode`,`show-status-badges`,`onBoundaryLoadProgress`,`onOpenFullscreen`,`onUpdate:activeIndex`])],8,ri),[[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)(En,{items:(0,e.unref)(s).items.value,active:(0,e.unref)(s).surfaceMode.value===`fullscreen`,"active-index":(0,e.unref)(s).activeIndex.value,"error-message":(0,e.unref)(s).errorMessage.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,phase:(0,e.unref)(s).phase.value,"report-asset-error":(0,e.unref)(c).report,"report-asset-load":(0,e.unref)(l).report,"empty-state-mode":i.emptyStateMode,"loop-fullscreen-video":i.loopFullscreenVideo??!0,"show-dominant-image-tone":i.showDominantImageTone??!0,"show-end-badge":i.showEndBadge??!0,"show-status-badges":i.showStatusBadges??!0,"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[`empty-state`]?{name:`empty-state`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`0`}:void 0,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:`1`}: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:`2`}: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:`3`}: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:`4`}: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:`5`}:void 0]),1032,[`items`,`active`,`active-index`,`error-message`,`loading`,`has-next-page`,`pagination-detail`,`phase`,`report-asset-error`,`report-asset-load`,`empty-state-mode`,`loop-fullscreen-video`,`show-dominant-image-tone`,`show-end-badge`,`show-status-badges`,`show-back-to-list`,`onBackToList`,`onUpdate:activeIndex`])],8,ii),[[e.vShow,(0,e.unref)(s).surfaceMode.value===`fullscreen`]])]),_:3})],64)):(0,e.unref)(s).items.value.length===0&&(0,e.unref)(s).loading.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,ai,[(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)])):((0,e.openBlock)(),(0,e.createBlock)(En,{key:4,items:(0,e.unref)(s).items.value,active:!0,"active-index":(0,e.unref)(s).activeIndex.value,"error-message":(0,e.unref)(s).errorMessage.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,phase:(0,e.unref)(s).phase.value,"report-asset-error":(0,e.unref)(c).report,"report-asset-load":(0,e.unref)(l).report,"empty-state-mode":i.emptyStateMode,"loop-fullscreen-video":i.loopFullscreenVideo??!0,"show-dominant-image-tone":i.showDominantImageTone??!0,"show-end-badge":i.showEndBadge??!0,"show-status-badges":i.showStatusBadges??!0,"show-back-to-list":!1,onBackToList:(0,e.unref)(s).returnToList,"onUpdate:activeIndex":(0,e.unref)(s).setActiveIndex},(0,e.createSlots)({_:2},[a[`empty-state`]?{name:`empty-state`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`0`}:void 0,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:`1`}: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:`2`}: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:`3`}: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:`4`}: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:`5`}:void 0]),1032,[`items`,`active-index`,`error-message`,`loading`,`has-next-page`,`pagination-detail`,`phase`,`report-asset-error`,`report-asset-load`,`empty-state-mode`,`loop-fullscreen-video`,`show-dominant-image-tone`,`show-end-badge`,`show-status-badges`,`onBackToList`,`onUpdate:activeIndex`]))],8,ti))}}),si={install(e){e.component(`VibeLayout`,oi)}};exports.VibeLayout=oi,exports.VibePlugin=si,exports.default=si;
|
|
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`}]]),y=l(`volume-1`,[[`path`,{d:`M11 4.702a.705.705 0 0 0-1.203-.498L6.413 7.587A1.4 1.4 0 0 1 5.416 8H3a1 1 0 0 0-1 1v6a1 1 0 0 0 1 1h2.416a1.4 1.4 0 0 1 .997.413l3.383 3.384A.705.705 0 0 0 11 19.298z`,key:`uqj9uw`}],[`path`,{d:`M16 9a5 5 0 0 1 0 6`,key:`1q6k2b`}]]),b=l(`volume-2`,[[`path`,{d:`M11 4.702a.705.705 0 0 0-1.203-.498L6.413 7.587A1.4 1.4 0 0 1 5.416 8H3a1 1 0 0 0-1 1v6a1 1 0 0 0 1 1h2.416a1.4 1.4 0 0 1 .997.413l3.383 3.384A.705.705 0 0 0 11 19.298z`,key:`uqj9uw`}],[`path`,{d:`M16 9a5 5 0 0 1 0 6`,key:`1q6k2b`}],[`path`,{d:`M19.364 18.364a9 9 0 0 0 0-12.728`,key:`ijwkga`}]]),x=l(`volume-x`,[[`path`,{d:`M11 4.702a.705.705 0 0 0-1.203-.498L6.413 7.587A1.4 1.4 0 0 1 5.416 8H3a1 1 0 0 0-1 1v6a1 1 0 0 0 1 1h2.416a1.4 1.4 0 0 1 .997.413l3.383 3.384A.705.705 0 0 0 11 19.298z`,key:`uqj9uw`}],[`line`,{x1:`22`,x2:`16`,y1:`9`,y2:`15`,key:`1ewh16`}],[`line`,{x1:`16`,x2:`22`,y1:`9`,y2:`15`,key:`5ykzw1`}]]);function S(e,t=150){return w(e,e=>`${e.surface}|${e.occurrenceKey}|${e.url}|${e.kind}`,t)}function C(e,t=150){return w(e,e=>`${e.surface}|${e.occurrenceKey}|${e.url}`,t)}function w(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 T(e){return e instanceof HTMLElement&&[`INPUT`,`TEXTAREA`,`SELECT`].includes(e.tagName)}function E(e){return e instanceof HTMLElement&&!!e.closest(`[data-swipe-lock], input, textarea, select, a`)}function D(e){return e===`filling`||e===`initializing`||e===`loading`||e===`refreshing`}function O(e){return!e||!Number.isFinite(e)||e<1?25:Math.floor(e)}function k(e){return e??`__vibe_initial_cursor__`}function A(e,t,n){return Math.min(Math.max(e,t),n)}function j(){let t=(0,e.ref)(new Set),n=(0,e.ref)([]);function r(e){let r=M(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=M(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 M(e){let t=Array.isArray(e)?e:[e];return Array.from(new Set(t.filter(e=>typeof e==`string`&&e.length>0)))}var N=`__vibeOccurrenceKey`;function P(e){let t=e[N];return typeof t==`string`&&t.length>0?t:e.id}function F(e,t,n){let r=new Map,i=[],a=n;for(let e of t){let t=r.get(e.id),n=P(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(I(t,e))}return{items:i,nextSequence:a}}function I(e,t){return P(e)===t?e:{...e,[N]:t}}function L(e){return e.flatMap(e=>e.items)}function R(e,t){return t.size?e.filter(e=>!t.has(e.id)):e}function z(e,t){return R(e.items,t)}function B(e,t){return z(e,t).length}function V(e,t,n){if(n<0)return null;let r=0;for(let i of e){let e=z(i,t),a=r+e.length;if(n<a)return i.cursor;r=a}return null}function H(e,t,n){let r=[...e],i=r.findIndex(e=>e.cursor===t);return i>=0&&r.splice(i,1,n),r}function U(e,t,n){let r=F(e,t,n);return{items:r.items,nextSequence:r.nextSequence}}function W(e,t,n,r){let i=new Map,a=e.map(e=>({item:e,matchIndex:null,occurrenceKey:null})),o=new Map,s=new Map,c=n;for(let[e,n]of t.entries()){let t=i.get(n.id),r={index:e,occurrenceKey:P(n)};t?t.push(r):i.set(n.id,[r])}for(let e of a){let t=i.get(e.item.id)?.shift();t&&(e.matchIndex=t.index,e.occurrenceKey=t.occurrenceKey)}let l=[],u=null;for(let e of a)l.push(u),e.matchIndex!==null&&(u=e.matchIndex);let d=Array(a.length).fill(null),f=null;for(let e=a.length-1;e>=0;--e)d[e]=f,a[e].matchIndex!==null&&(f=a[e].matchIndex);for(let[e,n]of a.entries()){if(n.matchIndex!==null&&n.occurrenceKey){o.set(n.matchIndex,G(n.item,n.occurrenceKey));continue}let i=d[e]??(l[e]===null?null:l[e]+1)??(r===`leading`?0:t.length),a=G(n.item,`vibe-occurrence-${c+=1}`),u=s.get(i);u?u.push(a):s.set(i,[a])}let p=[];for(let e=0;e<=t.length;e+=1){let n=s.get(e);n?.length&&p.push(...n),!(e>=t.length)&&p.push(o.get(e)??t[e])}return{items:p,nextSequence:c}}function G(e,t){return P(e)===t?e:{...e,__vibeOccurrenceKey:t}}function K(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 q(e){let t=U(e.nextItems,e.previousItems,e.sequence);return{bucket:{cursor:e.cursor,items:t.items,nextCursor:e.nextCursor,previousCursor:e.previousCursor},nextSequence:t.nextSequence}}function J(e){let t=W(e.nextItems,e.previousItems,e.sequence,e.edge);return{bucket:{cursor:e.cursor,items:t.items,nextCursor:e.nextCursor,previousCursor:e.previousCursor},nextSequence:t.nextSequence}}function Y(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+B(t,n),0)}}function X(e){let t=q({cursor:e.initialState.cursor,nextCursor:e.initialState.nextCursor??null,nextItems:e.initialState.items,previousCursor:e.initialState.previousCursor??null,previousItems:[],sequence:e.sequence}),n=R(t.bucket.items,e.removedIds);return{activeIndex:A(e.initialState.activeIndex??0,0,Math.max(0,n.length-1)),buckets:[t.bucket],nextSequence:t.nextSequence}}function ee(e,t){let n=e[A(t,0,Math.max(0,e.length-1))];return n?P(n):null}function te(e,t,n=null){if(!e.length)return 0;let r=n?e.findIndex(e=>P(e)===n):-1;return r>=0?r:A(t,0,e.length-1)}function ne(e,t,n){return e?B(e,t)<n:!1}var re=2e3,ie=1e3,ae=100;function oe(e,t=re,n=ie){return t+Math.max(0,e-1)*n}function se(e,t){return!Number.isFinite(e)||e==null||e<0?t:Math.floor(e)}function ce(){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,ae),r=setTimeout(l,e),u()}))}return{clear:a,remainingMs:t,wait:o}}function le(t){let n=!!t.initialState?.items.length,r=(0,e.ref)([]),i=(0,e.ref)(0),a=(0,e.ref)([]),o=(0,e.ref)(!1),s=(0,e.ref)(null),c=(0,e.ref)(!n&&typeof t.resolve==`function`?`initializing`:`idle`),l=(0,e.ref)(null),u=(0,e.ref)(null),d=ce(),f=d.remainingMs,p=(0,e.ref)(null),m=(0,e.ref)(!1),h=(0,e.ref)(!0),g=(0,e.ref)(!1),_=new Set,v=null,y=null,b=0,x=0,S=(0,e.computed)(()=>se(t.fillDelayMs,re)),C=(0,e.computed)(()=>se(t.fillDelayStepMs,ie)),w=(0,e.computed)(()=>typeof t.resolve==`function`),T=(0,e.computed)(()=>O(t.pageSize)),E=(0,e.computed)(()=>L(r.value)),j=(0,e.computed)(()=>R(E.value,t.removedIds.value)),M=(0,e.computed)(()=>i.value),N=(0,e.computed)(()=>D(c.value)||m.value),F=(0,e.computed)(()=>ue(r.value,t.removedIds.value)),I=(0,e.computed)(()=>de(r.value,t.removedIds.value)),z=(0,e.computed)(()=>I.value?.nextCursor??null),U=(0,e.computed)(()=>o.value?null:F.value?.previousCursor??null),W=(0,e.computed)(()=>!!z.value),G=(0,e.computed)(()=>!!U.value),ae=(0,e.computed)(()=>w.value&&r.value.length>0),le=(0,e.computed)(()=>R(L(a.value),t.removedIds.value)),fe=(0,e.computed)(()=>V(r.value,t.removedIds.value,M.value)),pe=(0,e.computed)(()=>!j.value.length&&!N.value&&!!s.value);(0,e.watch)(()=>j.value.length,e=>{if(e===0){i.value=0;return}o.value&&=(Le(),!1),i.value>e-1&&(i.value=e-1)}),(0,e.watch)(()=>i.value,()=>{h.value&&Oe()}),(0,e.onMounted)(()=>{Pe()||t.resolve&&me()}),(0,e.onBeforeUnmount)(()=>{v?.abort(),v=null,d.clear(!0)});async function me(){y=me;let e=await Me({continueUntilFilled:!0,cursor:t.initialCursor??null,direction:`forward`,phase:`initializing`});e&&(r.value=e.buckets,i.value=0,Z())}async function he(){if(!(g.value||N.value)){if(Ie(`trailing`)||!W.value){if(!ae.value)return;let e=await je(`trailing`);e?.followCursor&&Ie(`trailing`)&&await ke(e.followCursor);return}await ke(z.value)}}async function ge(){if(!(g.value||!G.value||N.value)){if(Ie(`leading`)){let e=await je(`leading`);e?.itemsLoaded===0&&e.followCursor&&await Ae(e.followCursor);return}await Ae(U.value)}}async function _e(){if(pe.value){if(r.value=[],i.value=0,a.value=[],o.value=!1,s.value=null,c.value=w.value?`initializing`:`idle`,l.value=null,u.value=null,p.value=null,m.value=!1,_.clear(),v?.abort(),v=null,d.clear(!0),Pe()){Z();return}await me()}}async function ve(){if(pe.value)return _e();g.value||c.value!==`failed`||!y||(s.value=null,await y())}async function ye(){if(!a.value.length)return m.value=!1,Z();r.value=[...r.value,...a.value],a.value=[],m.value=!1,Z()}function be(e){let n=j.value;if(!n.length)return;let r=A(e,0,n.length-1);r!==i.value&&(i.value=r,t.emit(`update:activeIndex`,r))}function xe(e){h.value=e}function Se(){g.value=!0,d.clear(!0)}function Ce(){g.value=!1}function we(){b+=1,v?.abort(),v=null,d.clear(!0),_.clear(),s.value=null,l.value=null,u.value=null,p.value=null,a.value.length>0&&(r.value=[...r.value,...a.value],a.value=[]),m.value=!1,o.value=!1,Z()}function Te(){return ee(j.value,M.value)}function Ee(e=null,t={}){if(j.value.length===0){i.value=0,!t.preserveTrailingPlaceholder&&r.value.length>0&&(o.value=!0);return}if(e){let t=j.value.findIndex(t=>P(t)===e);if(t>=0){i.value=t;return}}if(t.preserveTrailingPlaceholder&&i.value>=j.value.length){i.value=j.value.length;return}i.value=te(j.value,M.value,e)}function De(){a.value.length>0&&!le.value.length&&ye()}async function Oe(){if(!(!h.value||Fe())){if(!j.value.length){W.value&&await he();return}G.value&&i.value<3&&await ge(),W.value&&i.value>=j.value.length-3&&await he()}}async function ke(e){y=async()=>{await ke(e)};let t=await Me({continueUntilFilled:!0,cursor:e,direction:`forward`,phase:`loading`});if(t){if(t.canceled)return r.value=[...r.value,...t.buckets],a.value=[],m.value=!1,Z();if(a.value=t.buckets,!le.value.length)return r.value=[...r.value,...a.value],a.value=[],m.value=!1,Z();m.value=!0}}async function Ae(e){y=async()=>{await Ae(e)};let t=await Me({continueUntilFilled:!0,cursor:e,direction:`backward`,phase:`loading`});if(!t)return;let n=Te();r.value=[...t.buckets,...r.value],Ee(n),Z()}async function je(e){if(y=async()=>{await je(e)},!t.resolve)return null;let n=e===`leading`?F.value:I.value;if(!n)return null;let i=k(n.cursor);if(_.has(i))return null;_.add(i),s.value=null,c.value=`refreshing`,l.value=null,u.value=null,p.value=null;let a=++b,o=typeof AbortController>`u`?null:new AbortController;v=o;try{let i=await t.resolve({cursor:n.cursor,pageSize:T.value,signal:o?.signal});if(a!==b)return Z(),null;let s=J({cursor:n.cursor,edge:e,nextCursor:i.nextPage,nextItems:i.items,previousCursor:i.previousPage??null,previousItems:n.items,sequence:x});x=s.nextSequence;let c=Te();return r.value=H(r.value,n.cursor,s.bucket),Ee(c),Z(),{followCursor:e===`leading`?i.previousPage??null:i.nextPage,itemsLoaded:i.items.length}}catch(e){return K(e)||a!==b?(Z(),null):(s.value=e instanceof Error?e.message:`The viewer could not load items.`,c.value=`failed`,l.value=null,u.value=null,p.value=null,null)}finally{v===o&&(v=null),_.delete(i)}}async function Me(e){if(!t.resolve)return null;let n=++b,r=new Set,i=[],a=e.cursor,o=0;for(s.value=null,c.value=e.phase,l.value=null,u.value=null,p.value=null;;){if(n!==b)return Y(i,e.direction,t.removedIds.value,!0);if(i.length>0&&g.value)return Y(i,e.direction,t.removedIds.value,!1);let f=k(a);if(r.has(f)||_.has(f))break;r.add(f),_.add(f);let m=typeof AbortController>`u`?null:new AbortController;v=m;try{let r=await t.resolve({cursor:a,pageSize:T.value,signal:m?.signal});if(n!==b)return Y(i,e.direction,t.removedIds.value,!0);let s=Ne({cursor:a,nextCursor:r.nextPage,nextItems:r.items,previousCursor:r.previousPage??null,previousItems:[]});i.push(s);let f=i.reduce((e,n)=>e+B(n,t.removedIds.value),0),h=e.direction===`forward`?s.nextCursor:s.previousCursor;if(!e.continueUntilFilled||f>=T.value||!h)return u.value=null,{canceled:!1,buckets:e.direction===`backward`?[...i].reverse():i,visibleCount:f};if(g.value)return Y(i,e.direction,t.removedIds.value,!1);c.value=`filling`,l.value=f,u.value=h,p.value=T.value,o+=1;let _=oe(o,S.value,C.value);if(await d.wait(_),n!==b)return Y(i,e.direction,t.removedIds.value,!0);a=h}catch(r){return K(r)||n!==b?Y(i,e.direction,t.removedIds.value,!0):(s.value=r instanceof Error?r.message:`The viewer could not load items.`,c.value=`failed`,l.value=null,u.value=null,p.value=null,null)}finally{v===m&&(v=null),_.delete(f)}}return Y(i,e.direction,t.removedIds.value,!1)}function Ne(e){let t=q({cursor:e.cursor,nextCursor:e.nextCursor,nextItems:e.nextItems,previousCursor:e.previousCursor,previousItems:e.previousItems,sequence:x});return x=t.nextSequence,t.bucket}function Z(){c.value=`idle`,l.value=null,u.value=null,p.value=null,d.clear()}function Pe(){if(!t.initialState||!t.initialState.items.length)return!1;let e=X({initialState:t.initialState,removedIds:t.removedIds.value,sequence:x});return r.value=e.buckets,i.value=e.activeIndex,x=e.nextSequence,o.value=!1,s.value=null,a.value=[],m.value=!1,!0}function Fe(){return c.value===`initializing`}function Ie(e){return ne(e===`leading`?F.value:I.value,t.removedIds.value,T.value)}function Le(){let e=r.value.findIndex(e=>B(e,t.removedIds.value)>0);if(e<0)return;let n=e;for(let i=r.value.length-1;i>=e;--i)if(B(r.value[i],t.removedIds.value)>0){n=i;break}r.value=r.value.slice(e,n+1)}return{activeIndex:M,canRetryInitialLoad:pe,cancel:we,canRefreshTrailingBoundary:ae,commitPendingAppend:ye,currentCursor:fe,errorMessage:s,fillCollectedCount:l,fillCursor:u,fillDelayRemainingMs:f,fillTargetCount:p,hasNextPage:W,hasPreviousPage:G,isAutoPrefetchEnabled:h,isPageLoadingLocked:g,items:j,lockPageLoading:Se,loading:N,maybePrefetchAround:Oe,nextCursor:z,pendingAppendItems:le,phase:c,prefetchNextPage:he,prefetchPreviousPage:ge,previousCursor:U,retryInitialLoad:_e,retry:ve,setActiveIndex:be,setAutoPrefetchEnabled:xe,syncActiveIndexAfterVisibilityChange:Ee,unlockPageLoading:Ce,getActiveOccurrenceKey:Te,maybeCommitPendingAppendWhenFilteredOut:De}}function ue(e,t){return e.find(e=>B(e,t)>0)??e[0]??null}function de(e,t){for(let n=e.length-1;n>=0;--n){let r=e[n];if(B(r,t)>0)return r}return e[e.length-1]??null}function fe(t,n){let{clearRemoved:r,getRemovedIds:i,remove:a,removedIds:o,restore:s,undo:c}=j(),l=le({emit:n,fillDelayMs:t.fillDelayMs,fillDelayStepMs:t.fillDelayStepMs,initialCursor:t.initialCursor,initialState:t.initialState,pageSize:t.pageSize,removedIds:o,resolve:t.resolve}),u=l.items,d=l.activeIndex,f=l.loading,p=l.hasNextPage,m=l.hasPreviousPage,h=(0,e.computed)(()=>o.value.size),g=(0,e.computed)(()=>t.paginationDetail??null),_=(0,e.computed)(()=>!l.hasNextPage.value&&l.canRefreshTrailingBoundary.value);function v(e){let t=u.value;t.length&&l.setActiveIndex(C(e,0,t.length-1))}function y(e){let t=l.getActiveOccurrenceKey(),n=u.value[d.value]??null,r=Array.isArray(e)?e:[e],i=!!(n&&r.includes(n.id)&&l.isAutoPrefetchEnabled.value&&d.value>=u.value.length-3),o=!!(n&&r.includes(n.id)&&l.hasNextPage.value&&d.value===u.value.length-1),s=a(e);return s.ids.length?(l.maybeCommitPendingAppendWhenFilteredOut(),l.syncActiveIndexAfterVisibilityChange(t,{preserveTrailingPlaceholder:o}),i&&l.maybePrefetchAround(),s):s}function b(e){let t=l.getActiveOccurrenceKey(),n=s(e);return n.ids.length&&l.syncActiveIndexAfterVisibilityChange(t),n}function x(){let e=l.getActiveOccurrenceKey(),t=c();return t?.ids.length&&l.syncActiveIndexAfterVisibilityChange(e),t}function S(){let e=l.getActiveOccurrenceKey();r(),l.syncActiveIndexAfterVisibilityChange(e)}function C(e,t,n){return Math.min(Math.max(e,t),n)}function w(){l.cancel()}async function T(){await l.prefetchNextPage()}async function E(){await l.prefetchPreviousPage()}async function D(){await l.retry()}return{activeIndex:d,canRefreshExhaustedNextPage:_,canRetryInitialLoad:l.canRetryInitialLoad,cancel:w,clearRemoved:S,commitPendingAppend:l.commitPendingAppend,currentCursor:l.currentCursor,errorMessage:l.errorMessage,fillCollectedCount:l.fillCollectedCount,fillCursor:l.fillCursor,fillDelayRemainingMs:l.fillDelayRemainingMs,fillTargetCount:l.fillTargetCount,getRemovedIds:i,hasNextPage:p,hasPreviousPage:m,isPageLoadingLocked:l.isPageLoadingLocked,items:u,lockPageLoading:l.lockPageLoading,loading:f,loadNext:T,loadPrevious:E,nextCursor:l.nextCursor,paginationDetail:g,pendingAppendItems:l.pendingAppendItems,phase:l.phase,prefetchNextPage:l.prefetchNextPage,prefetchPreviousPage:l.prefetchPreviousPage,previousCursor:l.previousCursor,removedCount:h,remove:y,restore:b,retry:D,retryInitialLoad:l.retryInitialLoad,setActiveIndex:v,setAutoPrefetchEnabled:l.setAutoPrefetchEnabled,undo:x,unlockPageLoading:l.unlockPageLoading}}var pe=1024;function me(t,n){let r=fe(t,n),i=(0,e.reactive)({nextBoundaryLoadProgress:0,previousBoundaryLoadProgress:0}),a=(0,e.ref)(0),o=(0,e.ref)(`list`),s=(0,e.reactive)({activeIndex:0,currentCursor:null,errorMessage:null,fillCollectedCount:null,fillCursor:null,fillDelayRemainingMs:null,fillTargetCount:null,hasNextPage:!1,hasPreviousPage:!1,itemCount:0,loadState:`loaded`,nextBoundaryLoadProgress:0,nextCursor:null,pageLoadingLocked:!1,phase:`idle`,previousBoundaryLoadProgress:0,previousCursor:null,removedCount:0,removedIds:[],surfaceMode:`list`}),c=(0,e.computed)(()=>a.value>=pe),l=(0,e.computed)(()=>c.value?o.value:`fullscreen`),u=(0,e.computed)(()=>c.value&&l.value===`fullscreen`);(0,e.watch)(c,e=>{e&&h()}),(0,e.watch)(()=>t.surfaceMode,()=>{h()}),(0,e.watch)([l,()=>r.pendingAppendItems.value.length],([e,t])=>{e===`list`||t<=0||r.commitPendingAppend()}),(0,e.watch)([()=>r.items.value.length,()=>r.loading.value,()=>r.hasNextPage.value,()=>r.pendingAppendItems.value.length],([e,t,r,i])=>{!c.value||e>0||o.value===`list`||t||r||i>0||(o.value=`list`,n(`update:surfaceMode`,`list`))}),(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.fillCursor=r.fillCursor.value,s.fillDelayRemainingMs=r.fillDelayRemainingMs.value,s.fillTargetCount=r.fillTargetCount.value,s.hasNextPage=r.hasNextPage.value,s.hasPreviousPage=r.hasPreviousPage.value,s.itemCount=r.items.value.length,s.loadState=r.loading.value?`loading`:r.errorMessage.value?`failed`:`loaded`,s.nextBoundaryLoadProgress=i.nextBoundaryLoadProgress,s.nextCursor=r.nextCursor.value,s.pageLoadingLocked=r.isPageLoadingLocked.value,s.phase=r.phase.value,s.previousBoundaryLoadProgress=i.previousBoundaryLoadProgress,s.previousCursor=r.previousCursor.value,s.removedCount=r.removedCount.value,s.removedIds=r.getRemovedIds(),s.surfaceMode=l.value}),(0,e.onMounted)(()=>{m(),h(),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&&o.value!==`fullscreen`&&(o.value=`fullscreen`,n(`update:surfaceMode`,`fullscreen`))}function f(){!c.value||o.value===`list`||(o.value=`list`,n(`update:surfaceMode`,`list`))}function p(e){e.defaultPrevented||e.key!==`Escape`||!c.value||l.value!==`fullscreen`||T(e.target)||(e.preventDefault(),f())}function m(){a.value=window.innerWidth||0}function h(){!c.value||!t.surfaceMode||t.surfaceMode===o.value||(o.value=t.surfaceMode)}function g(e){i.nextBoundaryLoadProgress=he(e.nextBoundaryLoadProgress),i.previousBoundaryLoadProgress=he(e.previousBoundaryLoadProgress)}return{...r,cancel:r.cancel,isDesktop:c,lockPageLoading:r.lockPageLoading,loadNext:r.loadNext,loadPrevious:r.loadPrevious,openFullscreen:d,returnToList:f,retry:r.retry,setBoundaryLoadProgress:g,showBackToList:u,status:(0,e.readonly)(s),surfaceMode:l,unlockPageLoading:r.unlockPageLoading}}function he(e){return Math.min(Math.max(e,0),1)}var ge={"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]`},_e={class:`grid grid-cols-[auto_minmax(0,1fr)_auto_auto] items-center gap-3 border-t border-white/12 bg-black/70 px-4 py-3 backdrop-blur-[18px]`},ve={class:`text-[0.76rem] font-bold uppercase tracking-[0.18em] text-[#f7f1ea]/74`},ye={class:`relative h-4 w-full`},be=[`max`,`value`,`disabled`],xe={class:`text-[0.76rem] font-bold uppercase tracking-[0.18em] text-[#f7f1ea]/74`},Se=[`data-layout`],Ce={key:0,"data-testid":`vibe-media-volume-popover`,class:`absolute bottom-[calc(100%+0.8rem)] right-0 grid justify-items-center gap-3 border border-white/12 bg-black/82 px-3 py-4 shadow-[0_20px_50px_-20px_rgba(0,0,0,0.85)] backdrop-blur-[18px]`},we={class:`relative flex h-28 w-4 items-center justify-center`},Te=[`value`],Ee={class:`flex items-center gap-3`},De=[`aria-label`],Oe={key:0,class:`relative h-4 w-24`},ke=[`value`],Ae=(0,e.defineComponent)({__name:`FullscreenMediaBar`,props:{currentTime:{},currentTimeLabel:{},duration:{},durationLabel:{},muted:{type:Boolean},progress:{},volume:{},volumeControlLayout:{}},emits:[`seek-input`,`volume-input`,`volume-toggle`],setup(t,{emit:n}){let r=t,i=n,a=(0,e.ref)(null),o=(0,e.ref)(!1),s=(0,e.computed)(()=>r.volumeControlLayout===`vertical`),c=(0,e.computed)(()=>g(r.volume,0,1)),l=(0,e.computed)(()=>Math.round(c.value*100)),u=(0,e.computed)(()=>r.muted||c.value<=0?x:c.value<.5?y:b),d=(0,e.computed)(()=>r.muted||c.value<=0?`Unmute active media`:`Mute active media`),f=(0,e.computed)(()=>s.value&&!o.value?`Show volume controls`:d.value),p=(0,e.computed)(()=>r.volumeControlLayout===`vertical`?{height:`${l.value}%`}:{width:`${l.value}%`});(0,e.watch)(s,e=>{e||(o.value=!1)}),(0,e.onMounted)(()=>{document.addEventListener(`pointerdown`,m)}),(0,e.onBeforeUnmount)(()=>{document.removeEventListener(`pointerdown`,m)});function m(e){!s.value||!o.value||a.value&&e.target instanceof Node&&!a.value.contains(e.target)&&(o.value=!1)}function h(){if(!s.value){i(`volume-toggle`);return}if(!o.value){o.value=!0;return}i(`volume-toggle`)}function g(e,t,n){return Math.min(Math.max(e,t),n)}return(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,ge,[(0,e.createElementVNode)(`div`,_e,[(0,e.createElementVNode)(`span`,ve,(0,e.toDisplayString)(r.currentTimeLabel),1),(0,e.createElementVNode)(`div`,ye,[n[3]||=(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,be)]),(0,e.createElementVNode)(`span`,xe,(0,e.toDisplayString)(r.durationLabel),1),(0,e.createElementVNode)(`div`,{ref_key:`rootRef`,ref:a,"data-testid":`vibe-media-volume`,"data-layout":r.volumeControlLayout,class:`relative flex items-center justify-end`},[s.value&&o.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Ce,[(0,e.createElementVNode)(`div`,we,[n[4]||=(0,e.createElementVNode)(`div`,{class:`absolute bottom-0 left-1/2 h-full w-px -translate-x-1/2 bg-white/12`},null,-1),(0,e.createElementVNode)(`div`,{class:`absolute bottom-0 left-1/2 w-px -translate-x-1/2 bg-[#f7f1ea]`,style:(0,e.normalizeStyle)(p.value)},null,4),(0,e.createElementVNode)(`input`,{"data-testid":`vibe-media-volume-slider`,"data-swipe-lock":`true`,type:`range`,"aria-label":`Adjust active media volume`,min:`0`,max:`1`,step:`0.05`,value:c.value,class:`vibe-media-slider absolute left-1/2 top-1/2 h-4 w-28 -translate-x-1/2 -translate-y-1/2 -rotate-90 bg-transparent`,onInput:n[1]||=e=>i(`volume-input`,e)},null,40,Te)])])):(0,e.createCommentVNode)(``,!0),(0,e.createElementVNode)(`div`,Ee,[(0,e.createElementVNode)(`button`,{type:`button`,"data-testid":`vibe-media-volume-button`,"aria-label":f.value,class:`inline-flex h-10 w-10 items-center justify-center border border-white/14 bg-black/50 text-[#f7f1ea]/82 backdrop-blur-[18px] transition hover:border-white/28 hover:bg-black/65`,onClick:h},[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)(u.value),{class:`h-4 w-4 stroke-[1.9]`,"aria-hidden":`true`}))],8,De),r.volumeControlLayout===`horizontal`?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Oe,[n[5]||=(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)(p.value)},null,4),(0,e.createElementVNode)(`input`,{"data-testid":`vibe-media-volume-slider`,"data-swipe-lock":`true`,type:`range`,"aria-label":`Adjust active media volume`,min:`0`,max:`1`,step:`0.05`,value:c.value,class:`vibe-media-slider absolute inset-0 z-10 h-4 w-full cursor-pointer bg-transparent`,onInput:n[2]||=e=>i(`volume-input`,e)},null,40,ke)])):(0,e.createCommentVNode)(``,!0)])],8,Se)])]))}}),je={class:`pointer-events-none absolute inset-0 z-[3] flex flex-col justify-between p-[clamp(1.25rem,2.6vw,2.25rem)]`},Me={class:`grid gap-4`},Ne={class:`flex min-h-11 items-center justify-between gap-4`},Z={class:`min-w-0 flex flex-1 items-center gap-3`},Pe={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]`},Fe={class:`pointer-events-auto flex shrink-0 items-center gap-2`},Ie={"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]`},Le={class:`whitespace-nowrap`},Re={key:1,class:`whitespace-nowrap border-l border-white/12 pl-2 text-[#f7f1ea]/56 min-[721px]:pl-3`},ze={key:0,class:`grid gap-2 max-[720px]:justify-items-start`},Be=(0,e.defineComponent)({__name:`FullscreenHeader`,props:{currentIndex:{},loading:{type:Boolean},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`,je,[(0,e.createElementVNode)(`div`,Me,[(0,e.createElementVNode)(`div`,Ne,[(0,e.createElementVNode)(`div`,Z,[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`,Pe,(0,e.toDisplayString)(r.title),1)):(0,e.createCommentVNode)(``,!0)]),(0,e.createElementVNode)(`div`,Fe,[(0,e.createElementVNode)(`span`,Ie,[r.loading?((0,e.openBlock)(),(0,e.createBlock)((0,e.unref)(h),{key:0,"data-testid":`vibe-pagination-spinner`,class:`h-3.5 w-3.5 animate-spin stroke-[1.9]`,"aria-hidden":`true`})):(0,e.createCommentVNode)(``,!0),(0,e.createElementVNode)(`span`,Le,(0,e.toDisplayString)(r.currentIndex+1)+` / `+(0,e.toDisplayString)(r.total),1),r.paginationDetail?((0,e.openBlock)(),(0,e.createElementBlock)(`span`,Re,(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`,ze,[...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)]))}}),Ve={image:m,video:f,audio:d,other:p},He={image:`Image`,video:`Video`,audio:`Audio`,other:`File`};function Ue(e){return Ve[e]}function We(e){return He[e]}var Ge={maxGlobal:10,maxPerDomain:4,maxVideoPerDomain:2};function Ke(e=Ge){let t=new Map,n=new Map,r=0;function i(e){let i={...e,domain:Ye(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=Je(e)-Je(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 qe=Ke();function Je(e){try{let t=e.getPriority();return Number.isFinite(t)?t:1/0}catch{return 1/0}}function Ye(e){try{return new URL(e).hostname||`local`}catch{return`local`}}var Xe=[1,2,3],Ze={1:0,2:1,3:2};function Qe(t){let n=(0,e.ref)({}),r=Ke({maxGlobal:2,maxPerDomain:2,maxVideoPerDomain:2}),i=new Map,a=new Map,o=new Map,s=new Set;(0,e.watch)([t.active,t.items,t.resolvedActiveIndex],()=>{p()},{immediate:!0}),(0,e.getCurrentScope)()&&(0,e.onScopeDispose)(()=>{f()});function c(e){if(!t.active.value)return!1;let r=t.items.value[e];if(!r||!nt(r))return!1;let i=t.getItemKey(r);return i===h()||!!n.value[i]}function l(e,t){if(t instanceof HTMLImageElement){a.set(e,t),et(t)&&d(e);return}a.delete(e)}function u(e,t){if(t instanceof HTMLMediaElement){o.set(e,t),tt(t)&&d(e);return}o.delete(e)}function d(e){let t=i.get(e);t&&(t.lease.release(),i.delete(e))}function f(){for(let e of i.values())e.lease.release();i.clear(),n.value={},v()}function p(){if(!t.active.value){f();return}let e=m(),c=new Set(e.map(e=>e.key)),l=h();for(let e of s)e!==l&&c.has(e)&&y(e,!0);for(let e of Object.keys(n.value))c.has(e)||y(e,!1);for(let[t,n]of i.entries()){if(!c.has(t)){n.lease.release(),i.delete(t);continue}let r=e.find(e=>e.key===t);r&&(n.index=r.index)}for(let t of e){if(i.has(t.key)||n.value[t.key])continue;let e;e={index:t.index,key:t.key,lease:r.request({assetType:t.item.type===`image`?`image`:`video`,getPriority:()=>g(e.index),onGrant:()=>{y(t.key,!0),$e(t.key,a,o)&&d(t.key)},url:t.item.url})},i.set(t.key,e)}for(let e of i.values())e.lease.refresh();v()}function m(){let e=t.resolvedActiveIndex.value;return Xe.map(t=>_(e+t)).filter(e=>!!e)}function h(){let e=t.items.value[t.resolvedActiveIndex.value];return!t.active.value||!e||!nt(e)?null:t.getItemKey(e)}function g(e){return t.active.value?Ze[e-t.resolvedActiveIndex.value]??1/0:1/0}function _(e){let n=t.items.value[e];return!n||!nt(n)?null:{index:e,item:n,key:t.getItemKey(n)}}function v(){let e=new Set,r=h();r&&e.add(r);for(let t of Object.keys(n.value))e.add(t);for(let n of s)e.has(n)||(b(n),t.onResetAssetState(n));s=e}function y(e,t){if(t){if(n.value[e])return;n.value={...n.value,[e]:!0};return}if(!n.value[e])return;let r={...n.value};delete r[e],n.value=r}function b(e){let t=a.get(e);if(t)try{t.removeAttribute(`src`),t.src=``}catch{}let n=o.get(e);if(n){try{n.currentTime=0}catch{}n.pause();try{n.removeAttribute(`src`),n.load()}catch{}}}return{clearBackgroundPreloads:f,registerImageElement:l,registerMediaElement:u,settleBackgroundPreload:d,shouldAttachSlideAsset:c}}function $e(e,t,n){let r=t.get(e);if(r)return et(r);let i=n.get(e);return i?tt(i):!1}function et(e){return e.complete&&!!(e.currentSrc||e.getAttribute(`src`))}function tt(e){let t=typeof HTMLMediaElement>`u`?1:HTMLMediaElement.HAVE_METADATA;return e.readyState>=t}function nt(e){return e.type===`image`||e.type===`video`||e.type===`audio`}function rt(e){let t=Qe({active:e.active,getItemKey:r,items:e.items,onResetAssetState:e.viewer.resetAssetState,resolvedActiveIndex:e.resolvedActiveIndex});function n(e,t){let n=t.title?.trim();return n?`${e} ${n}`:`${e} ${We(t.type).toLowerCase()}`}function r(e){return P(e)}function i(e){return t.shouldAttachSlideAsset(e)}function a(t,n){let a=r(n);return!i(t)||t!==e.resolvedActiveIndex.value||e.viewer.getAssetErrorKind(a)?!1:n.type===`image`?!e.viewer.isImageReady(a):n.type===`video`||n.type===`audio`?!e.viewer.isMediaReady(a):!1}function o(t){return e.viewer.getAssetErrorKind(r(t))}function s(t){return e.viewer.getAssetErrorLabel(r(t))??`Load error`}function c(t,n){return i(t)&&t===e.resolvedActiveIndex.value&&!!o(n)}function l(t,n){return i(t)?e.viewer.getImageSource(n):void 0}function u(e){return i(e)?`metadata`:`none`}function d(e,t){return i(e)?t.url:void 0}return{getAssetErrorKind:o,getAssetErrorLabel:s,getFullscreenImageSource:l,getFullscreenMediaPreload:u,getFullscreenMediaSource:d,getItemKey:r,getMediaActionLabel:n,isAssetErrored:c,isAssetLoading:a,registerImageElement:t.registerImageElement,registerMediaElement:t.registerMediaElement,settleBackgroundPreload:t.settleBackgroundPreload,shouldPreloadSlideAsset:i}}function it(t){if(!Array.isArray(t))return!1;for(let n of t){if(Array.isArray(n)){if(it(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(!at(n))return!0}return!1}function at(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?!it(t.children):!1}var ot=`no items available`;function st(t){let n=(0,e.computed)(()=>t.loading.value||t.itemCount.value>0||t.emptyStateMode.value===`hidden`?null:{loading:!!t.loading.value,message:ot,mode:t.emptyStateMode.value===`badge`?`badge`:`inline`,surface:t.surface,total:t.itemCount.value}),r=(0,e.computed)(()=>!n.value||!t.renderSlot?[]:t.renderSlot(n.value));return{emptyStateProps:n,showBadgeEmptyState:(0,e.computed)(()=>n.value?.mode===`badge`),showCustomEmptyState:(0,e.computed)(()=>it(r.value)),showInlineEmptyState:(0,e.computed)(()=>n.value?.mode===`inline`)}}function ct(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 lt(e){return e.phase?e.phase:e.loading?e.itemCount>0?`loading`:`initializing`:`idle`}function ut(e){return e.phase===`failed`?{kind:`failed`,message:e.errorMessage??(e.hasItems?`The viewer could not load more items.`:`The viewer could not load items.`)}:e.phase===`initializing`?{kind:`initializing`,message:`Loading the first page`}:e.phase===`loading`?{kind:`loading-more`,message:e.hasItems?`Loading more items`:`Loading the first page`}:e.phase===`filling`?{kind:`filling`,message:`Filling the view`}:e.phase===`refreshing`?{kind:`refreshing`,message:!e.hasNextPage&&e.hasItems?e.surface===`grid`?`Refreshing the end of the list`:`Refreshing the end of the feed`:`Refreshing visible items`}:!e.hasItems||e.hasNextPage?null:{kind:`end`,message:e.surface===`grid`?`End of list`:`End of feed`}}function dt(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 ft={currentTime:0,duration:0,errorKind:null,muted:!1,paused:!0,ready:!1,volume:1};function pt(){return{...ft}}function mt(e){return e.complete&&!!(e.currentSrc||e.getAttribute(`src`))}function ht(e,t,n){e.currentTime=Number.isFinite(t.currentTime)?t.currentTime:0,e.duration=Number.isFinite(t.duration)?t.duration:0,e.muted=t.muted,e.paused=t.paused,e.volume=Number.isFinite(t.volume)?t.volume:e.volume,n&&n!==`error`&&(e.errorKind=null),e.ready=gt(t,n)}function gt(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 _t=new Map;function vt(e){return e===`not-found`?`404`:`Load error`}function yt(e){return e===`generic`}function bt(e){return xt(e).then(e=>e??`generic`)}function xt(e){let t=_t.get(e);if(t)return t;let n=St(e);return _t.set(e,n),n}async function St(e){if(!Ct(e))return null;try{let t=await fetch(e,{method:`HEAD`});return t.ok?null:t.status===404?`not-found`:`generic`}catch{return`generic`}}function Ct(e){return/^(https?:\/\/|\/)/i.test(e)}function wt(e){try{let t=e.play();t&&typeof t.catch==`function`&&t.catch(()=>{})}catch{}}function Tt(t){let n=(0,e.ref)({}),r=(0,e.ref)({}),i=(0,e.ref)({}),a=(0,e.ref)({}),o=(0,e.ref)({}),s=new Map,c=new Map,l=new Set,u=(0,e.computed)(()=>t.activeItem.value?P(t.activeItem.value):null),d=(0,e.computed)(()=>t.activeMediaItem.value?P(t.activeMediaItem.value):null),f=(0,e.computed)(()=>{let e=new Map;for(let n of t.items.value)e.set(P(n),n);return e}),p=(0,e.computed)(()=>d.value?i.value[d.value]??ft:ft),m=(0,e.computed)(()=>d.value?p.value.duration:0),h=(0,e.computed)(()=>m.value<=0?0:Et(p.value.currentTime/m.value*100,0,100)),g=(0,e.computed)(()=>u.value?I(u.value):null);(0,e.watch)(()=>u.value,async()=>{await S()}),(0,e.watch)(()=>t.itemCount.value,async()=>{await S()}),(0,e.watch)(()=>t.loopFullscreenVideo.value,async()=>{await S()});function _(e,t){if(t instanceof HTMLVideoElement){s.set(e,t),W(e,t);return}s.delete(e)}function v(e,t){if(t instanceof HTMLAudioElement){c.set(e,t),W(e,t);return}c.delete(e)}function y(e,t){t instanceof HTMLImageElement&&mt(t)&&(n.value[e]=!0,r.value[e]=null,X(e,t.currentSrc||t.src||te(e)))}function b(){H(),a.value={},r.value={},n.value={},o.value={},i.value={},l.clear()}function x(e){delete n.value[e],delete r.value[e],delete o.value[e],delete i.value[e],l.forEach(t=>{t.startsWith(`${e}|`)&&l.delete(t)})}async function S(){if(!t.isEnabled.value){H();return}await(0,e.nextTick)();let n=u.value;for(let[e,r]of s.entries()){if(e!==n||i.value[e]?.errorKind){V(r,e);continue}r.muted=!1,r.loop=t.loopFullscreenVideo.value,r.playsInline=!0,wt(r),W(e,r)}for(let[e,t]of c.entries()){if(e!==n||i.value[e]?.errorKind){V(t,e);continue}wt(t),W(e,t)}}function C(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;W(e,n,t.type);let a=i.value[e]?.ready??!1;!r&&a&&X(e,n.currentSrc||n.src||te(e))}}function w(e,t){n.value[e]=!0,r.value[e]=null,X(e,t)}async function T(e,i){let a=ee(e)??t.activeItem.value;n.value[e]=!1,r.value[e]=`generic`;let o=await bt(i);r.value[e]=o,a&&t.onAssetError?.({item:a,occurrenceKey:e,url:i,kind:o,surface:`fullscreen`})}async function E(e,n){let r=q(e),i=U(e),a=ee(e)??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 bt(n);i.errorKind=o,a&&t.onAssetError?.({item:a,occurrenceKey:e,url:n,kind:o,surface:`fullscreen`})}function D(e,t,n){e.button!==0||Date.now()<n||Y(s.get(t)??null)}function O(e,t,n){e.button!==0||Date.now()<n||Y(q(t))}function k(e){let t=J(),n=d.value;if(!t||!n||!(e.target instanceof HTMLInputElement))return;let r=Number.parseFloat(e.target.value);if(!Number.isFinite(r))return;let i=Et(r,0,m.value||0);G(n,i,t),t.currentTime=i}function A(e){let t=J(),n=d.value;if(!t||!n||!(e.target instanceof HTMLInputElement))return;let r=Et(Number.parseFloat(e.target.value),0,1);t.volume=r,t.muted=r<=0,r>0&&(o.value[n]=r),W(n,t)}function j(){let e=J(),t=d.value;!e||!t||(e.muted||e.volume<=0?(e.volume=K(t),e.muted=!1,o.value[t]=e.volume):(o.value[t]=e.volume,e.muted=!0),W(t,e))}function M(e){return!!n.value[e]&&!r.value[e]}function N(e){return(i.value[e]?.ready??!1)&&!i.value[e]?.errorKind}function F(e){return e.url}function I(e){return r.value[e]??i.value[e]?.errorKind??null}function L(e){let t=I(e);return t?vt(t):null}function R(e){return yt(I(e))}function z(e){return`${e}:${a.value[e]??0}`}async function B(t){if(!R(t))return;n.value[t]=!1,r.value[t]=null;let i=U(t);i.currentTime=0,i.duration=0,i.paused=!0,i.ready=!1,i.errorKind=null;let o=q(t);o&&V(o,t),l.forEach(e=>{e.startsWith(`${t}|`)&&l.delete(e)}),a.value[t]=(a.value[t]??0)+1,await(0,e.nextTick)(),await S()}function V(e,t){e.pause();try{e.currentTime=0}catch{}W(t,e)}function H(){for(let[e,t]of s.entries())V(t,e);for(let[e,t]of c.entries())V(t,e)}function U(e){return i.value[e]||(i.value[e]=pt()),i.value[e]}function W(e,t,n){ht(U(e),t,n),!t.muted&&t.volume>0&&(o.value[e]=t.volume)}function G(e,t,n){let r=U(e);r.currentTime=t,r.duration=Number.isFinite(n.duration)?n.duration:r.duration,r.muted=n.muted,r.paused=n.paused,r.volume=Number.isFinite(n.volume)?n.volume:r.volume}function K(e){return Et(o.value[e]??1,0,1)}function q(e){return s.get(e)??c.get(e)??null}function J(){return d.value?q(d.value):null}function Y(e){if(e){if(e.paused){wt(e);return}e.pause()}}function X(e,n){let r=ee(e)??t.activeMediaItem.value??t.activeItem.value;if(!r||!n)return;let i=`${e}|${n}`;l.has(i)||(l.add(i),t.onAssetLoad?.({item:r,occurrenceKey:e,surface:`fullscreen`,url:n}))}function ee(e){return f.value.get(e)??null}function te(e){return ee(e)?.url??null}return{activeAssetErrorKind:g,activeMediaDuration:m,activeMediaProgress:h,activeMediaState:p,getAssetErrorKind:I,getAssetErrorLabel:L,getAssetRenderKey:z,getImageSource:F,isImageReady:M,isMediaReady:N,canRetryAsset:R,mediaStates:i,onAudioCoverClick:O,onImageError:T,onImageLoad:w,onMediaError:E,onMediaEvent:C,onMediaSeekInput:k,onMediaVolumeInput:A,onMediaVolumeToggle:j,onVideoClick:D,registerAudioElement:v,registerImageElement:y,registerVideoElement:_,resetAssetState:x,resetMediaState:b,retryAsset:B,syncMediaPlayback:S}}function Et(e,t,n){return Math.min(Math.max(e,t),n)}var Dt={backward:1,forward:3};function Ot(e,t,n=Dt){return t<=0?{start:0,end:-1}:{start:Math.max(0,e-n.backward),end:Math.min(t-1,e+n.forward)}}function kt(e,t,n=Dt){let r=Ot(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 At(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 jt(t,n,r={}){let i=(0,e.computed)(()=>t.items),a=(0,e.computed)(()=>t.activeIndex??0),o=(0,e.computed)(()=>t.errorMessage??null),s=(0,e.computed)(()=>t.loading??!1),c=(0,e.computed)(()=>t.hasNextPage??!1),l=(0,e.computed)(()=>t.loopFullscreenVideo??!0),u=(0,e.computed)(()=>t.paginationDetail??null),d=(0,e.computed)(()=>lt({itemCount:i.value.length,loading:s.value,phase:t.phase})),f=(0,e.computed)(()=>!1),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,S=(0,e.computed)(()=>i.value.length===0?0:F(a.value,0,i.value.length-1)),C=(0,e.computed)(()=>i.value[S.value]??null),w=(0,e.computed)(()=>C.value?.type===`audio`||C.value?.type===`video`?C.value:null),D=Tt({items:i,activeItem:C,activeMediaItem:w,isEnabled:_,itemCount:(0,e.computed)(()=>i.value.length),loopFullscreenVideo:l,onAssetError:r.onAssetError,onAssetLoad:r.onAssetLoad}),O=(0,e.computed)(()=>i.value.length>0&&S.value===i.value.length-1),k=(0,e.computed)(()=>ut({errorMessage:o.value,hasItems:i.value.length>0,hasNextPage:c.value,phase:d.value,surface:`fullscreen`})),A=(0,e.computed)(()=>k.value?.kind??null),j=(0,e.computed)(()=>k.value?.message??null),M=(0,e.computed)(()=>Math.min(96,g.value*.15||96)),N=(0,e.computed)(()=>Ot(S.value,i.value.length)),P=(0,e.computed)(()=>kt(i.value,S.value));dt({enabled:_,onDisable(){G(),D.resetMediaState()},onEnable(){return D.syncMediaPlayback()},onKeydown:q,onResize:I});function F(e,t,n){return Math.min(Math.max(e,t),n)}function I(){g.value=p.value?.clientHeight||window.innerHeight||1}function L(e){return i.value.length===0?!1:F(S.value+e,0,i.value.length-1)!==S.value}function R(e){if(i.value.length===0)return;let t=F(S.value+e,0,i.value.length-1);t!==S.value&&n(`update:activeIndex`,t)}function z(e){let t=e>0,n=e<0;return t&&!L(-1)||n&&!L(1)?e*.24:e}function B(e){!_.value||i.value.length===0||e.pointerType===`mouse`||E(e.target)||(v=e.pointerId,y=e.clientY,m.value=0,h.value=!0,p.value?.setPointerCapture?.(e.pointerId))}function V(e){!_.value||!h.value||v!==e.pointerId||(m.value=z(e.clientY-y))}function H(e){!_.value||v!==e.pointerId||(p.value?.releasePointerCapture?.(e.pointerId),W())}function U(e){!_.value||v!==e.pointerId||(p.value?.releasePointerCapture?.(e.pointerId),G())}function W(){Math.abs(m.value)>=M.value&&(x=Date.now()+250,R(m.value<0?1:-1)),G()}function G(){m.value=0,h.value=!1,v=null}function K(e){if(!_.value||i.value.length===0||h.value||E(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,R(e.deltaY>0?1:-1))}function q(e){!_.value||i.value.length===0||T(e.target)||((e.key===`ArrowDown`||e.key===`PageDown`)&&(e.preventDefault(),R(1)),(e.key===`ArrowUp`||e.key===`PageUp`)&&(e.preventDefault(),R(-1)))}function J(e,t){D.onVideoClick(e,t,x)}function Y(e,t){D.onAudioCoverClick(e,t,x)}function X(e){D.onMediaSeekInput(e)}function ee(e){D.onMediaVolumeInput(e)}function te(){D.onMediaVolumeToggle()}function ne(e){return e.type===`image`||e.type===`video`}function re(e){return e.type===`audio`}function ie(e){return At(e,S.value,g.value,m.value,h.value)}return{activeItem:C,activeAssetErrorKind:D.activeAssetErrorKind,activeMediaDuration:D.activeMediaDuration,activeMediaItem:w,activeMediaProgress:D.activeMediaProgress,activeMediaState:D.activeMediaState,canRetryAsset:D.canRetryAsset,canRetryInitialLoad:f,errorMessage:o,getAssetErrorKind:D.getAssetErrorKind,getAssetErrorLabel:D.getAssetErrorLabel,getAssetRenderKey:D.getAssetRenderKey,formatPlaybackTime:ct,getImageSource:D.getImageSource,getSlideStyle:ie,hasNextPage:c,isAtEnd:O,isAudio:re,isVisual:ne,items:i,loading:s,mediaStates:D.mediaStates,isImageReady:D.isImageReady,isMediaReady:D.isMediaReady,onAudioCoverClick:Y,onImageError:D.onImageError,onImageLoad:D.onImageLoad,onMediaEvent:D.onMediaEvent,onMediaError:D.onMediaError,onMediaSeekInput:X,onMediaVolumeInput:ee,onMediaVolumeToggle:te,onPointerCancel:U,onPointerDown:B,onPointerMove:V,onPointerUp:H,onVideoClick:J,onWheel:K,registerAudioElement:D.registerAudioElement,registerImageElement:D.registerImageElement,registerVideoElement:D.registerVideoElement,renderedItems:P,renderedRange:N,resolvedActiveIndex:S,resetAssetState:D.resetAssetState,retryInitialLoad:async()=>{},retryAsset:D.retryAsset,stageRef:p,statusKind:A,statusMessage:j,paginationDetail:u,phase:d}}var Mt=`bg-[linear-gradient(180deg,#0a0b10,#05060a)]`,Nt=`bg-[linear-gradient(180deg,#0b0c11,#06070b)]`,Pt={image:!0,video:!0,audio:!0,other:!0};function Ft(e){return Pt[e],Mt}function It(e){return Pt[e],Nt}function Lt(e){if(e.naturalWidth<=0||e.naturalHeight<=0)return null;let t=document.createElement(`canvas`),n=t.getContext(`2d`,{willReadFrequently:!0});if(!n)return null;t.width=24,t.height=24;try{n.drawImage(e,0,0,24,24);let{data:t}=n.getImageData(0,0,24,24),r=0,i=0,a=0,o=0;for(let e=0;e<t.length;e+=4){let n=t[e+3]/255;if(n<=.05)continue;let s=t[e],c=t[e+1],l=t[e+2],u=Math.max(s,c,l),d=n*(.65+(u===0?0:(u-Math.min(s,c,l))/u)*.7);r+=d,i+=s*d,a+=c*d,o+=l*d}return r<=0?null:{r:Rt(Math.round(i/r)),g:Rt(Math.round(a/r)),b:Rt(Math.round(o/r))}}catch{return null}}function Rt(e){return Math.min(235,Math.max(26,e))}function zt(t){let n=(0,e.ref)({}),r=(0,e.computed)(()=>t.activeItem.value?t.getItemKey(t.activeItem.value):null),i=(0,e.computed)(()=>!t.showDominantImageTone.value||t.activeItem.value?.type!==`image`||!r.value||!t.isImageReady(r.value)?null:n.value[r.value]??null),a=(0,e.computed)(()=>{if(!i.value)return;let{r:e,g:t,b:n}=i.value;return{background:`radial-gradient(circle at top center, rgba(${e},${t},${n},0.34) 0%, transparent 44%), linear-gradient(180deg,#0a0b10,#05060a)`}}),o=(0,e.computed)(()=>{if(!i.value)return;let{r:e,g:t,b:n}=i.value;return{background:`radial-gradient(circle at center, rgba(${e},${t},${n},0.42) 0%, transparent 44%), linear-gradient(180deg,#0b0c11,#06070b)`}});(0,e.watch)(()=>t.showDominantImageTone.value,e=>{e||(n.value={})});function s(e,r){if(!t.showDominantImageTone.value)return;let i=Lt(r);i&&(n.value[e]=i)}return{activeStageToneStyle:a,activeSlideToneStyle:o,updateFromImageElement:s}}var Bt=[`data-surface`],Vt=[`data-surface`],Ht=(0,e.defineComponent)({inheritAttrs:!1,__name:`SurfaceEmptyState`,props:{message:{},mode:{},surface:{}},setup(t){let n=(0,e.useAttrs)();return(r,i)=>t.mode===`inline`?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,(0,e.mergeProps)({key:0},(0,e.unref)(n),{"data-testid":`vibe-empty-state-inline`,"data-surface":t.surface,class:[`pointer-events-none absolute z-[4] text-center`,t.surface===`grid`?`inset-x-0 top-[clamp(6rem,22vh,11rem)] flex justify-center px-6`:`inset-0 grid place-items-center px-[clamp(2rem,4vw,3rem)] py-[clamp(2rem,4vw,3rem)]`]}),[(0,e.renderSlot)(r.$slots,`default`,{},()=>[(0,e.createElementVNode)(`p`,{class:(0,e.normalizeClass)([`m-0 text-[0.82rem] font-medium tracking-[0.08em]`,t.surface===`grid`?`text-[#f7f1ea]/58`:`text-[#f7f1ea]/64`])},(0,e.toDisplayString)(t.message),3)])],16,Bt)):((0,e.openBlock)(),(0,e.createElementBlock)(`div`,(0,e.mergeProps)({key:1},(0,e.unref)(n),{class:[`pointer-events-none absolute z-[4]`,t.surface===`grid`?`inset-x-0 bottom-0 flex justify-center px-6`:`bottom-[1.8rem] left-1/2 -translate-x-1/2 max-[720px]:bottom-[1.3rem]`]}),[(0,e.renderSlot)(r.$slots,`default`,{},()=>[(0,e.createElementVNode)(`span`,{"data-testid":`vibe-empty-state-badge`,"data-surface":t.surface,class:(0,e.normalizeClass)([`inline-flex items-center border border-white/14 backdrop-blur-[18px]`,t.surface===`grid`?`bg-black/55 px-4 py-3 text-[0.82rem] font-medium tracking-[0.08em] text-[#f7f1ea]/72`:`w-auto bg-black/40 px-5 py-3 text-[0.82rem] font-medium tracking-[0.08em] text-[#f7f1ea]/74 max-[720px]:w-[calc(100%-2.5rem)] max-[720px]:justify-center`])},(0,e.toDisplayString)(t.message),11,Vt)])],16))}}),Ut={class:`relative h-full min-h-0 overflow-hidden bg-[#05060a] text-[#f7f1ea]`},Wt={key:0,class:`relative h-full min-h-0`},Gt=[`data-item-id`,`data-occurrence-key`,`data-index`,`data-active`,`aria-hidden`],Kt={key:0,"data-testid":`vibe-asset-spinner`,class:`pointer-events-none absolute inset-0 z-[2] grid place-items-center`},qt={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]`},Jt=[`data-kind`],Yt={class:`grid justify-items-center gap-4 border border-white/14 bg-black/45 px-8 py-7 text-center backdrop-blur-[18px]`},Xt={class:`m-0 text-[0.82rem] font-bold uppercase tracking-[0.28em] text-[#f7f1ea]/70`},Zt=[`onClick`],Qt=[`src`,`alt`,`onLoad`,`onError`],$t=[`loop`,`src`,`preload`,`onClick`,`onCanplay`,`onDurationchange`,`onEnded`,`onError`,`onLoadstart`,`onLoadedmetadata`,`onPause`,`onPlay`,`onPlaying`,`onSeeking`,`onSeeked`,`onStalled`,`onTimeupdate`,`onWaiting`],en={class:`relative grid aspect-square w-[clamp(320px,46vw,560px)] max-w-[calc(100vw-2.5rem)] place-items-center`},tn=[`aria-label`,`disabled`,`onClick`],nn={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]`},rn={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]`},an={key:0,"data-testid":`vibe-asset-spinner`,class:`pointer-events-none absolute inset-0 z-[3] grid place-items-center`},on={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]`},sn=[`data-kind`],cn={class:`m-0 text-[0.82rem] font-bold uppercase tracking-[0.28em] text-[#f7f1ea]/70`},ln=[`onClick`],un=[`src`,`preload`,`onCanplay`,`onDurationchange`,`onError`,`onLoadstart`,`onLoadedmetadata`,`onPause`,`onPlay`,`onPlaying`,`onSeeking`,`onSeeked`,`onStalled`,`onTimeupdate`,`onWaiting`],dn={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`},fn={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]`},pn={key:0,"data-testid":`vibe-fullscreen-overlay`,class:`pointer-events-none absolute inset-0 z-[6]`},mn={class:`h-full w-full`},hn={key:1,"data-testid":`vibe-forward-fill-placeholder`,class:`grid h-full min-h-0 place-items-center px-6 text-center`},gn={class:`grid justify-items-center gap-4 border border-white/14 bg-black/40 px-8 py-7 backdrop-blur-[18px]`},_n={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)]`},vn={class:`m-0 text-[0.78rem] font-bold uppercase tracking-[0.24em] text-[#f7f1ea]/72`},yn={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]`},bn={class:`h-full min-h-0 overflow-y-auto overscroll-y-contain`},xn={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]`},Sn={class:`h-full min-h-0 overflow-y-auto overscroll-y-contain`},Cn=1280,wn=768,Tn=(0,e.defineComponent)({__name:`FullscreenSurface`,props:{active:{type:Boolean,default:!0},activeIndex:{default:0},emptyStateMode:{default:`inline`},errorMessage:{default:null},hasNextPage:{type:Boolean,default:!1},items:{},loading:{type:Boolean,default:!1},loopFullscreenVideo:{type:Boolean,default:!0},paginationDetail:{default:null},phase:{default:null},reportAssetError:{type:[Function,null],default:null},reportAssetLoad:{type:[Function,null],default:null},showDominantImageTone:{type:Boolean,default:!0},showBackToList:{type:Boolean,default:!1},showEndBadge:{type:Boolean,default:!0},showStatusBadges:{type:Boolean,default:!0}},emits:[`back-to-list`,`update:activeIndex`],setup(t,{emit:n}){let r=t,i=(0,e.useSlots)(),a=n,o=jt(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`?Cn:window.innerWidth||Cn),c=rt({active:(0,e.toRef)(r,`active`),items:o.items,resolvedActiveIndex:o.resolvedActiveIndex,viewer:o}),l=(0,e.computed)(()=>Ft(o.activeItem.value?.type??`image`)),{activeSlideToneStyle:u,activeStageToneStyle:d,updateFromImageElement:f}=zt({activeItem:o.activeItem,getItemKey:c.getItemKey,isImageReady:o.isImageReady,showDominantImageTone:(0,e.toRef)(r,`showDominantImageTone`)}),p=(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]`),m=(0,e.computed)(()=>!!o.activeMediaItem.value&&!o.activeAssetErrorKind.value),y=(0,e.computed)(()=>s.value<wn?`vertical`:`horizontal`),b=(0,e.computed)(()=>m.value?`pb-[5.75rem] max-[720px]:pb-[7rem]`:``),x=(0,e.computed)(()=>r.activeIndex>=r.items.length&&(r.loading||r.hasNextPage)),S=(0,e.computed)(()=>r.hasNextPage?`Loading more items`:o.statusMessage.value??`Loading more items`),C=(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}),w=(0,e.computed)(()=>!C.value||!i[`fullscreen-header-actions`]?[]:i[`fullscreen-header-actions`](C.value)),T=(0,e.computed)(()=>!C.value||!i[`fullscreen-aside`]?[]:i[`fullscreen-aside`](C.value)),E=(0,e.computed)(()=>!r.showStatusBadges||!C.value||!o.statusKind.value||!o.statusMessage.value?null:{...C.value,kind:o.statusKind.value,message:o.statusMessage.value}),D=(0,e.computed)(()=>!E.value||!i[`fullscreen-status`]?[]:i[`fullscreen-status`](E.value)),O=(0,e.computed)(()=>({gridTemplateColumns:j.value?`minmax(0, 1fr) 22rem`:`minmax(0, 1fr) 0rem`,transition:`grid-template-columns 320ms cubic-bezier(0.22, 1, 0.36, 1)`})),k=(0,e.computed)(()=>it(w.value)),A=(0,e.computed)(()=>it(T.value)),j=(0,e.computed)(()=>A.value&&s.value>=Cn),M=(0,e.computed)(()=>A.value&&!j.value),N=(0,e.computed)(()=>it(D.value)),{emptyStateProps:P,showBadgeEmptyState:F,showCustomEmptyState:I,showInlineEmptyState:L}=st({emptyStateMode:(0,e.toRef)(r,`emptyStateMode`),itemCount:(0,e.computed)(()=>r.items.length),loading:(0,e.toRef)(r,`loading`),renderSlot:i[`empty-state`],surface:`fullscreen`});(0,e.onMounted)(()=>{window.addEventListener(`resize`,R)}),(0,e.onBeforeUnmount)(()=>{window.removeEventListener(`resize`,R)});function R(){s.value=window.innerWidth||Cn}function z(e,t,n){c.settleBackgroundPreload(t),o.onImageLoad(t,n);let r=e.currentTarget;r instanceof HTMLImageElement&&K(t,r)}async function B(e,t){c.settleBackgroundPreload(e),await o.onImageError(e,t)}function V(e,t){c.registerImageElement(e,t),o.registerImageElement(e,t),t instanceof HTMLImageElement&&K(e,t)}function H(e,t){c.registerMediaElement(e,t),o.registerVideoElement(e,t)}function U(e,t){c.registerMediaElement(e,t),o.registerAudioElement(e,t)}async function W(e,t){c.settleBackgroundPreload(e),await o.onMediaError(e,t)}function G(e,t){o.onMediaEvent(e,t);let n=t.currentTarget,r=typeof HTMLMediaElement>`u`?1:HTMLMediaElement.HAVE_METADATA;n instanceof HTMLMediaElement&&n.readyState>=r&&c.settleBackgroundPreload(e)}function K(e,t){f(e,t)}function q(e,t){if(G(t,e),!r.loopFullscreenVideo)return;let n=e.currentTarget;if(!(n instanceof HTMLVideoElement))return;try{n.currentTime=0}catch{}let i=n.play();i&&typeof i.catch==`function`&&i.catch(()=>{})}return(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Ut,[(0,e.createElementVNode)(`div`,{class:(0,e.normalizeClass)([`absolute inset-0 transition-[background] duration-200`,l.value]),style:(0,e.normalizeStyle)((0,e.unref)(d))},null,6),(0,e.createElementVNode)(`div`,{class:`relative z-[1] grid h-full min-h-0`,style:(0,e.normalizeStyle)(O.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).activeItem.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Wt,[((0,e.openBlock)(!0),(0,e.createElementBlock)(e.Fragment,null,(0,e.renderList)((0,e.unref)(o).renderedItems.value,({item:i,index:a})=>((0,e.openBlock)(),(0,e.createElementBlock)(`article`,{key:(0,e.unref)(c).getItemKey(i),"data-testid":`vibe-slide`,"data-item-id":i.id,"data-occurrence-key":(0,e.unref)(c).getItemKey(i),"data-index":a,"data-active":a===(0,e.unref)(o).resolvedActiveIndex.value,"aria-hidden":a===(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`,a===(0,e.unref)(o).resolvedActiveIndex.value?`pointer-events-auto`:`pointer-events-none`]),style:(0,e.normalizeStyle)((0,e.unref)(o).getSlideStyle(a))},[(0,e.createElementVNode)(`div`,{class:(0,e.normalizeClass)([`absolute inset-0 opacity-85`,(0,e.unref)(It)(i.type)]),style:(0,e.normalizeStyle)(a===(0,e.unref)(o).resolvedActiveIndex.value&&i.type===`image`?(0,e.unref)(u):void 0)},null,6),(0,e.unref)(o).isVisual(i)?((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`,a===(0,e.unref)(o).resolvedActiveIndex.value?b.value:``])},[(0,e.unref)(c).isAssetLoading(a,i)?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Kt,[(0,e.createElementVNode)(`span`,qt,[(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),(0,e.unref)(c).isAssetErrored(a,i)?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:1,"data-testid":`vibe-asset-error`,"data-kind":(0,e.unref)(c).getAssetErrorKind(i),class:`grid h-full w-full place-items-center`},[(0,e.createElementVNode)(`div`,Yt,[(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`,Xt,(0,e.toDisplayString)((0,e.unref)(c).getAssetErrorLabel(i)),1),(0,e.unref)(o).canRetryAsset((0,e.unref)(c).getItemKey(i))?((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((0,e.unref)(c).getItemKey(i)),[`stop`])},` Retry `,8,Zt)):(0,e.createCommentVNode)(``,!0)])],8,Jt)):i.type===`image`?((0,e.openBlock)(),(0,e.createElementBlock)(`img`,{key:(0,e.unref)(o).getAssetRenderKey((0,e.unref)(c).getItemKey(i)),src:(0,e.unref)(c).getFullscreenImageSource(a,i),alt:i.title??``,crossorigin:`anonymous`,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((0,e.unref)(c).getItemKey(i))?`opacity-100`:`opacity-0`]),ref_for:!0,ref:t=>V((0,e.unref)(c).getItemKey(i),t),onLoad:t=>z(t,(0,e.unref)(c).getItemKey(i),i.url),onError:t=>B((0,e.unref)(c).getItemKey(i),i.url)},null,42,Qt)):((0,e.openBlock)(),(0,e.createElementBlock)(`video`,{key:(0,e.unref)(o).getAssetRenderKey((0,e.unref)(c).getItemKey(i)),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((0,e.unref)(c).getItemKey(i))?`opacity-100`:`opacity-0`]),playsinline:``,loop:r.loopFullscreenVideo,src:(0,e.unref)(c).getFullscreenMediaSource(a,i),preload:(0,e.unref)(c).getFullscreenMediaPreload(a),ref_for:!0,ref:t=>H((0,e.unref)(c).getItemKey(i),t),onClick:(0,e.withModifiers)(t=>(0,e.unref)(o).onVideoClick(t,(0,e.unref)(c).getItemKey(i)),[`stop`]),onCanplay:t=>G((0,e.unref)(c).getItemKey(i),t),onDurationchange:t=>G((0,e.unref)(c).getItemKey(i),t),onEnded:t=>q(t,(0,e.unref)(c).getItemKey(i)),onError:t=>W((0,e.unref)(c).getItemKey(i),i.url),onLoadstart:t=>G((0,e.unref)(c).getItemKey(i),t),onLoadedmetadata:t=>G((0,e.unref)(c).getItemKey(i),t),onPause:t=>G((0,e.unref)(c).getItemKey(i),t),onPlay:t=>G((0,e.unref)(c).getItemKey(i),t),onPlaying:t=>G((0,e.unref)(c).getItemKey(i),t),onSeeking:t=>G((0,e.unref)(c).getItemKey(i),t),onSeeked:t=>G((0,e.unref)(c).getItemKey(i),t),onStalled:t=>G((0,e.unref)(c).getItemKey(i),t),onTimeupdate:t=>G((0,e.unref)(c).getItemKey(i),t),onWaiting:t=>G((0,e.unref)(c).getItemKey(i),t)},null,42,$t))],2)):(0,e.unref)(o).isAudio(i)?((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`,a===(0,e.unref)(o).resolvedActiveIndex.value?b.value:``])},[(0,e.createElementVNode)(`div`,en,[(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[(0,e.unref)(c).getItemKey(i)]?.paused??!0?(0,e.unref)(c).getMediaActionLabel(`Play`,i):(0,e.unref)(c).getMediaActionLabel(`Pause`,i),disabled:!!(0,e.unref)(c).getAssetErrorKind(i),onClick:t=>(0,e.unref)(o).onAudioCoverClick(t,(0,e.unref)(c).getItemKey(i))},[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`,nn,[(0,e.renderSlot)(t.$slots,`item-icon`,{icon:(0,e.unref)(Ue)(i.type),item:i},()=>[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(Ue)(i.type)),{class:`h-6 w-6 stroke-[1.9]`,"aria-hidden":`true`}))])]),(0,e.createElementVNode)(`span`,rn,[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(o).mediaStates.value[(0,e.unref)(c).getItemKey(i)]?.paused??!0?(0,e.unref)(_):(0,e.unref)(g)),{class:`h-4 w-4 stroke-2`,"aria-hidden":`true`}))])],8,tn),(0,e.unref)(c).isAssetLoading(a,i)?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,an,[(0,e.createElementVNode)(`span`,on,[(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),(0,e.unref)(c).getAssetErrorKind(i)?((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":(0,e.unref)(c).getAssetErrorKind(i),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`,cn,(0,e.toDisplayString)((0,e.unref)(c).getAssetErrorLabel(i)),1),(0,e.unref)(o).canRetryAsset((0,e.unref)(c).getItemKey(i))?((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((0,e.unref)(c).getItemKey(i)),[`stop`])},` Retry `,8,ln)):(0,e.createCommentVNode)(``,!0)],8,sn)],64)):(0,e.createCommentVNode)(``,!0)]),((0,e.openBlock)(),(0,e.createElementBlock)(`audio`,{key:(0,e.unref)(o).getAssetRenderKey((0,e.unref)(c).getItemKey(i)),src:(0,e.unref)(c).getFullscreenMediaSource(a,i),preload:(0,e.unref)(c).getFullscreenMediaPreload(a),class:`pointer-events-none absolute h-px w-px opacity-0`,ref_for:!0,ref:t=>U((0,e.unref)(c).getItemKey(i),t),onCanplay:t=>G((0,e.unref)(c).getItemKey(i),t),onDurationchange:t=>G((0,e.unref)(c).getItemKey(i),t),onError:t=>W((0,e.unref)(c).getItemKey(i),i.url),onLoadstart:t=>G((0,e.unref)(c).getItemKey(i),t),onLoadedmetadata:t=>G((0,e.unref)(c).getItemKey(i),t),onPause:t=>G((0,e.unref)(c).getItemKey(i),t),onPlay:t=>G((0,e.unref)(c).getItemKey(i),t),onPlaying:t=>G((0,e.unref)(c).getItemKey(i),t),onSeeking:t=>G((0,e.unref)(c).getItemKey(i),t),onSeeked:t=>G((0,e.unref)(c).getItemKey(i),t),onStalled:t=>G((0,e.unref)(c).getItemKey(i),t),onTimeupdate:t=>G((0,e.unref)(c).getItemKey(i),t),onWaiting:t=>G((0,e.unref)(c).getItemKey(i),t)},null,40,un))],2)):((0,e.openBlock)(),(0,e.createElementBlock)(`div`,dn,[(0,e.createElementVNode)(`div`,fn,[(0,e.renderSlot)(t.$slots,`item-icon`,{icon:(0,e.unref)(Ue)(i.type),item:i},()=>[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(Ue)(i.type)),{class:`h-6 w-6 stroke-[1.9]`,"aria-hidden":`true`}))])])]))],14,Gt))),128)),C.value&&i[`fullscreen-overlay`]?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,pn,[(0,e.createElementVNode)(`div`,mn,[(0,e.renderSlot)(t.$slots,`fullscreen-overlay`,(0,e.normalizeProps)((0,e.guardReactiveProps)(C.value)))])])):(0,e.createCommentVNode)(``,!0),(0,e.unref)(o).activeItem.value?((0,e.openBlock)(),(0,e.createBlock)(Be,{key:1,"current-index":(0,e.unref)(o).resolvedActiveIndex.value,loading:r.loading,"pagination-detail":(0,e.unref)(o).paginationDetail.value,"show-back-to-list":r.showBackToList,"show-end-badge":r.showEndBadge&&(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},[k.value&&C.value?{name:`actions`,fn:(0,e.withCtx)(()=>[(0,e.renderSlot)(t.$slots,`fullscreen-header-actions`,(0,e.normalizeProps)((0,e.guardReactiveProps)(C.value)))]),key:`0`}:void 0]),1032,[`current-index`,`loading`,`pagination-detail`,`show-back-to-list`,`show-end-badge`,`title`,`total`])):(0,e.createCommentVNode)(``,!0),m.value?((0,e.openBlock)(),(0,e.createBlock)(Ae,{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),muted:(0,e.unref)(o).activeMediaState.value.muted,progress:(0,e.unref)(o).activeMediaProgress.value,volume:(0,e.unref)(o).activeMediaState.value.volume,"volume-control-layout":y.value,onSeekInput:(0,e.unref)(o).onMediaSeekInput,onVolumeInput:(0,e.unref)(o).onMediaVolumeInput,onVolumeToggle:(0,e.unref)(o).onMediaVolumeToggle},null,8,[`current-time`,`current-time-label`,`duration`,`duration-label`,`muted`,`progress`,`volume`,`volume-control-layout`,`onSeekInput`,`onVolumeInput`,`onVolumeToggle`])):(0,e.createCommentVNode)(``,!0),E.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:3,class:(0,e.normalizeClass)([`absolute left-1/2 z-[4] -translate-x-1/2`,p.value])},[N.value?(0,e.renderSlot)(t.$slots,`fullscreen-status`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},E.value))):((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:1,"data-testid":`vibe-fullscreen-status-badge`,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`,E.value.kind===`end`?`border-amber-300/35 text-amber-200`:E.value.kind===`failed`?`border-rose-400/45 text-rose-100`:``])},(0,e.toDisplayString)(E.value.message),3))],2)):(0,e.createCommentVNode)(``,!0)])):x.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,hn,[(0,e.createElementVNode)(`div`,gn,[(0,e.createElementVNode)(`span`,_n,[(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.createElementVNode)(`p`,vn,(0,e.toDisplayString)(S.value),1)])])):(0,e.unref)(L)&&(0,e.unref)(P)?((0,e.openBlock)(),(0,e.createBlock)(Ht,{key:2,message:(0,e.unref)(P).message,mode:(0,e.unref)(P).mode,surface:(0,e.unref)(P).surface},{default:(0,e.withCtx)(()=>[(0,e.unref)(I)?(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},(0,e.unref)(P)))):(0,e.createCommentVNode)(``,!0)]),_:3},8,[`message`,`mode`,`surface`])):(0,e.createCommentVNode)(``,!0),(0,e.unref)(F)&&(0,e.unref)(P)?((0,e.openBlock)(),(0,e.createBlock)(Ht,{key:3,message:(0,e.unref)(P).message,mode:(0,e.unref)(P).mode,surface:(0,e.unref)(P).surface},{default:(0,e.withCtx)(()=>[(0,e.unref)(I)?(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},(0,e.unref)(P)))):(0,e.createCommentVNode)(``,!0)]),_:3},8,[`message`,`mode`,`surface`])):(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)(()=>[j.value&&C.value?((0,e.openBlock)(),(0,e.createElementBlock)(`aside`,yn,[(0,e.createElementVNode)(`div`,bn,[(0,e.renderSlot)(t.$slots,`fullscreen-aside`,(0,e.normalizeProps)((0,e.guardReactiveProps)(C.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)(()=>[M.value&&C.value?((0,e.openBlock)(),(0,e.createElementBlock)(`aside`,xn,[(0,e.createElementVNode)(`div`,Sn,[(0,e.renderSlot)(t.$slots,`fullscreen-aside`,(0,e.normalizeProps)((0,e.guardReactiveProps)(C.value)))])])):(0,e.createCommentVNode)(``,!0)]),_:3})]))}}),En=1,Dn=.5;function On(e){if(e.type!==`image`&&e.type!==`video`)return{width:En,height:En,source:`fallback`};let t=e.preview?.width,n=e.preview?.height;if(Fn(t)&&Fn(n)){let r=In(e,t,n);return{width:r.width,height:r.height,source:`preview`}}if(Fn(e.width)&&Fn(e.height)){let t=In(e,e.width,e.height);return{width:t.width,height:t.height,source:`original`}}return{width:En,height:En,source:`fallback`}}function kn(e,t){return!e||e<=0||!t||t<=0?1:Math.max(1,Math.floor(e/t))}function An(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 jn(e,t){let n=On(e);return n.height/n.width*t}function Mn(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(P(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=jn(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 Nn(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 Pn(e,t,n){let r=new Map;for(let i of e){let e=t.get(P(i));if(e==null)continue;let a=n[e];a&&r.set(P(i),a)}return r}function Fn(e){return typeof e==`number`&&Number.isFinite(e)&&e>0}function In(e,t,n){return e.type!==`image`||n/t>=Dn?{width:t,height:n}:{width:t,height:t}}var Ln=300,Rn=600,zn=40,Bn=300,Vn=400;function Hn(e,t){return t===`top`?[...e].reverse():e}function Un(e){return e<=0?Rn:Rn+Math.min((e-1)*zn,Vn)}function Wn(){return Bn}function Gn(e){let t=e.itemHeight>0?e.itemHeight:e.columnWidth;return e.direction===`top`?e.scrollTop-t:e.scrollTop+e.viewportHeight+t}function Kn(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 Set),c=(0,e.ref)(new Map),l=(0,e.ref)(new Map),u=(0,e.ref)(new Set),d=new Set,f=new Set,p=(0,e.computed)(()=>Array.from(o.value.values()));(0,e.watch)(t.visibleIndices,e=>{if(!e.length)return;let o=[];for(let r of e){let e=t.items.value[r]?P(t.items.value[r]):null;!e||!n.value.has(e)||d.has(e)||(d.add(e),o.push(e))}if(!o.length)return;let s=Hn(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*zn,Vn));i.value=c,qn(()=>{let e=new Set(r.value);for(let t of o)e.add(t);r.value=e}),Jn(()=>{let e=new Set(n.value);for(let t of o)e.delete(t);n.value=e,x(()=>{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),d.delete(r);r.value=e,i.value=t,a.value=n},Un(o.length))})},{flush:`post`}),(0,e.watch)(()=>t.items.value.map(e=>P(e)),e=>{if(!e.length||!o.value.size)return;let t=new Set(e),n=null,r=null;for(let e of o.value.keys())t.has(e)&&(n||=new Map(o.value),r||=new Set(s.value),n.delete(e),r.delete(e));n&&(o.value=n),r&&(s.value=r)}),(0,e.onBeforeUnmount)(()=>{for(let e of f)clearTimeout(e);f.clear()});function m(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=P(n);r.add(e),i.set(e,t)}n.value=r,a.value=i}function h(e){if(!e.length)return;let t=new Map(o.value),c=new Set(n.value),l=new Set(r.value),u=new Map(i.value),f=new Map(a.value),p=[];for(let n of e){let e=P(n.item);p.push(e),t.set(e,n),c.delete(e),l.delete(e),u.delete(e),f.delete(e),d.delete(e)}o.value=t,n.value=c,r.value=l,i.value=u,a.value=f,qn(()=>{let e=new Set(s.value);for(let t of p)e.add(t);s.value=e}),x(()=>{let e=new Map(o.value),t=new Set(s.value);for(let n of p)e.delete(n),t.delete(n);o.value=e,s.value=t},Bn)}function g(e,n,r=Ln){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;c.value=i,u.value=new Set;let o=new Map(l.value);for(let e of a)o.set(e,r);l.value=o,qn(()=>{u.value=new Set(a),qn(()=>{c.value=new Map})}),x(()=>{u.value=new Set;let e=new Map(l.value);for(let t of a)e.delete(t);l.value=e},r)}function _(e){if(r.value.has(e))return`transform ${Rn}ms ease-out`;if(u.value.has(e))return`transform ${l.value.get(e)??Ln}ms ease-out`}function v(e){if(!r.value.has(e))return;let t=i.value.get(e)??0;return t>0?`${t}ms`:void 0}function y(e){let r=t.items.value[e],i=t.positions.value[e]??{x:0,y:0},o=t.heights.value[e]??t.columnWidth.value,s=r?P(r):null,l=s?c.value.get(s)??{dx:0,dy:0}:{dx:0,dy:0},u=s?a.value.get(s)??`bottom`:`bottom`,d=s&&n.value.has(s)?Gn({columnWidth:t.columnWidth.value,direction:u,itemHeight:o,scrollTop:t.scrollTop.value,viewportHeight:t.viewportHeight.value}):i.y;return`translate3d(${i.x+l.dx}px, ${d+l.dy}px, 0)`}function b(e){let n=P(e),r=o.value.get(n);if(!r)return{opacity:`0`,transform:`translate3d(0, 0, 0) scale(0.96)`,transition:`opacity ${Bn}ms ease-out, transform ${Bn}ms ease-out`};let i=s.value.has(n);return{height:`${r.height}px`,opacity:i?`0`:`1`,transform:`translate3d(${r.position.x}px, ${r.position.y}px, 0) scale(${i?`0.96`:`1`})`,transition:`opacity ${Bn}ms ease-out, transform ${Bn}ms ease-out`,width:`${t.columnWidth.value}px`}}function x(e,t){let n=setTimeout(()=>{f.delete(n),e()},t);f.add(n)}return{getCardTransform:y,getCardTransition:_,getCardTransitionDelay:v,getLeavingCardStyle:b,leavingItems:p,markEnter:m,markLeave:h,playFlipMoveAnimation:g}}function qn(e){if(typeof requestAnimationFrame==`function`){requestAnimationFrame(()=>e());return}setTimeout(e,0)}function Jn(e){qn(()=>qn(e))}function Yn(e,t){return e?.clientHeight||Math.round(e?.getBoundingClientRect().height??0)||t||window.innerHeight||1}function Xn(e,t,n){return e?.clientWidth||Math.round(e?.getBoundingClientRect().width??0)||t||window.innerWidth||n}function Zn(e,t,n,r){return(e?.scrollHeight??r)-(t+n)}function Qn(e,t){return{height:`${e}px`,transform:`translate3d(0, ${t}px, 0)`}}var $n=250,er=1e3;function tr(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+$n,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.interactionLocked?.value&&!t.loading.value&&!o.value&&typeof t.requestPage.value==`function`}function _(){return t.hasPage.value&&n.value&&i.value>a.value&&!t.interactionLocked?.value&&!t.loading.value&&!o.value&&typeof t.requestPage.value==`function`}function v(){s.value=!1,y(er)}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 nr=600,Q=24,$=16,rr=300,ir=200,ar=200,or=Q+$,sr=200,cr=300,lr=24,ur=48,dr=500,fr=1e3;function pr(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||rr),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.ref)(null),p=(0,e.ref)(!1),m=(0,e.computed)(()=>Math.max(rr,a.value-Q*2)),h=(0,e.computed)(()=>kn(m.value,rr)),g=(0,e.computed)(()=>An(m.value,h.value,rr,$)),_=(0,e.computed)(()=>mr(t.activeIndex.value,0,Math.max(0,t.items.value.length-1))),v=(0,e.computed)(()=>Nn({itemCount:t.items.value.length,viewportHeight:i.value,scrollTop:r.value,overscanPx:ir,bucketPx:nr,buckets:c.value})),y=(0,e.computed)(()=>v.value.map(e=>({item:t.items.value[e],index:e}))),b=(0,e.computed)(()=>{let e=l.value+Q*2,t=d.value??0;return Math.max(e,t,i.value)+sr}),x=(0,e.computed)(()=>t.hasNextPage.value||t.allowExhaustedNextPageRefresh.value),S=(0,e.computed)(()=>gr({active:t.active.value,maxScrollTop:ne(),progressDistancePx:r.value,thresholdPx:ar,triggerEnabled:x.value})),C=(0,e.computed)(()=>t.items.value.length>0?`${_.value+1} / ${t.items.value.length}`:`0 / 0`),w=(0,e.computed)(()=>hr({active:t.active.value,maxScrollTop:ne(),progressDistancePx:r.value,thresholdPx:or,triggerEnabled:t.hasPreviousPage.value})),T=(0,e.computed)(()=>Math.max(0,i.value-lr*2)),E=(0,e.computed)(()=>b.value>i.value+1&&T.value>0),D=(0,e.computed)(()=>{if(!E.value)return 0;let e=i.value/b.value*T.value;return Math.min(T.value,Math.max(ur,e))}),O=(0,e.computed)(()=>{if(!E.value)return lr;let e=Math.max(0,b.value-i.value);return lr+Math.max(0,T.value-D.value)*(e>0?mr(r.value/e,0,1):0)}),k=Kn({items:t.items,visibleIndices:v,positions:o,heights:s,indexById:u,columnWidth:g,scrollTop:r,viewportHeight:i}),A=tr({direction:`top`,getAnimationLockMs(e){return Math.max(dr,Un(e))+fr},hasPage:t.hasPreviousPage,interactionLocked:p,isAtBoundary(){return r.value<=or},loading:t.loading,requestPage:t.requestPreviousPage}),j=tr({direction:`bottom`,getAnimationLockMs(e){return Un(e)+fr},hasPage:x,interactionLocked:p,isAtBoundary(){return te()<=ar},loading:t.loading,requestPage:t.requestNextPage}),M=null,N=0,F=null,I=null,L=!1;(0,e.watch)([()=>t.items.value,h,g],async([n],[i=[]])=>{let a=n.map(e=>P(e)),s=i??[],c=s.map(e=>P(e)),l=Pn(s,u.value,o.value),d=ae(s),f=new Set(c),p=new Set(a),m=n.filter(e=>!f.has(P(e))),h=s.flatMap(e=>{let t=P(e);if(p.has(t))return[];let n=l.get(t),r=d.get(t);return!n||r==null?[]:[{height:r,item:e,position:n}]}),g=a.length>c.length&&c.length>0&&a[0]!==c[0],v=n.length===0&&s.length>0&&h.length>0&&r.value>0,y=h.length>0&&r.value>Q+$,b=g&&r.value>Q+$?n[_.value]:null,x=b?P(b):null;y&&G(Wn()+fr),v&&W(),R(),h.length>0&&k.markLeave(h),m.length>0&&(k.markEnter(m,g?`top`:`bottom`),g?A.onItemsMutated(m.length):j.onItemsMutated(m.length)),k.playFlipMoveAnimation(l,new Set(m.map(e=>P(e))),g?dr:void 0),x?(await(0,e.nextTick)(),U(x,l)):t.active.value&&c.length>0&&q()},{immediate:!0}),(0,e.watch)([()=>t.pendingAppendItems.value.map(e=>P(e)),h,g,i],([e])=>{se(),e.length&&(d.value=ie([...t.items.value,...t.pendingAppendItems.value]),oe())},{immediate:!0}),(0,e.watch)(()=>t.active.value,async(t,a)=>{let o=n.value;if(!o)return;if(!t){f.value=o.scrollTop;return}if(a!==!1||f.value==null)return;await(0,e.nextTick)();let s=Math.max(0,b.value-i.value),c=mr(f.value,0,s);o.scrollTop=c,r.value=c,A.syncBoundary(),j.syncBoundary()}),(0,e.watch)(()=>t.loading.value,async n=>{!n&&!t.pendingAppendItems.value.length&&!F&&!L&&(d.value=null),A.onLoadingChange(n),j.onLoadingChange(n),await(0,e.nextTick)()}),(0,e.onMounted)(async()=>{Y(),await(0,e.nextTick)(),_.value>0?H(_.value,`center`):K(),A.syncBoundary(),j.syncBoundary(),typeof ResizeObserver<`u`?(M=new ResizeObserver(()=>{Y()}),n.value&&M.observe(n.value)):window.addEventListener(`resize`,Y)}),(0,e.onBeforeUnmount)(()=>{M?.disconnect(),M=null,window.removeEventListener(`resize`,Y),se(),ce(),N&&=(cancelAnimationFrame(N),0)});function R(){let e=Mn(t.items.value,{columnCount:h.value,columnWidth:g.value,gapX:$,gapY:$,bucketPx:nr});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 z(){t.active.value&&(r.value=n.value?.scrollTop??0,i.value=X(),A.syncBoundary(),j.syncBoundary(),J(),!q()&&(N||=requestAnimationFrame(()=>{N=0,K()})))}function B(e){t.active.value&&(A.onWheel(e),j.onWheel(e),J())}function V(e){let n=t.items.value[e],r=n?P(n):``;return{height:`${s.value[e]??g.value}px`,width:`${g.value}px`,transition:r?k.getCardTransition(r):void 0,transitionDelay:r?k.getCardTransitionDelay(r):void 0,transform:k.getCardTransform(e)}}function H(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,b.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=mr(u,0,d),r.value=a.scrollTop,K()}function U(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 W(){let e=n.value;if(!e){r.value=0;return}e.scrollTop=0,r.value=0,A.syncBoundary(),j.syncBoundary()}function G(e){ce(),p.value=!0,I=setTimeout(()=>{I=null,p.value=!1},Math.max(0,e))}function K(){if(!v.value.length||q())return;let e=r.value+i.value/2,n=_.value,a=1/0;for(let t of v.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 q(){let e=r.value<=or,n=te()<=ar;return e?(t.setActiveIndex(0),!0):n?(t.setActiveIndex(Math.max(0,t.items.value.length-1)),!0):!1}function J(){A.maybeRequestPage(),j.maybeRequestPage()}function Y(){i.value=X(),a.value=ee()}function X(){return Yn(n.value,i.value)}function ee(){return Xn(n.value,a.value,rr)}function te(){return Zn(n.value,r.value,i.value,b.value)}function ne(){let e=Math.max(n.value?.scrollHeight??0,b.value);return Math.max(0,e-i.value)}function re(){return Qn(D.value,O.value)}function ie(e){return e.length?Mn(e,{columnCount:h.value,columnWidth:g.value,gapX:$,gapY:$,bucketPx:nr}).contentHeight+Q*2:0}function ae(e){let t=new Map;for(let n of e){let e=P(n),r=u.value.get(e);if(r==null)continue;let i=s.value[r];i!=null&&t.set(e,i)}return t}function oe(){let n=t.commitPendingAppend.value;typeof n==`function`&&(F=setTimeout(async()=>{F=null,L=!0;try{if(!t.pendingAppendItems.value.length)return;await n(),await(0,e.nextTick)(),await(0,e.nextTick)()}finally{d.value=null,L=!1}},cr))}function se(){F&&=(clearTimeout(F),null)}function ce(){I&&(clearTimeout(I),I=null,p.value=!1)}return{columnWidth:g,containerHeight:b,getCardStyle:V,getLeavingCardStyle:k.getLeavingCardStyle,getScrollbarThumbStyle:re,leavingItems:k.leavingItems,nextBoundaryLoadProgress:S,onScroll:z,onWheel:B,paginationLabel:C,previousBoundaryLoadProgress:w,renderedItems:y,resolvedActiveIndex:_,scrollToIndex:H,showScrollbar:E,scrollViewportRef:n}}function mr(e,t,n){return Math.min(Math.max(e,t),n)}function hr(e){if(!e.active||!e.triggerEnabled)return 0;let t=Math.max(0,e.maxScrollTop-e.thresholdPx);return t<=0?1:mr(1-(e.progressDistancePx-e.thresholdPx)/t,0,1)}function gr(e){if(!e.active||!e.triggerEnabled)return 0;let t=Math.max(0,e.maxScrollTop-e.thresholdPx);return t<=0?1:mr(e.progressDistancePx/t,0,1)}function _r(e){if(e)try{e.removeAttribute(`src`),e.src=``}catch{}}function vr(e){if(e){try{e.currentTime=0}catch{}e.pause();try{e.removeAttribute(`src`),e.load()}catch{}}}function yr(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 br(e){if(!e)return null;try{return new URL(e,window.location.href).href}catch{return e}}var xr=/\.(avif|gif|jpe?g|png|svg|webp)(\?|#|$)/i,Sr=/\.(m4v|mov|mp4|mpeg|ogg|ogv|webm)(\?|#|$)/i,Cr=/^(?:(?:https?:)?\/\/[^/]+)?\/api\/files\/[^/?#]+\/(?:preview|downloaded)(?:\?|#|$)/i;function wr(e){let t=Tr(e),n=t?.url,r=On(e),i=e.title?.trim()||We(e.type);return t?.mediaType===`video`&&typeof n==`string`?{kind:`video`,url:n,width:r.width,height:r.height,label:i}:t?.mediaType===`image`&&typeof n==`string`?{kind:`image`,url:n,width:r.width,height:r.height,label:i}:e.type!==`image`&&e.type!==`video`?{kind:`fallback`,url:null,width:r.width,height:r.height,label:i}:typeof n==`string`&&Dr(e,n)?{kind:`video`,url:n,width:r.width,height:r.height,label:i}:typeof n==`string`&&Er(e,n)?{kind:`image`,url:n,width:r.width,height:r.height,label:i}:{kind:`fallback`,url:null,width:r.width,height:r.height,label:i}}function Tr(e){return e.preview?.url?e.preview:typeof e.url!=`string`||e.url.trim()===``?null:{url:e.url}}function Er(e,t){return e.type!==`image`||typeof t!=`string`?!1:xr.test(t)||Or(t)}function Dr(e,t){return e.type!==`video`||typeof t!=`string`?!1:Sr.test(t)||kr(t)}function Or(e){return/^(https?:\/\/|\/\/|\/(?!\/)|\.{1,2}\/|blob:|data:)/i.test(e)}function kr(e){return Cr.test(e)||/^blob:/i.test(e)||/^data:video\//i.test(e)}function Ar(t){let n=(0,e.ref)(null),r=(0,e.computed)(()=>{let e=typeof t.item.value.healthCheck?.url==`string`?br(t.item.value.healthCheck.url):null;return!e||e===t.attachedAssetUrl.value?null:e}),i=null,a=0,o=new Map;(0,e.watch)(r,(e,t)=>{e!==t&&(n.value=null,l(),a+=1)}),(0,e.watch)([r,t.surfaceActive,t.isInView,t.isReady,t.loadErrorKind],()=>{s()});function s(){let e=r.value;if(!e){l();return}if(!t.surfaceActive.value||!t.isInView.value||!t.isReady.value||t.loadErrorKind.value){l();return}if(o.has(e)){n.value=o.get(e)??null;return}if(i){i.refresh();return}i=qe.request({assetType:`probe`,getPriority:t.getPriority,onGrant(){let e=r.value;if(!e){l();return}let i=++a;xt(e).then(s=>{if(!(i!==a||r.value!==e)){if(o.set(e,s??null),!s){n.value=null;return}n.value=s,t.reportAssetError?.({item:t.item.value,occurrenceKey:P(t.item.value),url:e,kind:s,surface:`grid`})}}).finally(()=>{i===a&&l()})},url:e})}function c(){let e=r.value;return!n.value||!e?!1:(o.delete(e),n.value=null,l(),s(),!0)}function l(){i?.release(),i=null}return{errorKind:n,release:l,retry:c}}var jr=[`aria-label`],Mr={key:0,"data-testid":`vibe-list-card-spinner`,class:`pointer-events-none absolute inset-0 z-[4] grid place-items-center bg-black/18`},Nr={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]`},Pr=[`src`,`alt`],Fr=[`src`],Ir=[`data-kind`],Lr={class:`grid justify-items-center gap-3 px-4 text-center`},Rr={class:`text-[0.68rem] font-bold uppercase tracking-[0.22em] text-[#f7f1ea]/72`},zr={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))]`},Br={class:`inline-flex h-14 w-14 items-center justify-center border border-white/16 bg-black/20`},Vr={class:`pointer-events-none absolute inset-0 z-[3]`},Hr=(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)(()=>wr(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)(!1),d=(0,e.ref)(null),f=(0,e.ref)(null),p=(0,e.ref)(null),m=(0,e.ref)(null),g=(0,e.ref)(null),_=(0,e.ref)(a.value.kind===`fallback`),y=(0,e.computed)(()=>_.value?r.surfaceActive?o.value?a.value.url:null:a.value.url:null),b=(0,e.computed)(()=>r.surfaceActive&&o.value&&(a.value.kind===`image`||a.value.kind===`video`)&&!!a.value.url),x=(0,e.computed)(()=>a.value.kind===`image`&&!!y.value),S=(0,e.computed)(()=>a.value.kind===`video`&&!!y.value),C=Ar({attachedAssetUrl:y,getPriority:G,isInView:o,isReady:l,item:(0,e.computed)(()=>r.item),loadErrorKind:d,reportAssetError:r.reportAssetError,surfaceActive:(0,e.computed)(()=>r.surfaceActive)}),w=(0,e.computed)(()=>C.errorKind.value??d.value),T=(0,e.computed)(()=>!!w.value),E=(0,e.computed)(()=>yt(w.value)),D=(0,e.computed)(()=>b.value&&!d.value&&(!_.value||!l.value)),O=null,k=null,A=new Set;(0,e.watch)([y,()=>a.value.kind],()=>{let e=a.value.kind===`fallback`;l.value=e,u.value=!1,d.value=null,e&&(_.value=!0)}),(0,e.watch)(b,()=>{I()}),(0,e.watch)([o,l,y],()=>{L()}),(0,e.watch)(()=>r.surfaceActive,e=>{if(!e){z(),L();return}requestAnimationFrame(()=>{B(),I(),L()})}),(0,e.onMounted)(()=>{if(!p.value||typeof IntersectionObserver>`u`){m.value=null,o.value=!0,I();return}m.value=p.value.closest(`[data-testid="vibe-list-scroll"]`),O=new IntersectionObserver(e=>{for(let t of e)t.target===p.value&&(r.surfaceActive&&B(t),I(),L())},{root:m.value,threshold:[0,1]}),O.observe(p.value)}),(0,e.onBeforeUnmount)(()=>{R(),C.release(),O?.disconnect(),O=null});function j(){K(f.value)&&(l.value=!0,d.value=null,V(y.value??r.item.url),z())}async function M(){if(!K(f.value))return;let e=y.value??r.item.url;l.value=!1,d.value=`generic`;let t=await bt(e);d.value=t,r.reportAssetError?.({item:r.item,occurrenceKey:P(r.item),url:e,kind:t,surface:`grid`}),z()}function N(){K(g.value)&&(u.value=!0,l.value=!0,d.value=null,V(y.value??r.item.url),z(),L())}function F(){K(g.value)&&(u.value||(l.value=!1))}function I(){if(a.value.kind===`fallback`){R(!1);return}if(!r.surfaceActive){z();return}if(!b.value){R();return}if(_.value||k){k?.refresh();return}k=qe.request({assetType:a.value.kind,getPriority:G,onGrant(){_.value=!0,l.value=!1,d.value=null},url:a.value.url??r.item.url})}function L(){let e=g.value;if(!(!e||a.value.kind!==`video`)){if(w.value){e.pause();return}if(y.value&&o.value&&l.value){e.muted=!0,e.loop=!0,e.playsInline=!0,wt(e);return}try{e.currentTime=0}catch{}e.pause()}}function R(e=!0){_.value=a.value.kind===`fallback`,d.value=null,l.value=a.value.kind===`fallback`,e&&(U(),W()),z()}function z(){k?.release(),k=null}function B(e){let t=p.value;if(!t){o.value=!0;return}o.value=yr(e?.boundingClientRect??t.getBoundingClientRect(),e?.rootBounds??m.value?.getBoundingClientRect()??null)}function V(e){if(!e)return;let t=P(r.item),n=`${t}|${e}`;A.has(n)||(A.add(n),r.reportAssetLoad?.({item:r.item,occurrenceKey:t,surface:`grid`,url:e}))}function H(){if(!E.value||C.retry())return;let e=P(r.item);A.forEach(t=>{t.startsWith(`${e}|`)&&A.delete(t)}),d.value=null,l.value=!1,_.value=!1,z(),I()}function U(){_r(f.value)}function W(){vr(g.value)}function G(){let e=p.value;if(!e)return 1/0;let t=e.getBoundingClientRect();if(m.value){let e=m.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 K(e){let t=br(y.value);return!e||!t?!1:br(`currentSrc`in e&&e.currentSrc||e.getAttribute(`src`))===t}function q(){i(`open`)}function J(){s.value=!0}function Y(e){let t=e.relatedTarget;p.value&&t instanceof Node&&p.value.contains(t)||(s.value=!1)}return(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{ref_key:`rootRef`,ref:p,"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:J,onFocusout:Y,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:q},null,8,jr),D.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Mr,[(0,e.createElementVNode)(`span`,Nr,[(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),x.value&&y.value&&!T.value?((0,e.openBlock)(),(0,e.createElementBlock)(`img`,{key:1,ref_key:`imageRef`,ref:f,src:y.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:j,onError:M},null,42,Pr)):S.value&&y.value&&!T.value?((0,e.openBlock)(),(0,e.createElementBlock)(`video`,{key:2,ref_key:`videoRef`,ref:g,src:y.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:N,onError:M,onLoadstart:F,onPlaying:N,onStalled:F,onWaiting:F},null,42,Fr)):T.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,{key:3,"data-testid":`vibe-list-card-error`,"data-kind":w.value,class:`pointer-events-none 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`,Lr,[(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`,Rr,(0,e.toDisplayString)((0,e.unref)(vt)(w.value)),1),E.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)(H,[`stop`])},` Retry `)):(0,e.createCommentVNode)(``,!0)])],8,Ir)):((0,e.openBlock)(),(0,e.createElementBlock)(`div`,zr,[(0,e.createElementVNode)(`div`,Br,[(0,e.renderSlot)(t.$slots,`item-icon`,{icon:(0,e.unref)(Ue)(r.item.type),item:r.item},()=>[((0,e.openBlock)(),(0,e.createBlock)((0,e.resolveDynamicComponent)((0,e.unref)(Ue)(r.item.type)),{class:`h-6 w-6 stroke-[1.8] text-[#f7f1ea]/78`,"aria-hidden":`true`}))])])])),(0,e.createElementVNode)(`div`,Vr,[(0,e.renderSlot)(t.$slots,`grid-item-overlay`,{active:r.active,focused:s.value,hovered:c.value,index:r.index,item:r.item,openFullscreen:q})])],34))}}),Ur={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)]`},Wr={class:`pointer-events-none absolute inset-x-0 top-0 z-[2] flex justify-end p-6`},Gr={"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]`},Kr={class:`whitespace-nowrap`},qr={key:0,class:`whitespace-nowrap border-l border-white/12 pl-2 text-[#f7f1ea]/56 min-[721px]:pl-3`},Jr=[`data-active`,`data-index`,`data-item-id`,`data-occurrence-key`],Yr=[`data-item-id`],Xr={key:0,class:`pointer-events-none absolute inset-y-0 right-0 z-[3] hidden w-8 min-[1024px]:block`},Zr={key:1,class:`pointer-events-none absolute inset-x-0 bottom-0 z-[2] px-5 pb-5 sm:px-6`},Qr={class:`mx-auto flex w-full justify-center`},$r=(0,e.defineComponent)({__name:`ListSurface`,props:{active:{type:Boolean,default:!0},activeIndex:{default:0},allowExhaustedNextPageRefresh:{type:Boolean,default:!1},commitPendingAppend:{type:[Function,null],default:null},emptyStateMode:{default:`inline`},errorMessage:{default:null},hasNextPage:{type:Boolean,default:!1},hasPreviousPage:{type:Boolean,default:!1},items:{},loading:{type:Boolean,default:!1},pendingAppendItems:{default:()=>[]},paginationDetail:{default:null},phase:{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},showStatusBadges:{type:Boolean,default:!0}},emits:[`boundary-load-progress`,`open-fullscreen`,`update:activeIndex`],setup(t,{emit:n}){let r=t,i=(0,e.useSlots)(),a=n,o=pr({active:(0,e.toRef)(r,`active`),allowExhaustedNextPageRefresh:(0,e.toRef)(r,`allowExhaustedNextPageRefresh`),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`),setActiveIndex(e){a(`update:activeIndex`,e)}}),s=(0,e.computed)(()=>lt({itemCount:r.items.length,loading:r.loading,phase:r.phase})),c=(0,e.computed)(()=>ut({errorMessage:r.errorMessage,hasItems:r.items.length>0,hasNextPage:r.hasNextPage,phase:s.value,surface:`grid`})),l=(0,e.computed)(()=>!r.showStatusBadges||!c.value?null:{activeIndex:o.resolvedActiveIndex.value,kind:c.value.kind,loading:r.loading,message:c.value.message,paginationDetail:r.paginationDetail,total:r.items.length}),u=(0,e.computed)(()=>!l.value||!i[`grid-status`]?[]:i[`grid-status`](l.value)),d=(0,e.computed)(()=>it(u.value)),f=(0,e.computed)(()=>r.items.length+o.leavingItems.value.length),{emptyStateProps:p,showBadgeEmptyState:m,showCustomEmptyState:h,showInlineEmptyState:g}=st({emptyStateMode:(0,e.toRef)(r,`emptyStateMode`),itemCount:f,loading:(0,e.toRef)(r,`loading`),renderSlot:i[`empty-state`],surface:`grid`});return(0,e.watch)([o.nextBoundaryLoadProgress,o.previousBoundaryLoadProgress],([e,t])=>{a(`boundary-load-progress`,{nextBoundaryLoadProgress:e,previousBoundaryLoadProgress:t})},{immediate:!0}),(t,n)=>((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Ur,[(0,e.createElementVNode)(`div`,Wr,[(0,e.createElementVNode)(`span`,Gr,[(0,e.createElementVNode)(`span`,Kr,(0,e.toDisplayString)((0,e.unref)(o).paginationLabel.value),1),r.paginationDetail?((0,e.openBlock)(),(0,e.createElementBlock)(`span`,qr,(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)(P)(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)(P)(n),class:`absolute will-change-transform`,style:(0,e.normalizeStyle)((0,e.unref)(o).getCardStyle(s))},[(0,e.createVNode)(Hr,{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,Jr))),128)),((0,e.openBlock)(!0),(0,e.createElementBlock)(e.Fragment,null,(0,e.renderList)((0,e.unref)(o).leavingItems.value,n=>((0,e.openBlock)(),(0,e.createElementBlock)(`article`,{key:`leaving-${(0,e.unref)(P)(n.item)}`,"data-testid":`vibe-list-card-leaving`,"data-item-id":n.item.id,class:`pointer-events-none absolute z-[2] will-change-[opacity,transform]`,style:(0,e.normalizeStyle)((0,e.unref)(o).getLeavingCardStyle(n.item))},[(0,e.createVNode)(Hr,{active:!1,index:-1,item:n.item,"report-asset-error":r.reportAssetError,"report-asset-load":r.reportAssetLoad,"surface-active":!1},(0,e.createSlots)({_:2},[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:`0`}:void 0]),1032,[`item`,`report-asset-error`,`report-asset-load`])],12,Yr))),128)),(0,e.unref)(g)&&(0,e.unref)(p)?((0,e.openBlock)(),(0,e.createBlock)(Ht,{key:0,message:(0,e.unref)(p).message,mode:(0,e.unref)(p).mode,surface:(0,e.unref)(p).surface},{default:(0,e.withCtx)(()=>[(0,e.unref)(h)?(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},(0,e.unref)(p)))):(0,e.createCommentVNode)(``,!0)]),_:3},8,[`message`,`mode`,`surface`])):(0,e.createCommentVNode)(``,!0)],4)],544),(0,e.unref)(o).showScrollbar.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,Xr,[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`,Zr,[(0,e.createElementVNode)(`div`,Qr,[(0,e.renderSlot)(t.$slots,`grid-footer`)])])):(0,e.createCommentVNode)(``,!0),l.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`])},[d.value?(0,e.renderSlot)(t.$slots,`grid-status`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},l.value))):((0,e.openBlock)(),(0,e.createElementBlock)(`span`,{key:1,"data-testid":`vibe-grid-status-badge`,class:(0,e.normalizeClass)([`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]`,l.value.kind===`end`?`border-amber-300/35 text-amber-200`:l.value.kind===`failed`?`border-rose-400/45 text-rose-100`:``])},(0,e.toDisplayString)(l.value.message),3))],2)):(0,e.createCommentVNode)(``,!0),(0,e.unref)(m)&&(0,e.unref)(p)?((0,e.openBlock)(),(0,e.createBlock)(Ht,{key:3,class:(0,e.normalizeClass)([`z-[3]`,i[`grid-footer`]?`pb-24`:`pb-6`]),message:(0,e.unref)(p).message,mode:(0,e.unref)(p).mode,surface:(0,e.unref)(p).surface},{default:(0,e.withCtx)(()=>[(0,e.unref)(h)?(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.mergeProps)({key:0},(0,e.unref)(p)))):(0,e.createCommentVNode)(``,!0)]),_:3},8,[`class`,`message`,`mode`,`surface`])):(0,e.createCommentVNode)(``,!0)]))}}),ei=[`data-surface-mode`],ti={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`},ni=[`data-visible`,`inert`],ri=[`data-visible`,`inert`],ii={key:3,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`},ai=(0,e.defineComponent)({name:`VibeLayout`,__name:`Layout`,props:{emptyStateMode:{},fillDelayMs:{},fillDelayStepMs:{},initialCursor:{},initialState:{},loopFullscreenVideo:{type:Boolean},pageSize:{},paginationDetail:{},resolve:{type:Function},showDominantImageTone:{type:Boolean},showEndBadge:{type:Boolean},showStatusBadges:{type:Boolean},surfaceMode:{}},emits:[`asset-errors`,`asset-loads`,`update:activeIndex`,`update:surfaceMode`],setup(t,{expose:n,emit:r}){let i=t,a=(0,e.useSlots)(),o=r,s=me(i,o),c=S(e=>{o(`asset-errors`,e)}),l=C(e=>{o(`asset-loads`,e)});return(0,e.onBeforeUnmount)(()=>{c.stop(),l.stop()}),n({cancel:s.cancel,clearRemoved:s.clearRemoved,getRemovedIds:s.getRemovedIds,lockPageLoading:s.lockPageLoading,loadNext:s.loadNext,loadPrevious:s.loadPrevious,remove:s.remove,restore:s.restore,retry:s.retry,status:s.status,undo:s.undo,unlockPageLoading:s.unlockPageLoading}),(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`,ti,(0,e.toDisplayString)((0,e.unref)(s).errorMessage.value),1)):(0,e.createCommentVNode)(``,!0),(0,e.unref)(s).isDesktop.value?((0,e.openBlock)(),(0,e.createElementBlock)(e.Fragment,{key:2},[(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)($r,{active:(0,e.unref)(s).surfaceMode.value===`list`,"allow-exhausted-next-page-refresh":(0,e.unref)(s).canRefreshExhaustedNextPage.value,items:(0,e.unref)(s).items.value,"active-index":(0,e.unref)(s).activeIndex.value,"error-message":(0,e.unref)(s).errorMessage.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,phase:(0,e.unref)(s).phase.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,"empty-state-mode":i.emptyStateMode,"show-status-badges":i.showStatusBadges??!0,onBoundaryLoadProgress:(0,e.unref)(s).setBoundaryLoadProgress,onOpenFullscreen:(0,e.unref)(s).openFullscreen,"onUpdate:activeIndex":(0,e.unref)(s).setActiveIndex},(0,e.createSlots)({_:2},[a[`empty-state`]?{name:`empty-state`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`0`}:void 0,a[`grid-footer`]?{name:`grid-footer`,fn:(0,e.withCtx)(()=>[(0,e.renderSlot)(t.$slots,`grid-footer`)]),key:`1`}: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:`2`}: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:`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,[`active`,`allow-exhausted-next-page-refresh`,`items`,`active-index`,`error-message`,`loading`,`has-next-page`,`has-previous-page`,`pending-append-items`,`phase`,`commit-pending-append`,`pagination-detail`,`report-asset-error`,`report-asset-load`,`request-next-page`,`request-previous-page`,`empty-state-mode`,`show-status-badges`,`onBoundaryLoadProgress`,`onOpenFullscreen`,`onUpdate:activeIndex`])],8,ni),[[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)(Tn,{items:(0,e.unref)(s).items.value,active:(0,e.unref)(s).surfaceMode.value===`fullscreen`,"active-index":(0,e.unref)(s).activeIndex.value,"error-message":(0,e.unref)(s).errorMessage.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,phase:(0,e.unref)(s).phase.value,"report-asset-error":(0,e.unref)(c).report,"report-asset-load":(0,e.unref)(l).report,"empty-state-mode":i.emptyStateMode,"loop-fullscreen-video":i.loopFullscreenVideo??!0,"show-dominant-image-tone":i.showDominantImageTone??!0,"show-end-badge":i.showEndBadge??!0,"show-status-badges":i.showStatusBadges??!0,"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[`empty-state`]?{name:`empty-state`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`0`}:void 0,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:`1`}: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:`2`}: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:`3`}: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:`4`}: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:`5`}:void 0]),1032,[`items`,`active`,`active-index`,`error-message`,`loading`,`has-next-page`,`pagination-detail`,`phase`,`report-asset-error`,`report-asset-load`,`empty-state-mode`,`loop-fullscreen-video`,`show-dominant-image-tone`,`show-end-badge`,`show-status-badges`,`show-back-to-list`,`onBackToList`,`onUpdate:activeIndex`])],8,ri),[[e.vShow,(0,e.unref)(s).surfaceMode.value===`fullscreen`]])]),_:3})],64)):(0,e.unref)(s).items.value.length===0&&(0,e.unref)(s).loading.value?((0,e.openBlock)(),(0,e.createElementBlock)(`div`,ii,[(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)])):((0,e.openBlock)(),(0,e.createBlock)(Tn,{key:4,items:(0,e.unref)(s).items.value,active:!0,"active-index":(0,e.unref)(s).activeIndex.value,"error-message":(0,e.unref)(s).errorMessage.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,phase:(0,e.unref)(s).phase.value,"report-asset-error":(0,e.unref)(c).report,"report-asset-load":(0,e.unref)(l).report,"empty-state-mode":i.emptyStateMode,"loop-fullscreen-video":i.loopFullscreenVideo??!0,"show-dominant-image-tone":i.showDominantImageTone??!0,"show-end-badge":i.showEndBadge??!0,"show-status-badges":i.showStatusBadges??!0,"show-back-to-list":!1,onBackToList:(0,e.unref)(s).returnToList,"onUpdate:activeIndex":(0,e.unref)(s).setActiveIndex},(0,e.createSlots)({_:2},[a[`empty-state`]?{name:`empty-state`,fn:(0,e.withCtx)(n=>[(0,e.renderSlot)(t.$slots,`empty-state`,(0,e.normalizeProps)((0,e.guardReactiveProps)(n)))]),key:`0`}:void 0,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:`1`}: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:`2`}: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:`3`}: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:`4`}: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:`5`}:void 0]),1032,[`items`,`active-index`,`error-message`,`loading`,`has-next-page`,`pagination-detail`,`phase`,`report-asset-error`,`report-asset-load`,`empty-state-mode`,`loop-fullscreen-video`,`show-dominant-image-tone`,`show-end-badge`,`show-status-badges`,`onBackToList`,`onUpdate:activeIndex`]))],8,ei))}}),oi={install(e){e.component(`VibeLayout`,ai)}};exports.VibeLayout=ai,exports.VibePlugin=oi,exports.default=oi;
|