@hyperframes/producer 0.1.1 → 0.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
@@ -0,0 +1,75 @@
1
+ # @hyperframes/producer
2
+
3
+ Full HTML-to-video rendering pipeline: capture frames with Chrome's BeginFrame API, encode with FFmpeg, mix audio — all in one call.
4
+
5
+ ## Install
6
+
7
+ ```bash
8
+ npm install @hyperframes/producer
9
+ ```
10
+
11
+ **Requirements:** Node.js >= 22, Chrome/Chromium (auto-downloaded), FFmpeg
12
+
13
+ ## Usage
14
+
15
+ ### Render a video
16
+
17
+ ```typescript
18
+ import { createRenderJob, executeRenderJob } from "@hyperframes/producer";
19
+
20
+ const job = createRenderJob({
21
+ inputPath: "./my-composition.html",
22
+ outputPath: "./output.mp4",
23
+ width: 1920,
24
+ height: 1080,
25
+ fps: 30,
26
+ });
27
+
28
+ const result = await executeRenderJob(job, (progress) => {
29
+ console.log(`${Math.round(progress.percent * 100)}%`);
30
+ });
31
+
32
+ console.log(result.outputPath); // ./output.mp4
33
+ ```
34
+
35
+ ### Run as an HTTP server
36
+
37
+ The producer can also run as a render server, accepting render requests over HTTP:
38
+
39
+ ```typescript
40
+ import { startServer } from "@hyperframes/producer";
41
+
42
+ await startServer({ port: 8080 });
43
+ // POST /render with a RenderConfig body
44
+ ```
45
+
46
+ ### Configuration
47
+
48
+ `RenderConfig` controls the render pipeline:
49
+
50
+ | Option | Default | Description |
51
+ | ------------ | ------------ | -------------------------------------------------- |
52
+ | `inputPath` | — | Path to the HTML composition |
53
+ | `outputPath` | — | Output video file path |
54
+ | `width` | 1920 | Frame width in pixels |
55
+ | `height` | 1080 | Frame height in pixels |
56
+ | `fps` | 30 | Frames per second (24, 30, or 60) |
57
+ | `quality` | `"standard"` | Encoder preset (`"draft"`, `"standard"`, `"high"`) |
58
+
59
+ ## How it works
60
+
61
+ 1. **Serve** — spins up a local file server for the HTML composition
62
+ 2. **Capture** — opens the page in headless Chrome, seeks frame-by-frame via `HeadlessExperimental.beginFrame`, captures screenshots
63
+ 3. **Encode** — pipes frames through FFmpeg (with GPU encoder detection and chunked concat)
64
+ 4. **Mix** — extracts `<audio>` elements and mixes them into the final video
65
+ 5. **Finalize** — applies faststart for streaming-friendly MP4
66
+
67
+ ## Documentation
68
+
69
+ Full documentation: [hyperframes.heygen.com/packages/producer](https://hyperframes.heygen.com/packages/producer)
70
+
71
+ ## Related packages
72
+
73
+ - [`@hyperframes/core`](../core) — types, parsers, frame adapters
74
+ - [`@hyperframes/engine`](../engine) — lower-level capture and encode primitives
75
+ - [`hyperframes`](../cli) — CLI
@@ -6,10 +6,10 @@
6
6
  * Results are saved to producer/tests/perf/benchmark-results.json.
7
7
  *
8
8
  * Usage:
9
- * pnpm benchmark # 3 runs per fixture (default)
10
- * pnpm benchmark -- --runs 5 # 5 runs per fixture
11
- * pnpm benchmark -- --only chat # single fixture
12
- * pnpm benchmark -- --exclude-tags slow
9
+ * bun run benchmark # 3 runs per fixture (default)
10
+ * bun run benchmark -- --runs 5 # 5 runs per fixture
11
+ * bun run benchmark -- --only chat # single fixture
12
+ * bun run benchmark -- --exclude-tags slow
13
13
  */
14
14
  export {};
15
15
  //# sourceMappingURL=benchmark.d.ts.map
@@ -0,0 +1,22 @@
1
+ {
2
+ "version": "0.1.0",
3
+ "buildId": "dev",
4
+ "sha256": "5f4cd628dcd92b0808af565ae014f4299bdef377718a99306ab6f6bddc0d7392",
5
+ "artifacts": {
6
+ "iife": "hyperframe.runtime.iife.js",
7
+ "esm": "hyperframe.runtime.mjs"
8
+ },
9
+ "contract": {
10
+ "globals": {
11
+ "player": "__player",
12
+ "playerReady": "__playerReady",
13
+ "renderReady": "__renderReady",
14
+ "timelines": "__timelines",
15
+ "clipManifest": "__clipManifest"
16
+ },
17
+ "messageSources": {
18
+ "parent": "hf-parent",
19
+ "preview": "hf-preview"
20
+ }
21
+ }
22
+ }
@@ -0,0 +1,13 @@
1
+ "use strict";(()=>{function Q(e){try{window.parent.postMessage(e,"*")}catch{}}function Ue(e){let n=i=>{let a=i.data;if(!a||a.source!=="hf-parent"||a.type!=="control")return;let c=a.action;if(c==="play"){e.onPlay();return}if(c==="pause"){e.onPause();return}if(c==="seek"){e.onSeek(Number(a.frame??0),a.seekMode??"commit");return}if(c==="set-muted"){e.onSetMuted(!!a.muted);return}if(c==="set-playback-rate"){e.onSetPlaybackRate(Number(a.playbackRate??1));return}if(c==="enable-pick-mode"){e.onEnablePickMode();return}if(c==="disable-pick-mode"){e.onDisablePickMode();return}if(c==="flash-elements"){let p=a.selectors,y=a.duration||800;p&&mt(p,y)}};return window.addEventListener("message",n),n}function mt(e,n){if(!document.getElementById("__hf-flash-styles")){let i=document.createElement("style");i.id="__hf-flash-styles",i.textContent=`
2
+ .__hf-flash {
3
+ outline: 2px solid rgba(59, 130, 246, 0.6) !important;
4
+ outline-offset: 2px !important;
5
+ animation: __hf-flash-pulse ${n}ms ease-out forwards !important;
6
+ }
7
+ @keyframes __hf-flash-pulse {
8
+ 0% { outline-color: rgba(59, 130, 246, 0.8); }
9
+ 100% { outline-color: transparent; }
10
+ }
11
+ `,document.head.appendChild(i)}for(let i of e)try{document.querySelectorAll(i).forEach(c=>{c.classList.add("__hf-flash"),setTimeout(()=>c.classList.remove("__hf-flash"),n)})}catch{}}var Le=null;function qe(e){Le=e}function be(e,n){if(Le)try{Le({source:"hf-preview",type:"analytics",event:e,properties:n??{}})}catch{}}function Ve(e){let n=[];return{name:"css",discover:()=>{n=[];let i=document.querySelectorAll("*");for(let a of i){if(!(a instanceof HTMLElement))continue;let c=window.getComputedStyle(a);!c.animationName||c.animationName==="none"||n.push({el:a,baseDelay:a.style.animationDelay||"",basePlayState:a.style.animationPlayState||""})}},seek:i=>{let a=Number(i.time)||0;for(let c of n){if(!c.el.isConnected)continue;let p=e?.resolveStartSeconds?e.resolveStartSeconds(c.el):Number.parseFloat(c.el.getAttribute("data-start")??"0")||0,y=Math.max(0,a-p);c.el.style.animationPlayState="paused",c.el.style.animationDelay=`-${y.toFixed(3)}s`}},pause:()=>{for(let i of n)i.el.isConnected&&(i.el.style.animationPlayState=i.basePlayState||"paused",i.baseDelay&&(i.el.style.animationDelay=i.baseDelay))},revert:()=>{n=[]}}}function $e(e){return{name:"gsap",discover:()=>{},seek:n=>{let i=e.getTimeline();if(!i)return;i.pause();let a=Math.max(0,Number(n.time)||0);typeof i.totalTime=="function"?i.totalTime(a,!1):i.seek(a,!1)},pause:()=>{let n=e.getTimeline();n&&n.pause()}}}function ze(){return{name:"lottie",discover:()=>{try{let e=window.lottie;if(e&&typeof e.getRegisteredAnimations=="function"){let n=e.getRegisteredAnimations();if(Array.isArray(n)&&n.length>0){let i=window.__hfLottie??[],a=new Set(i);for(let c of n)a.has(c)||i.push(c);window.__hfLottie=i}}}catch{}},seek:e=>{let n=Math.max(0,Number(e.time)||0),i=window.__hfLottie;if(!(!i||i.length===0))for(let a of i)try{if(Ce(a))a.goToAndStop(n*1e3,!1);else if(Ie(a)){if(typeof a.setCurrentRawFrameValue=="function"){let c=a.totalFrames??0,p=a.frameRate??30,y=n*p;c>0&&a.setCurrentRawFrameValue(Math.min(y,c-1))}else if(typeof a.seek=="function"){let c=a.duration??1,p=Math.min(100,n/c*100);a.seek(p)}}}catch{}},pause:()=>{let e=window.__hfLottie;if(!(!e||e.length===0))for(let n of e)try{(Ce(n)||Ie(n))&&n.pause()}catch{}},play:()=>{let e=window.__hfLottie;if(!(!e||e.length===0))for(let n of e)try{(Ce(n)||Ie(n))&&n.play()}catch{}},revert:()=>{}}}function Ce(e){return typeof e=="object"&&e!==null&&typeof e.goToAndStop=="function"}function Ie(e){return typeof e=="object"&&e!==null&&typeof e.pause=="function"&&("totalFrames"in e||"duration"in e)}function Ge(){let e=null,n=0;return{name:"three",discover:()=>{},seek:i=>{e=Math.max(0,Number(i.time)||0),n=e,window.__hfThreeTime=e;try{window.dispatchEvent(new CustomEvent("hf-seek",{detail:{time:e}}))}catch{}},pause:()=>{e==null&&(e=Math.max(0,n))},play:()=>{e=null},revert:()=>{e=null,n=0}}}function Ke(){return{name:"waapi",discover:()=>{},seek:e=>{if(!document.getAnimations)return;let n=Math.max(0,(Number(e.time)||0)*1e3);for(let i of document.getAnimations())try{i.pause(),i.currentTime=n}catch{}},pause:()=>{if(document.getAnimations)for(let e of document.getAnimations())try{e.pause()}catch{}}}}function Ze(e){let n=Array.from(document.querySelectorAll("video[data-start], audio[data-start]")),i=[],a=[],c=0;for(let p of n){let y=e?.resolveStartSeconds?e.resolveStartSeconds(p):Number.parseFloat(p.dataset.start??"0");if(!Number.isFinite(y))continue;let f=Number.parseFloat(p.dataset.playbackStart??p.dataset.mediaStart??"0")||0,s=p.defaultPlaybackRate,h=Number.isFinite(s)&&s>0?Math.max(.1,Math.min(5,s)):1,b=p.loop,R=Number.isFinite(p.duration)&&p.duration>0?p.duration:null,T=Number.parseFloat(p.dataset.duration??"");(!Number.isFinite(T)||T<=0)&&R!=null&&(T=Math.max(0,(R-f)/h));let N=Number.isFinite(T)&&T>0?y+T:Number.POSITIVE_INFINITY,P=Number.parseFloat(p.dataset.volume??""),Z={el:p,start:y,mediaStart:f,duration:Number.isFinite(T)&&T>0?T:Number.POSITIVE_INFINITY,end:N,volume:Number.isFinite(P)?P:null,playbackRate:h,loop:b,sourceDuration:R};i.push(Z),p.tagName==="VIDEO"&&a.push(Z),Number.isFinite(N)&&(c=Math.max(c,N))}return{timedMediaEls:n,mediaClips:i,videoClips:a,maxMediaEnd:c}}function Ye(e){for(let n of e.clips){let{el:i}=n;if(!i.isConnected)continue;let a=(e.timeSeconds-n.start)*n.playbackRate+n.mediaStart;if(e.timeSeconds>=n.start&&e.timeSeconds<n.end&&a>=0){if(n.loop&&n.sourceDuration!=null&&n.sourceDuration>0){let p=n.sourceDuration-n.mediaStart;p>0&&a>=n.sourceDuration&&(a=n.mediaStart+(a-n.mediaStart)%p)}n.volume!=null&&(i.volume=n.volume);try{i.playbackRate=n.playbackRate*e.playbackRate}catch{}if(Math.abs((i.currentTime||0)-a)>.3)try{i.currentTime=a}catch{}e.playing&&i.paused?i.play().catch(()=>{}):!e.playing&&!i.paused&&i.pause();continue}i.paused||i.pause()}}function Je(e){let n=!1,i=null,a=null,c=null,p=null;function y(u,g){try{window.dispatchEvent(new CustomEvent(u,{detail:g}))}catch{}}function f(u){c=u,y("hyperframe:picker:hovered",{elementInfo:c,isPickMode:n,timestamp:Date.now()})}function s(u){p=u,y("hyperframe:picker:selected",{elementInfo:p,isPickMode:n,timestamp:Date.now()})}function h(u){if(!u||u===document.body||u===document.documentElement)return!1;let g=u.tagName.toLowerCase();return!(g==="script"||g==="style"||g==="link"||g==="meta"||u.classList.contains("__hf-pick-highlight"))}function b(u){let g=u;if(g.id)return`#${g.id}`;let S=u.getAttribute("data-composition-id");if(S)return`[data-composition-id="${S}"]`;let C=u.getAttribute("data-composition-src");if(C)return`[data-composition-src="${C}"]`;let v=u.getAttribute("data-track-index");if(v)return`[data-track-index="${v}"]`;let w=u.tagName.toLowerCase(),G=u.parentElement;if(!G)return w;let O=G.querySelectorAll(`:scope > ${w}`);if(O.length===1)return w;for(let I=0;I<O.length;I+=1)if(O[I]===u)return`${w}:nth-of-type(${I+1})`;return w}function R(u){let g=u.tagName.toLowerCase(),S=(u.textContent??"").trim().replace(/\s+/g," "),C=(v,w)=>v.length>w?`${v.slice(0,w-1)}\u2026`:v;return g==="h1"||g==="h2"||g==="h3"?"Heading":g==="p"||g==="span"||g==="div"?S.length>0?C(S,56):"Text":g==="img"?"Image":g==="video"?"Video":g==="audio"?"Audio":g==="svg"?"Shape":u.getAttribute("data-composition-src")?"Composition":g==="section"?"Section":`${g.charAt(0).toUpperCase()}${g.slice(1)}`}function T(u,g,S){let C=typeof S=="number"&&S>0?S:8,v=[];if(document.elementsFromPoint)v=document.elementsFromPoint(u,g);else if(document.elementFromPoint){let O=document.elementFromPoint(u,g);v=O?[O]:[]}let w={},G=[];for(let O=0;O<v.length;O+=1){let I=v[O];if(!h(I))continue;let K=`${I.tagName}::${I.id||""}::${O}`;if(!w[K]&&(w[K]=!0,G.push(I),G.length>=C))break}return G}function N(u){let g=u.getBoundingClientRect(),S={};for(let v=0;v<u.attributes.length;v+=1){let w=u.attributes[v];w.name.startsWith("data-")&&(S[w.name]=w.value)}return{id:u.id||null,tagName:u.tagName.toLowerCase(),selector:b(u),label:R(u),boundingBox:{x:g.left,y:g.top,width:g.width,height:g.height},textContent:u.textContent?u.textContent.trim().slice(0,200):null,src:u.getAttribute("src")||u.getAttribute("data-composition-src")||null,dataAttributes:S}}function P(u,g,S){return T(u,g,S).map(N)}function Z(u){if(!n)return;let S=T(u.clientX,u.clientY,1)[0]??(u.target instanceof Element?u.target:null);if(!h(S)||i===S)return;i&&i.classList.remove("__hf-pick-highlight"),i=S,S.classList.add("__hf-pick-highlight");let C=N(S);f(C),e.postMessage({source:"hf-preview",type:"element-hovered",elementInfo:C})}function W(u){if(!n)return;u.preventDefault(),u.stopPropagation(),u.stopImmediatePropagation();let g=P(u.clientX,u.clientY,8);g.length!==0&&(f(g[0]??null),e.postMessage({source:"hf-preview",type:"element-pick-candidates",candidates:g,selectedIndex:0,point:{x:u.clientX,y:u.clientY}}))}function oe(u){u.key==="Escape"&&(ie(),e.postMessage({source:"hf-preview",type:"pick-mode-cancelled"}))}function re(){n||(n=!0,a=document.createElement("style"),a.textContent=[".__hf-pick-highlight { outline: 2px solid #4f8cf7 !important; outline-offset: 2px; cursor: crosshair !important; }",".__hf-pick-active * { cursor: crosshair !important; }"].join(`
12
+ `),document.head.appendChild(a),document.body.classList.add("__hf-pick-active"),document.addEventListener("mousemove",Z,!0),document.addEventListener("click",W,!0),document.addEventListener("keydown",oe,!0),y("hyperframe:picker:mode",{isPickMode:!0,timestamp:Date.now()}))}function ie(){n&&(n=!1,i&&(i.classList.remove("__hf-pick-highlight"),i=null),a&&(a.remove(),a=null),document.body.classList.remove("__hf-pick-active"),document.removeEventListener("mousemove",Z,!0),document.removeEventListener("click",W,!0),document.removeEventListener("keydown",oe,!0),y("hyperframe:picker:mode",{isPickMode:!1,timestamp:Date.now()}))}function se(){window.__HF_PICKER_API={enable:re,disable:ie,isActive:()=>n,getHovered:()=>c,getSelected:()=>p,getCandidatesAtPoint:(u,g,S)=>Number.isFinite(u)&&Number.isFinite(g)?P(u,g,S):[],pickAtPoint:(u,g,S)=>{if(!Number.isFinite(u)||!Number.isFinite(g))return null;let C=P(u,g,8);if(!C.length)return null;let v=Math.max(0,Math.min(C.length-1,Number(S??0))),w=C[v]??null;return w?(s(w),e.postMessage({source:"hf-preview",type:"element-picked",elementInfo:w}),ie(),w):null},pickManyAtPoint:(u,g,S)=>{if(!Number.isFinite(u)||!Number.isFinite(g))return[];let C=P(u,g,8);if(!C.length)return[];let v=[],w=Array.isArray(S)?S:[0];for(let G of w){let O=Math.max(0,Math.min(C.length-1,Math.floor(Number(G)))),I=C[O];if(!I)continue;v.some(q=>q.selector===I.selector&&q.tagName===I.tagName)||v.push(I)}return v.length?(s(v[0]??null),e.postMessage({source:"hf-preview",type:"element-picked-many",elementInfos:v}),ie(),v):[]}},y("hyperframe:picker:api-ready",{hasApi:!0,timestamp:Date.now()})}return{enablePickMode:re,disablePickMode:ie,installPickerApi:se}}function Xe(e,n){let i=Number.isFinite(n)&&n>0?n:30,a=Number.isFinite(e)&&e>0?e:0;return Math.floor(a*i+1e-9)/i}function Qe(e,n,i){let a=Xe(n,i);return e.pause(),typeof e.totalTime=="function"?e.totalTime(a,!1):e.seek(a,!1),a}function et(e){return{_timeline:null,play:()=>{let n=e.getTimeline();if(!n||e.getIsPlaying())return;let i=Math.max(0,Number(e.getSafeDuration?.()??n.duration()??0)||0);i>0&&Math.max(0,Number(n.time())||0)>=i&&(n.pause(),n.seek(0,!1),e.onDeterministicSeek(0),e.setIsPlaying(!1),e.onSyncMedia(0,!1),e.onRenderFrameSeek(0)),typeof n.timeScale=="function"&&n.timeScale(e.getPlaybackRate()),n.play(),e.onDeterministicPlay(),e.setIsPlaying(!0),e.onShowNativeVideos(),e.onStatePost(!0)},pause:()=>{let n=e.getTimeline();if(!n)return;n.pause();let i=Math.max(0,Number(n.time())||0);e.onDeterministicSeek(i),e.onDeterministicPause(),e.setIsPlaying(!1),e.onSyncMedia(i,!1),e.onRenderFrameSeek(i),e.onStatePost(!0)},seek:n=>{let i=e.getTimeline();if(!i)return;let a=Math.max(0,Number(n)||0),c=Qe(i,a,e.getCanonicalFps());e.onDeterministicSeek(c),e.setIsPlaying(!1),e.onSyncMedia(c,!1),e.onRenderFrameSeek(c),e.onStatePost(!0)},renderSeek:n=>{let i=e.getTimeline();if(!i)return;let a=Qe(i,n,e.getCanonicalFps());e.onDeterministicSeek(a),e.setIsPlaying(!1),e.onSyncMedia(a,!1),e.onRenderFrameSeek(a),e.onStatePost(!0)},getTime:()=>Number(e.getTimeline()?.time()??0),getDuration:()=>Number(e.getTimeline()?.duration()??0),isPlaying:()=>e.getIsPlaying(),setPlaybackRate:n=>e.setPlaybackRate(n),getPlaybackRate:()=>e.getPlaybackRate()}}function tt(){return{capturedTimeline:null,isPlaying:!1,rafId:null,currentTime:0,deterministicAdapters:[],parityModeEnabled:!0,canonicalFps:30,bridgeMuted:!1,playbackRate:1,bridgeLastPostedFrame:-1,bridgeLastPostedAt:0,bridgeLastPostedPlaying:!1,bridgeLastPostedMuted:!1,bridgeMaxPostIntervalMs:80,timelinePollIntervalId:null,controlBridgeHandler:null,clampDurationLoggedRaw:null,beforeUnloadHandler:null,domReadyHandler:null,injectedCompStyles:[],injectedCompScripts:[],cachedTimedMediaEls:[],cachedMediaClips:[],cachedVideoClips:[],cachedMediaTimelineDurationSeconds:0,tornDown:!1,maxTimelineDurationSeconds:1800,nativeVisualWatchdogTick:0}}function he(e){let n=Number(e);return Number.isFinite(n)?n:null}function ft(e){let n=(e??"").trim();if(!n)return null;let i=he(n);if(i!=null)return{kind:"absolute",value:i};let a=n.match(/^([A-Za-z0-9_.:-]+)(?:\s*([+-])\s*([0-9]*\.?[0-9]+))?$/);if(!a)return null;let c=(a[1]??"").trim();if(!c)return null;let p=a[2]??"+",y=a[3]??"0",f=Number.parseFloat(y),s=Number.isFinite(f)?Math.max(0,f):0,h=p==="-"?-s:s;return{kind:"reference",refId:c,offset:h}}function pe(e){let n=e.timelineRegistry??{},i=new WeakMap,a=new WeakMap,c=new Set,p=s=>{let h=document.getElementById(s);return h||(document.querySelector(`[data-composition-id="${CSS.escape(s)}"]`)??null)},y=s=>{let h=a.get(s);if(h!==void 0)return h;let b=null,R=he(s.getAttribute("data-duration"));if(R!=null&&R>0&&(b=R),b==null||b<=0){let T=he(s.getAttribute("data-end"));if(T!=null){let N=f(s,0),P=T-N;Number.isFinite(P)&&P>0&&(b=P)}}if((b==null||b<=0)&&s instanceof HTMLMediaElement){let T=he(s.getAttribute("data-playback-start"))??he(s.getAttribute("data-media-start"))??0;Number.isFinite(s.duration)&&s.duration>T&&(b=s.duration-T)}if(b==null||b<=0){let T=s.getAttribute("data-composition-id");if(T){let N=n[T]??null;if(N&&typeof N.duration=="function")try{let P=Number(N.duration());Number.isFinite(P)&&P>0&&(b=P)}catch{}}}return b!=null&&Number.isFinite(b)&&b>0?(a.set(s,b),b):(a.set(s,null),null)},f=(s,h)=>{let b=i.get(s);if(b!==void 0)return b??h;if(c.has(s))return h;c.add(s);try{let R=ft(s.getAttribute("data-start"));if(!R){if(s.hasAttribute("data-composition-id")){let W=s.parentElement;if(W&&(W.hasAttribute("data-composition-src")||W.hasAttribute("data-composition-id"))){let oe=f(W,h);return i.set(s,oe),oe}}return i.set(s,h),h}if(R.kind==="absolute"){let W=Math.max(0,R.value);return i.set(s,W),W}let T=p(R.refId);if(!T)return i.set(s,h),h;let N=f(T,0),P=y(T);if(P==null||P<=0){let W=Math.max(0,N+R.offset);return i.set(s,W),W}let Z=Math.max(0,N+P+R.offset);return i.set(s,Z),Z}finally{c.delete(s)}};return{resolveStartForElement:(s,h=0)=>f(s,Math.max(0,h)),resolveDurationForElement:s=>y(s)}}function ne(e){let n=Number(e);return Number.isFinite(n)?n:null}var nt={composition:0,video:1,image:2,element:3,audio:4};function pt(e){if(e.length===0)return;let n=new Map;for(let y of e){let f=n.get(y.track)??new Set;f.add(y.kind),n.set(y.track,f)}if(!Array.from(n.values()).some(y=>y.size>1))return;let a=0,c=new Map,p=[...n.keys()].sort((y,f)=>y-f);for(let y of p){let f=n.get(y);if(f.size===1)c.set(`${y}:${[...f][0]}`,a++);else{let s=[...f].sort((h,b)=>(nt[h]??99)-(nt[b]??99));for(let h of s)c.set(`${y}:${h}`,a++)}}for(let y of e){let f=`${y.track}:${y.kind}`,s=c.get(f);s!=null&&(y.track=s)}}function Se(e){let n=String(e??"").trim();if(!n)return null;let i=n.toLowerCase();if(i.startsWith("data:")||i.startsWith("javascript:"))return null;try{return new URL(n,document.baseURI).toString()}catch{return n}}function gt(e){let n=e.getAttribute("src")??e.getAttribute("data-src");if(n)return Se(n);let i=e.getAttribute("data-composition-src");if(i)return Se(i);let a=e.querySelector("img[src], video[src], audio[src], source[src]");return a?Se(a.getAttribute("src")):null}function it(e){let i=window.__timelines??{},a=pe({timelineRegistry:i}),c=E=>{if(!E)return null;let m=i[E]??null;if(!m||typeof m.duration!="function")return null;try{let x=Number(m.duration());return Number.isFinite(x)&&x>0?x:null}catch{return null}},p=E=>{let m=ne(E.getAttribute("data-duration"));if(m!=null&&m>0)return m;let x=ne(E.getAttribute("data-playback-start"))??ne(E.getAttribute("data-media-start"))??0;return Number.isFinite(E.duration)&&E.duration>x?Math.max(0,E.duration-x):null},y=()=>{let E=Array.from(document.querySelectorAll("video[data-start], audio[data-start]"));if(E.length===0)return null;let m=0;for(let x of E){let j=a.resolveStartForElement(x,0);if(!Number.isFinite(j))continue;let F=p(x);F==null||F<=0||(m=Math.max(m,Math.max(0,j)+F))}return m>0?m:null},f=E=>{let m=E.trim().toLowerCase();return!(!m||m==="main"||m.includes("caption")||m.includes("ambient"))},s=(E,m)=>{let x=[],j=null,F=null,D=null,Y=E.parentElement;for(;Y;){let J=Y.getAttribute("data-composition-id");J&&(x.push(J),!D&&Y!==m&&(D=J),j==null&&(j=a.resolveStartForElement(Y,0)),F==null&&(F=ne(Y.getAttribute("data-duration"))??c(J)??null)),Y=Y.parentElement}return{parentCompositionId:D,compositionAncestors:x.reverse(),inheritedStart:j,inheritedDuration:F}},h=document.querySelector("[data-composition-id]"),b=h?.getAttribute("data-composition-id")??null,R=h?a.resolveStartForElement(h,0):0,T=y(),N=T!=null?Math.max(0,T-Math.max(0,R)):null,P=c(b),Z=ne(h?.getAttribute("data-duration")),W=typeof P=="number"&&Number.isFinite(P)&&P>0?P:null,oe=typeof Z=="number"&&Number.isFinite(Z)&&Z>0?Z:null,re=typeof N=="number"&&Number.isFinite(N)&&N>0?N:null,ie=W!=null&&re!=null&&W>re+1,se=oe??(ie?re:W??re),u=se!=null?Math.min(se,e.maxTimelineDurationSeconds):null,S=(u!=null?R+u:null)??(typeof T=="number"&&Number.isFinite(T)&&T>0?T:null),C=(E,m)=>!Number.isFinite(m)||m<=0?0:S==null||!Number.isFinite(S)?m:!Number.isFinite(E)||E>=S?0:Math.max(0,Math.min(m,S-E)),v=Array.from(document.querySelectorAll("[data-composition-id]")),w=[],G=[],O=Array.from(document.querySelectorAll("*")),I=0;for(let E=0;E<O.length;E+=1){let m=O[E];if(m===h||["SCRIPT","STYLE","LINK","META","TEMPLATE","NOSCRIPT"].includes(m.tagName))continue;let x=s(m,h),j=a.resolveStartForElement(m,x.inheritedStart??0),F=m.getAttribute("data-composition-id"),D=ne(m.getAttribute("data-duration"));if((D==null||D<=0)&&F&&F!==b&&(D=c(F)),(D==null||D<=0)&&m instanceof HTMLMediaElement){let le=ne(m.getAttribute("data-playback-start"))??ne(m.getAttribute("data-media-start"))??0;Number.isFinite(m.duration)&&m.duration>0&&(D=Math.max(0,m.duration-le))}if(D==null||D<=0){let le=x.inheritedDuration;if(le!=null&&le>0){let ve=(x.inheritedStart??0)+le;D=Math.max(0,ve-j)}}if(D==null||D<=0||(D=C(j,D),D<=0))continue;let Y=j+D;I=Math.max(I,Y);let J=m.tagName.toLowerCase(),Te=F&&F!==b?"composition":J==="video"?"video":J==="audio"?"audio":J==="img"?"image":"element";w.push({id:m.id||F||`__node__index_${E}`,label:m.getAttribute("data-timeline-label")??m.getAttribute("data-label")??m.getAttribute("aria-label")??F??m.id??m.className?.split(" ")[0]??Te,start:j,duration:D,track:Number.parseInt(m.getAttribute("data-track-index")??m.getAttribute("data-track")??String(E),10)||0,kind:Te,tagName:J,compositionId:m.getAttribute("data-composition-id"),compositionAncestors:x.compositionAncestors,parentCompositionId:x.parentCompositionId,nodePath:null,compositionSrc:Se(m.getAttribute("data-composition-src")),assetUrl:gt(m),timelineRole:m.getAttribute("data-timeline-role"),timelineLabel:m.getAttribute("data-timeline-label"),timelineGroup:m.getAttribute("data-timeline-group"),timelinePriority:ne(m.getAttribute("data-timeline-priority"))})}pt(w);for(let E of v){if(E===h)continue;let m=E.getAttribute("data-composition-id");if(!m||!f(m))continue;let x=a.resolveStartForElement(E,0),j=ne(E.getAttribute("data-duration")),F=c(m),D=j&&j>0?j:F;if(D==null||D<=0)continue;let Y=C(x,D);Y<=0||G.push({id:m,label:E.getAttribute("data-label")??m,start:x,duration:Y,thumbnailUrl:Se(E.getAttribute("data-thumbnail-url")),avatarName:null})}let K=Math.max(1,Math.min(I||1,e.maxTimelineDurationSeconds));return{source:"hf-preview",type:"timeline",durationInFrames:ie&&oe==null?Number.POSITIVE_INFINITY:Math.max(1,Math.round(K*Math.max(1,e.canonicalFps))),clips:w,scenes:G,compositionWidth:ne(h?.getAttribute("data-width"))??1920,compositionHeight:ne(h?.getAttribute("data-height"))??1080}}var yt=/^(?![a-zA-Z][a-zA-Z\d+\-.]*:)(?!\/\/)(?!\/)(?!\.\.?\/).+/,bt=e=>new Promise(n=>{let i=!1,a=Date.now(),c=null,p=y=>{i||(i=!0,c!=null&&window.clearTimeout(c),n({status:y,elapsedMs:Math.max(0,Date.now()-a)}))};e.addEventListener("load",()=>p("load"),{once:!0}),e.addEventListener("error",()=>p("error"),{once:!0}),c=window.setTimeout(()=>p("timeout"),8e3)});function ot(e){for(;e.firstChild;)e.removeChild(e.firstChild);e.textContent=""}function ht(e,n){let i=e.trim();if(!i)return e;try{return yt.test(i)?new URL(i,document.baseURI).toString():n?new URL(i,n).toString():new URL(i,document.baseURI).toString()}catch{return e}}async function rt(e){let n=null;e.hostCompositionId&&(n=Array.from(e.sourceNode.querySelectorAll("[data-composition-id]")).find(s=>s.getAttribute("data-composition-id")===e.hostCompositionId)??null);let i=n??e.sourceNode,a=Array.from(i.querySelectorAll("style"));for(let f of a){let s=f.cloneNode(!0);s instanceof HTMLStyleElement&&(document.head.appendChild(s),e.injectedStyles.push(s))}let c=Array.from(i.querySelectorAll("script")),p=[];for(let f of c){let s=f.getAttribute("type")?.trim()??"",h=f.getAttribute("src")?.trim()??"";if(h){let b=ht(h,e.compositionUrl);p.push({kind:"external",src:b,type:s})}else{let b=f.textContent?.trim()??"";b&&p.push({kind:"inline",content:b,type:s})}f.parentNode?.removeChild(f)}let y=Array.from(i.querySelectorAll("style"));for(let f of y)f.parentNode?.removeChild(f);if(n){let f=document.importNode(n,!0),s=n.getAttribute("data-width"),h=n.getAttribute("data-height"),b=e.parseDimensionPx(s),R=e.parseDimensionPx(h);f.style.position="relative",f.style.width=b||"100%",f.style.height=R||"100%",b&&f.style.setProperty("--comp-width",b),R&&f.style.setProperty("--comp-height",R),s&&e.host.setAttribute("data-width",s),h&&e.host.setAttribute("data-height",h),b&&e.host instanceof HTMLElement&&(e.host.style.width=b),R&&e.host instanceof HTMLElement&&(e.host.style.height=R),e.host.appendChild(f)}else e.hasTemplate?e.host.appendChild(document.importNode(i,!0)):e.host.innerHTML=e.fallbackBodyInnerHtml;for(let f of p){let s=document.createElement("script");if(f.type&&(s.type=f.type),s.async=!1,f.kind==="external"?s.src=f.src:f.type.toLowerCase()==="module"?s.textContent=f.content:s.textContent=`(function(){${f.content}})();`,document.body.appendChild(s),e.injectedScripts.push(s),f.kind==="external"){let h=await bt(s);h.status!=="load"&&e.onDiagnostic?.({code:"external_composition_script_load_issue",details:{hostCompositionId:e.hostCompositionId,hostCompositionSrc:e.hostCompositionSrc,resolvedScriptSrc:f.src,loadStatus:h.status,elapsedMs:h.elapsedMs}})}}}async function at(e){let n=Array.from(document.querySelectorAll("[data-composition-src]"));n.length!==0&&await Promise.all(n.map(async i=>{let a=i.getAttribute("data-composition-src");if(!a)return;let c=null;try{c=new URL(a,document.baseURI)}catch{c=null}ot(i);try{let p=i.getAttribute("data-composition-id"),y=p!=null?document.querySelector(`template#${CSS.escape(p)}-template`):null;if(y){await rt({host:i,hostCompositionId:p,hostCompositionSrc:a,sourceNode:y.content,hasTemplate:!0,fallbackBodyInnerHtml:"",compositionUrl:c,injectedStyles:e.injectedStyles,injectedScripts:e.injectedScripts,parseDimensionPx:e.parseDimensionPx,onDiagnostic:e.onDiagnostic});return}let f=await fetch(a);if(!f.ok)throw new Error(`HTTP ${f.status}`);let s=await f.text(),b=new DOMParser().parseFromString(s,"text/html"),R=(p?b.querySelector(`template#${CSS.escape(p)}-template`):null)??b.querySelector("template"),T=R?R.content:b.body;await rt({host:i,hostCompositionId:p,hostCompositionSrc:a,sourceNode:T,hasTemplate:!!R,fallbackBodyInnerHtml:b.body.innerHTML,compositionUrl:c,injectedStyles:e.injectedStyles,injectedScripts:e.injectedScripts,parseDimensionPx:e.parseDimensionPx,onDiagnostic:e.onDiagnostic})}catch(p){e.onDiagnostic?.({code:"external_composition_load_failed",details:{hostCompositionId:i.getAttribute("data-composition-id"),hostCompositionSrc:a,errorMessage:p instanceof Error?p.message:"unknown_error"}}),ot(i)}}))}function st(){let e=tt(),n=window,i=null,a=null,c=[],p=new Set,y=null;if(typeof n.__hfRuntimeTeardown=="function")try{n.__hfRuntimeTeardown()}catch{}window.__timelines=window.__timelines||{};let f=t=>{c.push(t)},s=(t,r,o)=>{let d=o??`${t}:${JSON.stringify(r)}`;p.has(d)||(p.add(d),Q({source:"hf-preview",type:"diagnostic",code:t,details:r}))},h=t=>{let r={scale:1,focusX:960,focusY:540},o=[],d=[],l={time:t.getTime(),duration:t.getDuration(),isPlaying:t.isPlaying(),renderMode:!1,timelineDirty:!1};return{play:t.play,pause:t.pause,seek:t.seek,getTime:t.getTime,getDuration:t.getDuration,isPlaying:t.isPlaying,getMainTimeline:()=>null,getElementBounds:()=>{},getElementsAtPoint:()=>{},setElementPosition:()=>{},previewElementPosition:()=>{},setElementKeyframes:()=>{},setElementScale:()=>{},setElementFontSize:()=>{},setElementTextContent:()=>{},setElementTextColor:()=>{},setElementTextShadow:()=>{},setElementTextFontWeight:()=>{},setElementTextFontFamily:()=>{},setElementTextOutline:()=>{},setElementTextHighlight:()=>{},setElementVolume:()=>{},setStageZoom:()=>{},getStageZoom:()=>r,setStageZoomKeyframes:()=>{},getStageZoomKeyframes:()=>o,addElement:()=>!1,removeElement:()=>!1,updateElementTiming:()=>!1,setElementTiming:()=>{},updateElementSrc:()=>!1,updateElementLayer:()=>!1,updateElementBasePosition:()=>!1,markTimelineDirty:()=>{},isTimelineDirty:()=>!1,rebuildTimeline:()=>{},ensureTimeline:()=>{},enableRenderMode:()=>{},disableRenderMode:()=>{},renderSeek:t.renderSeek,getElementVisibility:()=>({visible:!1}),getVisibleElements:()=>d,getRenderState:()=>({...l,time:t.getTime(),duration:t.getDuration(),isPlaying:t.isPlaying()})}},b=1/60,R=.75,T=.75,N=.35,P=900,Z=3,W=2,oe=.05,re=100,ie=240,se=t=>{if(t instanceof Error)return t.message||String(t);if(typeof t=="string")return t;try{return JSON.stringify(t)}catch{return String(t??"")}},u=t=>{let r=t.toLowerCase();return r.includes("cannot read properties of null")||r.includes("cannot set properties of null")?{code:"runtime_null_dom_access",category:"dom-null-access"}:r.includes("failed to execute 'queryselector'")?{code:"runtime_invalid_selector",category:"selector-invalid"}:r.includes("is not defined")?{code:"runtime_reference_missing",category:"reference-missing"}:{code:"runtime_script_error",category:"script-error"}},g=t=>{if(t==null||t.trim()==="")return null;let r=Number.parseFloat(t);return!Number.isFinite(r)||r<=0?null:`${r}px`},S=()=>{let t=document.querySelector('[data-composition-id][data-root="true"]');if(t instanceof HTMLElement)return t;let r=Array.from(document.querySelectorAll("[data-composition-id]"));return r.length===0?null:r.find(o=>!o.parentElement?.closest("[data-composition-id]"))??r[0]??null},C=()=>{let t=S();if(!t)return;let r=g(t.getAttribute("data-width")),o=g(t.getAttribute("data-height"));r&&(t.style.width=r),o&&(t.style.height=o),r&&t.style.setProperty("--comp-width",r),o&&t.style.setProperty("--comp-height",o)},v=()=>{let t=S(),r=Array.from(document.querySelectorAll("[data-composition-id]")).filter(o=>o.hasAttribute("data-duration")||o.hasAttribute("data-end"));for(let o of r)t&&o===t||(o.removeAttribute("data-duration"),o.removeAttribute("data-end"))},w=()=>{let t=S();if(!t)return;t.style.position||(t.style.position="relative"),t.style.overflow="hidden";let r=g(t.getAttribute("data-width")),o=g(t.getAttribute("data-height"));r&&(t.style.width=r),o&&(t.style.height=o);let d=Array.from(t.children);for(let l of d){let L=l.tagName.toLowerCase();if(L==="script"||L==="style"||L==="link"||L==="meta"||!l.hasAttribute("data-start"))continue;let $=(l.style.top==="0px"||l.style.top==="0")&&(l.style.left==="0px"||l.style.left==="0")&&l.style.width==="100%"&&l.style.height==="100%",ue=/translate\(\s*-50%\s*,\s*-50%\s*\)/.test(l.style.transform);if($&&ue&&!l.hasAttribute("data-width")&&!l.hasAttribute("data-height")){let te=l.style.top,k=l.style.left,M=l.style.width,A=l.style.height;l.style.top="",l.style.left="",l.style.width="",l.style.height="";let _=window.getComputedStyle(l);_.top!=="auto"||_.bottom!=="auto"||_.left!=="auto"||_.right!=="auto"||_.width!=="0px"||_.height!=="0px"||(l.style.top=te,l.style.left=k,l.style.width=M,l.style.height=A)}let B=window.getComputedStyle(l),H=B.position;if(H!=="absolute"&&H!=="fixed"&&(l.style.position="absolute"),!!l.style.top||!!l.style.bottom||B.top!=="auto"||B.bottom!=="auto"||(l.style.top="0"),!!l.style.left||!!l.style.right||B.left!=="auto"||B.right!=="auto"||(l.style.left="0"),L!=="audio"){let te=g(l.getAttribute("data-width")),k=g(l.getAttribute("data-height")),M=B.width!=="0px"&&B.width!=="auto",A=B.height!=="0px"&&B.height!=="auto";te?!l.style.width&&!M&&(l.style.width=te):!l.style.width&&B.width==="0px"&&(l.style.width="100%"),k?!l.style.height&&!A&&(l.style.height=k):!l.style.height&&B.height==="0px"&&(l.style.height="100%")}}},G=(t,r=0)=>pe({timelineRegistry:window.__timelines??{}}).resolveStartForElement(t,r),O=t=>pe({timelineRegistry:window.__timelines??{}}).resolveDurationForElement(t),I=!document.querySelector("[data-composition-src]"),K=t=>{if(!t||typeof t.duration!="function")return null;try{let r=Number(t.duration());return Number.isFinite(r)?Math.max(0,r):null}catch{return null}},q=t=>typeof t=="number"&&Number.isFinite(t)&&t>b,xe=t=>{let r=Number(t.getAttribute("data-duration"));if(Number.isFinite(r)&&r>0)return r;let o=Number(t.getAttribute("data-playback-start")??t.getAttribute("data-media-start")??"0"),d=Number.isFinite(o)?Math.max(0,o):0;return Number.isFinite(t.duration)&&t.duration>d?Math.max(0,t.duration-d):null},E=()=>{let t=Array.from(document.querySelectorAll("video[data-start], audio[data-start]"));if(t.length===0)return null;let r=0;for(let o of t){let d=G(o,0);if(!Number.isFinite(d))continue;let l=xe(o);l==null||l<=b||(r=Math.max(r,Math.max(0,d)+l))}return r>b?r:null},m=()=>{let t=E();return typeof t!="number"||!Number.isFinite(t)||t<=b?null:t},x=t=>q(t)?Math.max(b,t*R):b,j=(t,r=0)=>{let o=K(t),d=m(),l=Number.isFinite(r)&&r>b?r:0,L=0;q(o)?L=Math.max(o,l):q(d)?L=Math.max(d,l):L=l;let $=Math.max(1,Number(e.maxTimelineDurationSeconds)||1800);return L>0?Math.max(0,Math.min(L,$)):0},F=()=>{let t=window.__timelines??{},r=pe({timelineRegistry:t}),o=m(),d=x(o),l=k=>{let M=document.querySelector(`[data-composition-id="${CSS.escape(k)}"]`);return M?r.resolveStartForElement(M,0):0},L=k=>{let M=window.gsap;if(!M||typeof M.timeline!="function")return null;let A=M.timeline({paused:!0});for(let _ of k)A.add(_.timeline,l(_.compositionId));return A},$=(k,M)=>{if(!q(k))return null;let A=window.gsap;if(!A||typeof A.timeline!="function")return null;let _=A.timeline({paused:!0});if(M)try{_.add(M,0)}catch{}let z=_;if(typeof z.to=="function")try{z.to({},{duration:k})}catch{}return _},ue=(k,M)=>{let A=k;if(typeof A.getChildren!="function")return[];try{let _=A.getChildren(!0,!0,!0)??[];if(!Array.isArray(_))return[];let z=[];for(let X of M)if(!_.some(ye=>ye===X.timeline))try{let ye=l(X.compositionId);k.add(X.timeline,ye),z.push(X.compositionId)}catch{}return z}catch{return[]}},B=S(),H=B?.getAttribute("data-composition-id")??null;if(!H)return{timeline:null};let ee=t[H]??null,U=(()=>{if(!B)return[];let k=new Set,M=Array.from(B.querySelectorAll("[data-composition-id]")),A=[];for(let _ of M){let z=_.getAttribute("data-composition-id");if(!z||z===H||k.has(z))continue;k.add(z);let X=t[z]??null;if(!X||typeof X.play!="function"||typeof X.pause!="function")continue;let fe=K(X);A.push({compositionId:z,timeline:X,durationSeconds:fe??0})}return A})(),te=k=>{for(let M of k){let A=M.timeline;if(typeof A.paused=="function")try{A.paused(!1)}catch{}}};if(U.length>0&&te(U),ee){let k=U.length>0?ue(ee,U):[];if((U.length>0||!document.querySelector("[data-composition-id]:not([data-composition-id='"+H+"'])"))&&(Y=!0),k.length>0)try{let A=ee.time();ee.seek(A,!1)}catch{}let M=K(ee);if(!q(M)&&U.length>0){let A=U.map(ye=>ye.compositionId),_=L(U),z=K(_);if(_&&q(z))return{timeline:_,selectedTimelineIds:A,selectedDurationSeconds:z,mediaDurationFloorSeconds:o,diagnostics:{code:"root_timeline_unusable_fallback",details:{rootCompositionId:H,rootDurationSeconds:M,fallbackKind:"composite_by_root_children",minCandidateDurationSeconds:d,selectedDurationSeconds:z,mediaDurationFloorSeconds:o,selectedTimelineIds:A,autoNestedChildren:k}}};let X=$(o??0,ee),fe=K(X);if(X&&q(fe))return{timeline:X,selectedTimelineIds:[H],selectedDurationSeconds:fe,mediaDurationFloorSeconds:o,diagnostics:{code:"root_timeline_unusable_media_floor_fallback",details:{rootCompositionId:H,rootDurationSeconds:M,fallbackKind:"media_duration_floor",mediaDurationFloorSeconds:o,selectedDurationSeconds:fe,selectedTimelineIds:[H],autoNestedChildren:k}}}}if(!q(M)&&U.length===0){let A=$(o??0,ee),_=K(A);if(A&&q(_))return{timeline:A,selectedTimelineIds:[H],selectedDurationSeconds:_,mediaDurationFloorSeconds:o,diagnostics:{code:"root_timeline_unusable_media_floor_fallback",details:{rootCompositionId:H,rootDurationSeconds:M,fallbackKind:"media_duration_floor",mediaDurationFloorSeconds:o,selectedDurationSeconds:_,selectedTimelineIds:[H]}}}}return{timeline:ee,selectedTimelineIds:[H],selectedDurationSeconds:M,mediaDurationFloorSeconds:o,diagnostics:k.length>0?{code:"root_timeline_auto_nested_children",details:{rootCompositionId:H,selectedDurationSeconds:M,autoNestedChildren:k}}:void 0}}if(U.length>0){let k=U.map(_=>_.compositionId),M=L(U),A=K(M);if(M)return{timeline:M,selectedTimelineIds:k,selectedDurationSeconds:A,mediaDurationFloorSeconds:o,diagnostics:{code:"root_timeline_missing_fallback",details:{rootCompositionId:H,fallbackKind:"composite_by_root_children",minCandidateDurationSeconds:d,selectedDurationSeconds:A,mediaDurationFloorSeconds:o,selectedTimelineIds:k}}}}return{timeline:null}},D=()=>{let t=e.capturedTimeline;if(!t||typeof t.time!="function")return;let r=Number(t.time());Number.isFinite(r)&&(e.currentTime=Math.max(0,r))},Y=!1,J=()=>{if(!I)return!1;let t=e.capturedTimeline,r=K(t),o=q(r);if(t&&o&&Y)return!1;let d=F();return d.timeline?t&&t===d.timeline?(typeof t.timeScale=="function"&&t.timeScale(e.playbackRate),!1):(e.capturedTimeline=d.timeline,typeof e.capturedTimeline.timeScale=="function"&&e.capturedTimeline.timeScale(e.playbackRate),d.diagnostics&&Q({source:"hf-preview",type:"diagnostic",code:d.diagnostics.code,details:d.diagnostics.details}),Q({source:"hf-preview",type:"diagnostic",code:"timeline_bound",details:{selectedTimelineIds:d.selectedTimelineIds??[],selectedDurationSeconds:d.selectedDurationSeconds??null,mediaDurationFloorSeconds:d.mediaDurationFloorSeconds??null}}),!0):!1},Te=()=>{let t=S();if(!(t instanceof HTMLElement))return;let r=t.getBoundingClientRect(),o=Number(t.getAttribute("data-width")),d=Number(t.getAttribute("data-height")),l=window.getComputedStyle(t),L=Number.isFinite(o)&&o>0&&Number.isFinite(d)&&d>0,$=r.width<=0||r.height<=0||t.clientWidth<=0||t.clientHeight<=0;!L||!$||s("root_stage_layout_zero",{compositionId:t.getAttribute("data-composition-id")??null,declaredWidth:o,declaredHeight:d,rectWidth:Math.round(r.width),rectHeight:Math.round(r.height),clientWidth:t.clientWidth,clientHeight:t.clientHeight,display:l.display,visibility:l.visibility,overflow:l.overflow},`root-stage-layout-zero:${t.getAttribute("data-composition-id")??"unknown"}`)},le=()=>{e.tornDown||(y!=null&&window.cancelAnimationFrame(y),y=window.requestAnimationFrame(()=>{y=null,Te()}))},Ne=()=>{i=t=>{let r=se(t.error??t.message).slice(0,ie);if(!r)return;let o=u(r);Q({source:"hf-preview",type:"diagnostic",code:o.code,details:{category:o.category,message:r,filename:t.filename||null,line:Number.isFinite(t.lineno)?t.lineno:null,column:Number.isFinite(t.colno)?t.colno:null}})},a=t=>{let r=se(t.reason).slice(0,ie);if(!r)return;let o=u(r);Q({source:"hf-preview",type:"diagnostic",code:`${o.code}_unhandled_rejection`,details:{category:`${o.category}-unhandled-rejection`,message:r}})},window.addEventListener("error",i),window.addEventListener("unhandledrejection",a)},ve=()=>{let t=Array.from(document.querySelectorAll("img, video, audio, source, link[rel='stylesheet']"));for(let o of t){let d=()=>{if(!(o instanceof Element))return;let l=o.tagName.toLowerCase(),L=o.getAttribute("src")??o.getAttribute("href")??o.getAttribute("poster")??null,$=l==="link"?"runtime_stylesheet_load_failed":"runtime_asset_load_failed";s($,{tagName:l,assetUrl:L,currentSrc:(o instanceof HTMLImageElement||o instanceof HTMLMediaElement)&&o.currentSrc||null,readyState:o instanceof HTMLMediaElement?o.readyState:null,networkState:o instanceof HTMLMediaElement?o.networkState:null},`${$}:${l}:${L??"unknown"}`)};o.addEventListener("error",d),f(()=>{o.removeEventListener("error",d)})}let r=document.fonts;r&&r.ready.then(()=>{if(e.tornDown)return;let o=Array.from(r).filter(d=>d.status==="error").map(d=>d.family).filter(d=>!!d).slice(0,10);o.length!==0&&s("runtime_font_load_issue",{failedFamilies:o,totalFaces:Array.from(r).length},`runtime-font-load-issue:${o.join("|")}`)}).catch(()=>{})},Fe=(t,r)=>{if(!t.timeline)return!1;let o=e.capturedTimeline;if(o&&o===t.timeline)return!1;let d=Math.max(0,e.currentTime||0),l=e.isPlaying;e.capturedTimeline=t.timeline,typeof e.capturedTimeline.timeScale=="function"&&e.capturedTimeline.timeScale(e.playbackRate);try{e.capturedTimeline.pause(),e.capturedTimeline.seek(d,!1),l&&e.capturedTimeline.play()}catch{}return Q({source:"hf-preview",type:"diagnostic",code:"timeline_loop_guard_rebind",details:{reason:r,previousTime:d,selectedTimelineIds:t.selectedTimelineIds??[],selectedDurationSeconds:t.selectedDurationSeconds??null,mediaDurationFloorSeconds:t.mediaDurationFloorSeconds??null}}),!0},ce=null,He=!1,Ee=new Set,Re=()=>{e.tornDown||(ce!=null&&window.clearTimeout(ce),ce=window.setTimeout(()=>{if(e.tornDown)return;ce=null;let t=F();if(!t.timeline||!q(t.mediaDurationFloorSeconds??null))return;if(!e.capturedTimeline){J()&&(de(),ae(!0));return}if(He)return;let o=K(e.capturedTimeline),d=t.selectedDurationSeconds??K(t.timeline);q(d)&&(!q(o)||d>=o+oe)&&Fe(t,"manual")&&(He=!0,Q({source:"hf-preview",type:"diagnostic",code:"timeline_rebind_after_media_metadata",details:{previousDurationSeconds:o??null,selectedDurationSeconds:d??null,selectedTimelineIds:t.selectedTimelineIds??[],mediaDurationFloorSeconds:t.mediaDurationFloorSeconds??null}}),de(),ae(!0))},re))},ct=()=>{for(let t of Ee)t.removeEventListener("loadedmetadata",Re),t.removeEventListener("durationchange",Re);Ee.clear()},we=()=>{if(e.tornDown)return;let t=Array.from(document.querySelectorAll("video, audio"));for(let r of t)Ee.has(r)||(Ee.add(r),r.addEventListener("loadedmetadata",Re),r.addEventListener("durationchange",Re))},We=()=>{let t=Ze({resolveStartSeconds:d=>G(d,0)});Ye({clips:t.mediaClips,timeSeconds:e.currentTime,playing:e.isPlaying,playbackRate:e.playbackRate});let r=document.querySelector("[data-composition-id]")?.getAttribute("data-composition-id")??null,o=Array.from(document.querySelectorAll("[data-start]"));for(let d of o){if(!(d instanceof HTMLElement))continue;let l=d.tagName.toLowerCase();if(l==="script"||l==="style"||l==="link"||l==="meta")continue;if(!d.getAttribute("data-composition-id")){let te=d.closest("[data-composition-id]")?.getAttribute("data-composition-id")??null;if(te&&te!==r)continue}let $=G(d,0),ue=O(d),B=ue!=null&&ue>0?$+ue:Number.POSITIVE_INFINITY,H=B,ee=d.getAttribute("data-composition-id");if(ee&&!Number.isFinite(B)){let U=(window.__timelines??{})[ee];if(U&&typeof U.duration=="function"){let te=U.duration();te>0&&(H=$+te)}}let Pe=e.currentTime>=$&&(Number.isFinite(H)?e.currentTime<H:!0);d.style.visibility=Pe?"visible":"hidden"}},ae=t=>{D();let r=Math.max(0,Math.round((e.currentTime||0)*e.canonicalFps)),o=Date.now();(t||r!==e.bridgeLastPostedFrame||e.isPlaying!==e.bridgeLastPostedPlaying||e.bridgeMuted!==e.bridgeLastPostedMuted||o-e.bridgeLastPostedAt>=e.bridgeMaxPostIntervalMs)&&(e.bridgeLastPostedFrame=r,e.bridgeLastPostedPlaying=e.isPlaying,e.bridgeLastPostedMuted=e.bridgeMuted,e.bridgeLastPostedAt=o,Q({source:"hf-preview",type:"state",frame:r,isPlaying:e.isPlaying,muted:e.bridgeMuted,playbackRate:e.playbackRate}))},de=()=>{v(),C(),w();let t=S();if(t){let o=g(t.getAttribute("data-width")),d=g(t.getAttribute("data-height")),l=o?parseInt(o,10):0,L=d?parseInt(d,10):0;l>0&&L>0&&Q({source:"hf-preview",type:"stage-size",width:l,height:L})}J();let r=it({canonicalFps:e.canonicalFps,maxTimelineDurationSeconds:e.maxTimelineDurationSeconds});window.__clipManifest=r,Q(r),le()},ge=(t,r=0)=>{for(let o of e.deterministicAdapters){try{t==="discover"&&o.discover(),t==="pause"&&o.pause(),t==="play"&&o.play&&o.play()}catch{}if(t==="discover")try{o.seek({time:r})}catch{}}};I||at({injectedStyles:e.injectedCompStyles,injectedScripts:e.injectedCompScripts,parseDimensionPx:g,onDiagnostic:({code:t,details:r})=>{Q({source:"hf-preview",type:"diagnostic",code:t,details:r})}}).finally(()=>{I=!0,ge("discover",e.currentTime),we(),ve(),de(),ae(!0)});let Me=Je({postMessage:t=>Q(t)});Me.installPickerApi();let Oe=t=>{let r=Number(t);!Number.isFinite(r)||r<=0?e.playbackRate=1:e.playbackRate=Math.max(.1,Math.min(5,r)),e.capturedTimeline&&typeof e.capturedTimeline.timeScale=="function"&&e.capturedTimeline.timeScale(e.playbackRate);let o=document.querySelectorAll("video, audio");for(let d of o)if(d instanceof HTMLMediaElement)try{d.playbackRate=e.playbackRate}catch{}},V=et({getTimeline:()=>e.capturedTimeline,setTimeline:t=>{e.capturedTimeline=t},getIsPlaying:()=>e.isPlaying,setIsPlaying:t=>{e.isPlaying=t},getPlaybackRate:()=>e.playbackRate,setPlaybackRate:Oe,getCanonicalFps:()=>e.canonicalFps,onSyncMedia:(t,r)=>{e.currentTime=Math.max(0,Number(t)||0),e.isPlaying=r,We()},onStatePost:ae,onDeterministicSeek:t=>{for(let r of e.deterministicAdapters)try{r.seek({time:Number(t)||0})}catch{}},onDeterministicPause:()=>ge("pause"),onDeterministicPlay:()=>ge("play"),onRenderFrameSeek:()=>{},onShowNativeVideos:()=>{},getSafeDuration:()=>j(e.capturedTimeline,0)});window.__player=h(V),window.__playerReady=!0,window.__renderReady=!0,qe(Q),be("composition_loaded",{duration:V.getDuration(),compositionId:document.querySelector("[data-composition-id]")?.getAttribute("data-composition-id")??null}),e.controlBridgeHandler=Ue({onPlay:()=>{V.play(),be("composition_played",{time:V.getTime()})},onPause:()=>{V.pause(),be("composition_paused",{time:V.getTime()})},onSeek:(t,r)=>{let o=Math.max(0,t)/e.canonicalFps;V.seek(o),be("composition_seeked",{time:o})},onSetMuted:t=>{e.bridgeMuted=t;let r=document.querySelectorAll("video, audio");for(let o of r)o instanceof HTMLMediaElement&&(o.muted=t)},onSetPlaybackRate:t=>Oe(t),onEnablePickMode:()=>Me.enablePickMode(),onDisablePickMode:()=>Me.disablePickMode()}),J(),e.capturedTimeline&&(V._timeline=e.capturedTimeline),I&&setTimeout(()=>{let t=e.capturedTimeline;J()&&e.capturedTimeline!==t&&(V._timeline=e.capturedTimeline),ge("discover",e.currentTime),de(),ae(!0)},0),e.deterministicAdapters=[Ve({resolveStartSeconds:t=>G(t,0)}),Ke(),$e({getTimeline:()=>e.capturedTimeline}),Ge(),ze()],Ne(),ge("discover"),we(),e.timelinePollIntervalId&&clearInterval(e.timelinePollIntervalId);let ke=0,Ae=null,je=0,_e=!1,me=0,Be=()=>{je=Date.now(),_e=!1,me=0};e.timelinePollIntervalId=setInterval(()=>{ke+=1;let r=e.isPlaying&&e.capturedTimeline!=null&&Math.max(0,e.currentTime||0)<W?!1:J();if(e.capturedTimeline&&!V._timeline&&(V._timeline=e.capturedTimeline),(r||ke%20===0)&&de(),ke%10===0&&we(),D(),e.isPlaying&&e.capturedTimeline){let o=Math.max(0,e.currentTime||0),d=Ae,l=j(e.capturedTimeline,0);if(l>0&&o>=l){V.pause(),V.seek(l),Ae=l,me=0,ae(!0);return}if(d!=null&&d>=T&&o<=N?me+=1:me=0,!_e&&me>=Z&&Date.now()-je>P){let $=F();Fe($,"loop_guard")&&(_e=!0,me=0)}Ae=Math.max(0,e.currentTime||0)}else Ae=Math.max(0,e.currentTime||0);e.isPlaying&&We(),ae(!1)},50),de(),ae(!0);let ut=V.seek;V.seek=t=>{Be(),ut(t)};let dt=V.renderSeek;V.renderSeek=t=>{Be(),dt(t)};let De=()=>{if(!e.tornDown){e.tornDown=!0,e.timelinePollIntervalId&&(clearInterval(e.timelinePollIntervalId),e.timelinePollIntervalId=null),ce!=null&&(window.clearTimeout(ce),ce=null),y!=null&&(window.cancelAnimationFrame(y),y=null),ct(),e.controlBridgeHandler&&(window.removeEventListener("message",e.controlBridgeHandler),e.controlBridgeHandler=null),i&&(window.removeEventListener("error",i),i=null),a&&(window.removeEventListener("unhandledrejection",a),a=null),e.beforeUnloadHandler&&(window.removeEventListener("beforeunload",e.beforeUnloadHandler),e.beforeUnloadHandler=null),Me.disablePickMode();for(let t of e.deterministicAdapters)if(!(!t||typeof t.revert!="function"))try{t.revert()}catch{}e.deterministicAdapters=[];for(let t of c.splice(0))try{t()}catch{}for(let t of e.injectedCompStyles)try{t.remove()}catch{}e.injectedCompStyles=[];for(let t of e.injectedCompScripts)try{t.remove()}catch{}e.injectedCompScripts=[],e.capturedTimeline=null,n.__hfRuntimeTeardown===De&&(n.__hfRuntimeTeardown=null)}};n.__hfRuntimeTeardown=De,e.beforeUnloadHandler=De,window.addEventListener("beforeunload",e.beforeUnloadHandler)}window.__timelines=window.__timelines||{};function lt(){let e=window;e.__hyperframeRuntimeBootstrapped||(e.__hyperframeRuntimeBootstrapped=!0,st())}document.readyState==="loading"?document.addEventListener("DOMContentLoaded",lt,{once:!0}):lt();})();
13
+
package/dist/index.d.ts CHANGED
@@ -9,10 +9,10 @@ export { createRenderJob, executeRenderJob, RenderCancelledError, type RenderCon
9
9
  export { createCaptureSession, initializeSession, closeCaptureSession, captureFrame, captureFrameToBuffer, getCompositionDuration, getCapturePerfSummary, prepareCaptureSessionForReuse, type CaptureOptions, type CaptureSession, type CaptureResult, type CapturePerfSummary, type BeforeCaptureHook, } from "./services/frameCapture.js";
10
10
  export { createFileServer, type FileServerOptions, type FileServerHandle, } from "./services/fileServer.js";
11
11
  export { createVideoFrameInjector } from "./services/videoFrameInjector.js";
12
- export { resolveConfig, DEFAULT_CONFIG, type ProducerConfig, } from "./config.js";
12
+ export { resolveConfig, DEFAULT_CONFIG, type ProducerConfig } from "./config.js";
13
13
  export { type ProducerLogger, type LogLevel, createConsoleLogger, defaultLogger, } from "./logger.js";
14
14
  export { createRenderHandlers, createProducerApp, startServer, type HandlerOptions, type ServerOptions, type RenderHandlers, } from "./server.js";
15
15
  export { quantizeTimeToFrame } from "./utils/parityContract.js";
16
- export { resolveRenderPaths, type RenderPaths, } from "./utils/paths.js";
16
+ export { resolveRenderPaths, type RenderPaths } from "./utils/paths.js";
17
17
  export { prepareHyperframeLintBody, runHyperframeLint, type PreparedHyperframeLintInput, } from "./services/hyperframeLint.js";
18
18
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,EACL,eAAe,EACf,gBAAgB,EAChB,oBAAoB,EACpB,KAAK,YAAY,EACjB,KAAK,SAAS,EACd,KAAK,YAAY,EACjB,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,GACtB,MAAM,kCAAkC,CAAC;AAG1C,OAAO,EACL,oBAAoB,EACpB,iBAAiB,EACjB,mBAAmB,EACnB,YAAY,EACZ,oBAAoB,EACpB,sBAAsB,EACtB,qBAAqB,EACrB,6BAA6B,EAC7B,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,aAAa,EAClB,KAAK,kBAAkB,EACvB,KAAK,iBAAiB,GACvB,MAAM,4BAA4B,CAAC;AAGpC,OAAO,EACL,gBAAgB,EAChB,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,GACtB,MAAM,0BAA0B,CAAC;AAGlC,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAG5E,OAAO,EACL,aAAa,EACb,cAAc,EACd,KAAK,cAAc,GACpB,MAAM,aAAa,CAAC;AAGrB,OAAO,EACL,KAAK,cAAc,EACnB,KAAK,QAAQ,EACb,mBAAmB,EACnB,aAAa,GACd,MAAM,aAAa,CAAC;AAGrB,OAAO,EACL,oBAAoB,EACpB,iBAAiB,EACjB,WAAW,EACX,KAAK,cAAc,EACnB,KAAK,aAAa,EAClB,KAAK,cAAc,GACpB,MAAM,aAAa,CAAC;AAGrB,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EACL,kBAAkB,EAClB,KAAK,WAAW,GACjB,MAAM,kBAAkB,CAAC;AAE1B,OAAO,EACL,yBAAyB,EACzB,iBAAiB,EACjB,KAAK,2BAA2B,GACjC,MAAM,8BAA8B,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,EACL,eAAe,EACf,gBAAgB,EAChB,oBAAoB,EACpB,KAAK,YAAY,EACjB,KAAK,SAAS,EACd,KAAK,YAAY,EACjB,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,GACtB,MAAM,kCAAkC,CAAC;AAG1C,OAAO,EACL,oBAAoB,EACpB,iBAAiB,EACjB,mBAAmB,EACnB,YAAY,EACZ,oBAAoB,EACpB,sBAAsB,EACtB,qBAAqB,EACrB,6BAA6B,EAC7B,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,aAAa,EAClB,KAAK,kBAAkB,EACvB,KAAK,iBAAiB,GACvB,MAAM,4BAA4B,CAAC;AAGpC,OAAO,EACL,gBAAgB,EAChB,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,GACtB,MAAM,0BAA0B,CAAC;AAGlC,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAG5E,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,aAAa,CAAC;AAGjF,OAAO,EACL,KAAK,cAAc,EACnB,KAAK,QAAQ,EACb,mBAAmB,EACnB,aAAa,GACd,MAAM,aAAa,CAAC;AAGrB,OAAO,EACL,oBAAoB,EACpB,iBAAiB,EACjB,WAAW,EACX,KAAK,cAAc,EACnB,KAAK,aAAa,EAClB,KAAK,cAAc,GACpB,MAAM,aAAa,CAAC;AAGrB,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,KAAK,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAExE,OAAO,EACL,yBAAyB,EACzB,iBAAiB,EACjB,KAAK,2BAA2B,GACjC,MAAM,8BAA8B,CAAC"}