melies-video-editor 0.1.8 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +8 -8
- package/dist/index.js +1651 -1604
- package/dist/types/App.d.ts +37 -0
- package/dist/types/player.d.ts +4 -1
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
2
|
-
`+
|
|
3
|
-
`),
|
|
4
|
-
`),sA=T.length-1,
|
|
5
|
-
`+T[sA].replace(" at new "," at ");return n.displayName&&
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const I=require("react"),Dn=require("@xzdarcy/react-timeline-editor"),Mt=require("howler"),pt=require("antd"),$A=require("@dnd-kit/core");var nt={exports:{}},Ke={};var Lt;function pn(){if(Lt)return Ke;Lt=1;var B=I,t=Symbol.for("react.element"),a=Symbol.for("react.fragment"),u=Object.prototype.hasOwnProperty,g=B.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,E={key:!0,ref:!0,__self:!0,__source:!0};function p(F,h,P){var D,L={},q=null,Z=null;P!==void 0&&(q=""+P),h.key!==void 0&&(q=""+h.key),h.ref!==void 0&&(Z=h.ref);for(D in h)u.call(h,D)&&!E.hasOwnProperty(D)&&(L[D]=h[D]);if(F&&F.defaultProps)for(D in h=F.defaultProps,h)L[D]===void 0&&(L[D]=h[D]);return{$$typeof:t,type:F,key:q,ref:Z,props:L,_owner:g.current}}return Ke.Fragment=a,Ke.jsx=p,Ke.jsxs=p,Ke}var Ge={};var xt;function bn(){return xt||(xt=1,process.env.NODE_ENV!=="production"&&(function(){var B=I,t=Symbol.for("react.element"),a=Symbol.for("react.portal"),u=Symbol.for("react.fragment"),g=Symbol.for("react.strict_mode"),E=Symbol.for("react.profiler"),p=Symbol.for("react.provider"),F=Symbol.for("react.context"),h=Symbol.for("react.forward_ref"),P=Symbol.for("react.suspense"),D=Symbol.for("react.suspense_list"),L=Symbol.for("react.memo"),q=Symbol.for("react.lazy"),Z=Symbol.for("react.offscreen"),JA=Symbol.iterator,bA="@@iterator";function QA(n){if(n===null||typeof n!="object")return null;var f=JA&&n[JA]||n[bA];return typeof f=="function"?f:null}var aA=B.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function U(n){{for(var f=arguments.length,R=new Array(f>1?f-1:0),x=1;x<f;x++)R[x-1]=arguments[x];AA("error",n,R)}}function AA(n,f,R){{var x=aA.ReactDebugCurrentFrame,G=x.getStackAddendum();G!==""&&(f+="%s",R=R.concat([G]));var X=R.map(function(j){return String(j)});X.unshift("Warning: "+f),Function.prototype.apply.call(console[n],console,X)}}var iA=!1,qA=!1,K=!1,ie=!1,UA=!1,we;we=Symbol.for("react.module.reference");function Ie(n){return!!(typeof n=="string"||typeof n=="function"||n===u||n===E||UA||n===g||n===P||n===D||ie||n===Z||iA||qA||K||typeof n=="object"&&n!==null&&(n.$$typeof===q||n.$$typeof===L||n.$$typeof===p||n.$$typeof===F||n.$$typeof===h||n.$$typeof===we||n.getModuleId!==void 0))}function oe(n,f,R){var x=n.displayName;if(x)return x;var G=f.displayName||f.name||"";return G!==""?R+"("+G+")":R}function TA(n){return n.displayName||"Context"}function EA(n){if(n==null)return null;if(typeof n.tag=="number"&&U("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),typeof n=="function")return n.displayName||n.name||null;if(typeof n=="string")return n;switch(n){case u:return"Fragment";case a:return"Portal";case E:return"Profiler";case g:return"StrictMode";case P:return"Suspense";case D:return"SuspenseList"}if(typeof n=="object")switch(n.$$typeof){case F:var f=n;return TA(f)+".Consumer";case p:var R=n;return TA(R._context)+".Provider";case h:return oe(n,n.render,"ForwardRef");case L:var x=n.displayName||null;return x!==null?x:EA(n.type)||"Memo";case q:{var G=n,X=G._payload,j=G._init;try{return EA(j(X))}catch{return null}}}return null}var vA=Object.assign,VA=0,se,ae,Qe,me,ve,KA,lA;function M(){}M.__reactDisabledLog=!0;function oA(){{if(VA===0){se=console.log,ae=console.info,Qe=console.warn,me=console.error,ve=console.group,KA=console.groupCollapsed,lA=console.groupEnd;var n={configurable:!0,enumerable:!0,value:M,writable:!0};Object.defineProperties(console,{info:n,log:n,warn:n,error:n,group:n,groupCollapsed:n,groupEnd:n})}VA++}}function eA(){{if(VA--,VA===0){var n={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:vA({},n,{value:se}),info:vA({},n,{value:ae}),warn:vA({},n,{value:Qe}),error:vA({},n,{value:me}),group:vA({},n,{value:ve}),groupCollapsed:vA({},n,{value:KA}),groupEnd:vA({},n,{value:lA})})}VA<0&&U("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var z=aA.ReactCurrentDispatcher,V;function _(n,f,R){{if(V===void 0)try{throw Error()}catch(G){var x=G.stack.trim().match(/\n( *(at )?)/);V=x&&x[1]||""}return`
|
|
2
|
+
`+V+n}}var fA=!1,cA;{var ce=typeof WeakMap=="function"?WeakMap:Map;cA=new ce}function GA(n,f){if(!n||fA)return"";{var R=cA.get(n);if(R!==void 0)return R}var x;fA=!0;var G=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var X;X=z.current,z.current=null,oA();try{if(f){var j=function(){throw Error()};if(Object.defineProperty(j.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(j,[])}catch(DA){x=DA}Reflect.construct(n,[],j)}else{try{j.call()}catch(DA){x=DA}n.call(j.prototype)}}else{try{throw Error()}catch(DA){x=DA}n()}}catch(DA){if(DA&&x&&typeof DA.stack=="string"){for(var T=DA.stack.split(`
|
|
3
|
+
`),CA=x.stack.split(`
|
|
4
|
+
`),sA=T.length-1,uA=CA.length-1;sA>=1&&uA>=0&&T[sA]!==CA[uA];)uA--;for(;sA>=1&&uA>=0;sA--,uA--)if(T[sA]!==CA[uA]){if(sA!==1||uA!==1)do if(sA--,uA--,uA<0||T[sA]!==CA[uA]){var NA=`
|
|
5
|
+
`+T[sA].replace(" at new "," at ");return n.displayName&&NA.includes("<anonymous>")&&(NA=NA.replace("<anonymous>",n.displayName)),typeof n=="function"&&cA.set(n,NA),NA}while(sA>=1&&uA>=0);break}}}finally{fA=!1,z.current=X,eA(),Error.prepareStackTrace=G}var de=n?n.displayName||n.name:"",SA=de?_(de):"";return typeof n=="function"&&cA.set(n,SA),SA}function Ae(n,f,R){return GA(n,!1)}function ee(n){var f=n.prototype;return!!(f&&f.isReactComponent)}function zA(n,f,R){if(n==null)return"";if(typeof n=="function")return GA(n,ee(n));if(typeof n=="string")return _(n);switch(n){case P:return _("Suspense");case D:return _("SuspenseList")}if(typeof n=="object")switch(n.$$typeof){case h:return Ae(n.render);case L:return zA(n.type,f,R);case q:{var x=n,G=x._payload,X=x._init;try{return zA(X(G),f,R)}catch{}}}return""}var te=Object.prototype.hasOwnProperty,PA={},he=aA.ReactDebugCurrentFrame;function jA(n){if(n){var f=n._owner,R=zA(n.type,n._source,f?f.type:null);he.setExtraStackFrame(R)}else he.setExtraStackFrame(null)}function MA(n,f,R,x,G){{var X=Function.call.bind(te);for(var j in n)if(X(n,j)){var T=void 0;try{if(typeof n[j]!="function"){var CA=Error((x||"React class")+": "+R+" type `"+j+"` is invalid; it must be a function, usually from the `prop-types` package, but received `"+typeof n[j]+"`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");throw CA.name="Invariant Violation",CA}T=n[j](f,j,x,R,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(sA){T=sA}T&&!(T instanceof Error)&&(jA(G),U("%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).",x||"React class",R,j,typeof T),jA(null)),T instanceof Error&&!(T.message in PA)&&(PA[T.message]=!0,jA(G),U("Failed %s type: %s",R,T.message),jA(null))}}}var XA=Array.isArray;function ne(n){return XA(n)}function ue(n){{var f=typeof Symbol=="function"&&Symbol.toStringTag,R=f&&n[Symbol.toStringTag]||n.constructor.name||"Object";return R}}function LA(n){try{return Se(n),!1}catch{return!0}}function Se(n){return""+n}function OA(n){if(LA(n))return U("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",ue(n)),Se(n)}var Me=aA.ReactCurrentOwner,ZA={key:!0,ref:!0,__self:!0,__source:!0},Oe,je;function Xe(n){if(te.call(n,"ref")){var f=Object.getOwnPropertyDescriptor(n,"ref").get;if(f&&f.isReactWarning)return!1}return n.ref!==void 0}function We(n){if(te.call(n,"key")){var f=Object.getOwnPropertyDescriptor(n,"key").get;if(f&&f.isReactWarning)return!1}return n.key!==void 0}function qe(n,f){typeof n.ref=="string"&&Me.current}function mA(n,f){{var R=function(){Oe||(Oe=!0,U("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)",f))};R.isReactWarning=!0,Object.defineProperty(n,"key",{get:R,configurable:!0})}}function re(n,f){{var R=function(){je||(je=!0,U("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)",f))};R.isReactWarning=!0,Object.defineProperty(n,"ref",{get:R,configurable:!0})}}var Ve=function(n,f,R,x,G,X,j){var T={$$typeof:t,type:n,key:f,ref:R,props:j,_owner:X};return T._store={},Object.defineProperty(T._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:!1}),Object.defineProperty(T,"_self",{configurable:!1,enumerable:!1,writable:!1,value:x}),Object.defineProperty(T,"_source",{configurable:!1,enumerable:!1,writable:!1,value:G}),Object.freeze&&(Object.freeze(T.props),Object.freeze(T)),T};function De(n,f,R,x,G){{var X,j={},T=null,CA=null;R!==void 0&&(OA(R),T=""+R),We(f)&&(OA(f.key),T=""+f.key),Xe(f)&&(CA=f.ref,qe(f,G));for(X in f)te.call(f,X)&&!ZA.hasOwnProperty(X)&&(j[X]=f[X]);if(n&&n.defaultProps){var sA=n.defaultProps;for(X in sA)j[X]===void 0&&(j[X]=sA[X])}if(T||CA){var uA=typeof n=="function"?n.displayName||n.name||"Unknown":n;T&&mA(j,uA),CA&&re(j,uA)}return Ve(n,T,CA,G,x,Me.current,j)}}var ge=aA.ReactCurrentOwner,xA=aA.ReactDebugCurrentFrame;function WA(n){if(n){var f=n._owner,R=zA(n.type,n._source,f?f.type:null);xA.setExtraStackFrame(R)}else xA.setExtraStackFrame(null)}var yA;yA=!1;function ye(n){return typeof n=="object"&&n!==null&&n.$$typeof===t}function He(){{if(ge.current){var n=EA(ge.current.type);if(n)return`
|
|
6
6
|
|
|
7
|
-
Check the render method of \``+n+"`."}return""}}function
|
|
7
|
+
Check the render method of \``+n+"`."}return""}}function st(n){return""}var FA={};function RA(n){{var f=He();if(!f){var R=typeof n=="string"?n:n.displayName||n.name;R&&(f=`
|
|
8
8
|
|
|
9
|
-
Check the top-level render call using <`+
|
|
9
|
+
Check the top-level render call using <`+R+">.")}return f}}function HA(n,f){{if(!n._store||n._store.validated||n.key!=null)return;n._store.validated=!0;var R=RA(f);if(FA[R])return;FA[R]=!0;var x="";n&&n._owner&&n._owner!==ge.current&&(x=" It was passed a child from "+EA(n._owner.type)+"."),WA(n),U('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.',R,x),WA(null)}}function le(n,f){{if(typeof n!="object")return;if(ne(n))for(var R=0;R<n.length;R++){var x=n[R];ye(x)&&HA(x,f)}else if(ye(n))n._store&&(n._store.validated=!0);else if(n){var G=QA(n);if(typeof G=="function"&&G!==n.entries)for(var X=G.call(n),j;!(j=X.next()).done;)ye(j.value)&&HA(j.value,f)}}}function kA(n){{var f=n.type;if(f==null||typeof f=="string")return;var R;if(typeof f=="function")R=f.propTypes;else if(typeof f=="object"&&(f.$$typeof===h||f.$$typeof===L))R=f.propTypes;else return;if(R){var x=EA(f);MA(R,n.props,"prop",x,n)}else if(f.PropTypes!==void 0&&!yA){yA=!0;var G=EA(f);U("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?",G||"Unknown")}typeof f.getDefaultProps=="function"&&!f.getDefaultProps.isReactClassApproved&&U("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.")}}function tA(n){{for(var f=Object.keys(n.props),R=0;R<f.length;R++){var x=f[R];if(x!=="children"&&x!=="key"){WA(n),U("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.",x),WA(null);break}}n.ref!==null&&(WA(n),U("Invalid attribute `ref` supplied to `React.Fragment`."),WA(null))}}var hA={};function ke(n,f,R,x,G,X){{var j=Ie(n);if(!j){var T="";(n===void 0||typeof n=="object"&&n!==null&&Object.keys(n).length===0)&&(T+=" You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.");var CA=st();CA?T+=CA:T+=He();var sA;n===null?sA="null":ne(n)?sA="array":n!==void 0&&n.$$typeof===t?(sA="<"+(EA(n.type)||"Unknown")+" />",T=" Did you accidentally export a JSX literal instead of a component?"):sA=typeof n,U("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s",sA,T)}var uA=De(n,f,R,G,X);if(uA==null)return uA;if(j){var NA=f.children;if(NA!==void 0)if(x)if(ne(NA)){for(var de=0;de<NA.length;de++)le(NA[de],n);Object.freeze&&Object.freeze(NA)}else U("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");else le(NA,n)}if(te.call(f,"key")){var SA=EA(n),DA=Object.keys(f).filter(function(at){return at!=="key"}),Le=DA.length>0?"{key: someKey, "+DA.join(": ..., ")+": ...}":"{key: someKey}";if(!hA[SA+Le]){var be=DA.length>0?"{"+DA.join(": ..., ")+": ...}":"{}";U(`A props object containing a "key" prop is being spread into JSX:
|
|
10
10
|
let props = %s;
|
|
11
11
|
<%s {...props} />
|
|
12
12
|
React keys must be passed directly to JSX without using spread:
|
|
13
13
|
let props = %s;
|
|
14
|
-
<%s key={someKey} {...props} />`,le,TA,Ve,TA),se[TA+le]=!0}}return n===g?he(V):Ye(V),V}}function Ae(n,E,b){return Se(n,E,b,!0)}function FA(n,E,b){return Se(n,E,b,!1)}var YA=FA,st=Ae;We.Fragment=g,We.jsx=YA,We.jsxs=st})()),We}var Mt;function Dn(){return Mt||(Mt=1,process.env.NODE_ENV==="production"?nt.exports=hn():nt.exports=Sn()),nt.exports}var h=Dn();const pn=({action:B,row:t})=>h.jsx("div",{className:"effect0","data-action-id":B.id,"data-row-id":t.id,children:h.jsx("div",{className:"effect0-text",children:`Audio: ${B.data.name}`})}),bn=({action:B,row:t})=>h.jsx("div",{className:"effect1","data-action-id":B.id,"data-row-id":t.id,children:h.jsx("div",{className:"effect1-text",children:`Video: ${B.data.name}`})}),Fn=({action:B,row:t})=>h.jsx("div",{className:"effect2","data-action-id":B.id,"data-row-id":t.id,children:h.jsx("div",{className:"effect2-text",children:`Video audio: ${B.data.name}`})}),Qt=B=>{const t=B.toLowerCase();return t.endsWith(".mp4")||t.endsWith(".webm")||t.endsWith(".mov")||t.endsWith(".m4v")?"video":t.endsWith(".mp3")||t.endsWith(".wav")||t.endsWith(".ogg")||t.endsWith(".m4a")||t.endsWith(".aac")?"audio":"other"};class Rn{blobUrlBySrc=new Map;pendingBySrc=new Map;metaBySrc=new Map;durationSecBySrc=new Map;pendingDurationBySrc=new Map;registerSrcMeta(t,a){const g=String(t??"");if(!g)return;const u={name:a?.name?String(a.name):void 0,mimeType:a?.mimeType?String(a.mimeType):void 0},f=this.metaBySrc.get(g);this.metaBySrc.set(g,{name:f?.name??u.name,mimeType:f?.mimeType??u.mimeType})}getSrcMeta(t){const a=String(t??"");if(a)return this.metaBySrc.get(a)}getCachedDurationSec(t){const a=String(t??"");if(!a)return;const g=this.durationSecBySrc.get(a);if(g!=null&&!(!Number.isFinite(g)||g<=0))return g}async getDurationSec(t,a){const g=String(t??"");if(!g)return null;const u=this.getCachedDurationSec(g);if(u!=null)return u;const f=this.pendingDurationBySrc.get(g);if(f)return f;const p=(async()=>{const F=a??Qt(g);if(F!=="video"&&F!=="audio")return null;const Q=F==="video"?document.createElement("video"):document.createElement("audio");Q.preload="metadata";try{Q.crossOrigin="anonymous"}catch{}const v=await new Promise(D=>{let L=!1,Z=null;const dA=q=>{L||(L=!0,x(),D(q))},wA=()=>{const q=Number(Q.duration);if(Number.isFinite(q)&&q>0){dA(q);return}queueMicrotask(()=>{const vA=Number(Q.duration);dA(Number.isFinite(vA)&&vA>0?vA:null)})},KA=()=>{const q=Number(Q.duration);Number.isFinite(q)&&q>0&&dA(q)},gA=()=>dA(null),x=()=>{if(Z!=null){try{window.clearTimeout(Z)}catch{}Z=null}Q.removeEventListener("loadedmetadata",wA),Q.removeEventListener("durationchange",KA),Q.removeEventListener("error",gA);try{Q.src="",Q.load()}catch{}};Q.addEventListener("loadedmetadata",wA),Q.addEventListener("durationchange",KA),Q.addEventListener("error",gA),Z=window.setTimeout(()=>dA(null),4e3),Q.src=g});return v!=null&&Number.isFinite(v)&&v>0?(this.durationSecBySrc.set(g,v),v):null})().catch(F=>(console.warn("[mediaCache] duration probe failed:",g,F),null)).finally(()=>{this.pendingDurationBySrc.delete(g)});return this.pendingDurationBySrc.set(g,p),p}async preloadToBlobUrl(t){if(!t||t.startsWith("blob:")||t.startsWith("data:"))return t;const a=this.blobUrlBySrc.get(t);if(a)return a;const g=this.pendingBySrc.get(t);if(g)return g;const u=(async()=>{const f=await fetch(t,{cache:"force-cache"});if(!f.ok)throw new Error(`Failed to fetch ${t}: ${f.status}`);const p=await f.blob(),F=URL.createObjectURL(p);return this.blobUrlBySrc.set(t,F),F})().catch(f=>(console.warn("[mediaCache] preload failed:",t,f),t)).finally(()=>{this.pendingBySrc.delete(t)});return this.pendingBySrc.set(t,u),u}resolve(t){return this.blobUrlBySrc.get(t)??t}warm(t){t&&(t.startsWith("blob:")||t.startsWith("data:")||this.preloadToBlobUrl(t))}async warmAll(t,a){const g=[],u=new Set;for(const v of t){const D=String(v??"");if(!D||u.has(D))continue;u.add(D);const L=Qt(D);L!=="video"&&L!=="audio"||g.push(D)}if(g.length===0)return;const f=Math.max(1,Math.floor(a?.concurrency??3)),p=a?.yieldBetween!==!1;let F=0;const Q=Array.from({length:Math.min(f,g.length)},async()=>{for(;F<g.length;){const v=g[F++];await this.preloadToBlobUrl(v),p&&await new Promise(D=>setTimeout(D,0))}});await Promise.all(Q)}warmFromEditorData(t){const a=new Set,g=Array.isArray(t)?t:[];for(const u of g){const f=u?.actions;if(Array.isArray(f))for(const p of f){const F=p?.data?.src,Q=p?.data?.previewSrc;typeof F=="string"&&F&&a.add(F),typeof Q=="string"&&Q&&a.add(Q)}}for(const u of a){const f=Qt(u);(f==="video"||f==="audio")&&this.warm(u)}}}const pA=new Rn,Lt=B=>{if(!B)return;const a=B.split("#")[0].split("?")[0].toLowerCase(),g=a.lastIndexOf(".");if(g<0)return;const u=a.slice(g+1);if(u)return u==="m4a"||u==="m4v"?"mp4":u},vn=B=>{const t=String(B??"").toLowerCase();if(t){if(t==="audio/mpeg"||t==="audio/mp3")return"mp3";if(t==="audio/wav"||t==="audio/x-wav")return"wav";if(t==="audio/ogg")return"ogg";if(t==="audio/aac")return"aac";if(t==="audio/mp4"||t==="video/mp4")return"mp4"}},xt=B=>{const t=Lt(B);if(t)return t;const a=pA.getSrcMeta(B),g=a?.name?Lt(a.name):void 0;if(g)return g;const u=a?.mimeType?vn(a.mimeType):void 0;if(u)return u};class On{howlBySrc={};activeByActionId={};stopActiveAction(t){const a=this.activeByActionId[t];if(!a)return;const g=this.getHowl(a.src);try{g.stop(a.soundId)}catch{}try{a.time&&a.engine.off("afterSetTime",a.time),a.rate&&a.engine.off("afterSetPlayRate",a.rate)}catch{}delete this.activeByActionId[t]}getHowl(t){const a=pA.resolve(t),g=a,u=g;if(this.howlBySrc[u])return this.howlBySrc[u];const f=xt(t)??xt(a),p=typeof navigator<"u"&&/iPhone|iPad|iPod|Android/i.test(navigator.userAgent),F=pA.getSrcMeta(t),v=f==="mp4"||F?.mimeType?.startsWith("video/")||p,D=new Jt.Howl({src:[g],format:f?[f]:void 0,loop:!0,autoplay:!1,preload:!0,html5:v});return this.howlBySrc[u]=D,D}unlock(){try{const t=Jt.Howler.ctx;t&&t.state==="suspended"&&t.resume()}catch{}}warm(t){t&&(pA.warm(t),this.getHowl(t))}seekForEngineTime(t,a,g,u,f){const p=Number(f),F=Number.isFinite(p)?p:0,Q=t.duration();if(!Number.isFinite(Q)||Q<=0){t.seek(Math.max(0,u-g+F),a);return}const v=(u-g+F)%Q,D=v<0?v+Q:v;t.seek(D,a)}start(t){const{actionId:a,src:g,startTime:u,time:f,engine:p}=t,F=Number(t.offset??0),Q=Number.isFinite(F)?F:0,v=this.activeByActionId[a];if(v){const gA=v.src!==g,x=v.engine!==p;if(gA||x)this.stopActiveAction(a);else{const G=this.getHowl(v.src);G.rate(p.getPlayRate(),v.soundId);try{G.playing(v.soundId)||G.play(v.soundId)}catch{}p.isPlaying||this.seekForEngineTime(G,v.soundId,v.startTime,f,v.offset);return}}const D=this.getHowl(g),L=D.play();D.rate(p.getPlayRate(),L),this.seekForEngineTime(D,L,u,f,Q);const Z=()=>{this.activeByActionId[a]?.soundId===L&&this.seekForEngineTime(D,L,u,f,Q)};D.state()!=="loaded"&&D.once("load",Z,L),D.once("play",Z,L);let dA=performance.now();const wA=({time:gA})=>{if(!p.isPlaying){this.seekForEngineTime(D,L,u,gA,Q);return}const x=performance.now();if(!(x-dA<200)){dA=x;try{const G=Math.max(0,gA-u+Q),q=Number(D.seek(L));if(Number.isFinite(q)){const vA=q-G,j=Math.abs(vA),jA=p.getPlayRate();if(j>.3){this.seekForEngineTime(D,L,u,gA,Q),D.rate(jA,L);return}if(j>.04){const OA=vA>0?.95:1.05;D.rate(jA*OA,L)}else D.rate(L)!==jA&&D.rate(jA,L)}}catch{}}},KA=({rate:gA})=>{D.rate(gA,L)};p.on("afterSetTime",wA),p.on("afterSetPlayRate",KA),this.activeByActionId[a]={src:g,startTime:u,offset:Q,soundId:L,engine:p,lastResyncAtMs:dA,time:wA,rate:KA}}stop(t){const{actionId:a}=t;this.stopActiveAction(a)}reset(){const t=Object.keys(this.activeByActionId);for(const g of t)this.stopActiveAction(g);const a=Object.values(this.howlBySrc);for(const g of a)try{g.unload()}catch{}this.howlBySrc={}}}const EA=new On;class Hn{primaryEl=null;secondaryEl=null;activeEl=null;rowData=[];boundEngine=null;vfcHandle=null;rafHandle=null;isPlaying=!1;playbackRate=1;lastVideoClip=null;lastKnownTime=0;constructor(){this.tickLoop=this.tickLoop.bind(this)}attachPrimary(t){this.primaryEl=t,this.initElement(t)}attachSecondary(t){this.secondaryEl=t,this.initElement(t)}initElement(t){t&&(t.style.position="absolute",t.style.top="0",t.style.left="0",t.style.width="100%",t.style.height="100%",t.style.objectFit="contain",t.style.opacity="0",t.preload="auto")}attach(t){this.attachPrimary(t)}setEditorData(t){this.rowData=t}claimVideo(t){this.isPlaying=!!t.isPlaying;const a=Number(t.time);Number.isFinite(a)&&(this.lastKnownTime=a,this.updateState(a))}bindEngine(t){this.unbindEngine(),this.boundEngine=t,this.startLoop()}unbindEngine(){this.stopLoop(),this.boundEngine=null}startLoop(){this.rafHandle||this.vfcHandle||this.tickLoop()}stopLoop(){this.vfcHandle&&this.activeEl?.cancelVideoFrameCallback&&this.activeEl.cancelVideoFrameCallback(this.vfcHandle),this.rafHandle&&cancelAnimationFrame(this.rafHandle),this.vfcHandle=null,this.rafHandle=null}tickLoop(){if(!this.boundEngine)return;const t=this.boundEngine.getTime();this.lastKnownTime=t,this.updateState(this.lastKnownTime),this.rafHandle=requestAnimationFrame(()=>{this.rafHandle=null,this.tickLoop()})}updateState(t){if(!this.primaryEl||!this.secondaryEl)return;const a=this.findClipAtTime(t),g=t+.5;let u=this.findClipAtTime(g);if((!u||a&&u.actionId===a.actionId)&&(u=this.findNextVideoClipAfter(t)),a)this.isLoaded(this.primaryEl,a.src)?this.makeActive(this.primaryEl,a,t):this.isLoaded(this.secondaryEl,a.src)?this.makeActive(this.secondaryEl,a,t):(this.loadVideo(this.primaryEl,a.src),this.makeActive(this.primaryEl,a,t)),this.lastVideoClip=a;else{const f=this.findNextVideoClipStartAfter(t);if(f!=null&&f-t>0&&f-t<=.1&&this.lastVideoClip!=null&&t-this.lastVideoClip.end>=0&&t-this.lastVideoClip.end<=.1&&this.activeEl!=null){const F=this.activeEl;if(!F)return;const Q=Math.max(0,this.lastVideoClip.end-this.lastVideoClip.start+this.lastVideoClip.offset-.02),v=F===this.primaryEl?this.secondaryEl:this.primaryEl;v&&(v.style.opacity="0"),F.style.opacity="1";try{F.paused||F.pause();const D=F.duration;Number.isFinite(D)&&D>0?F.currentTime=Math.min(Q,Math.max(0,D-.05)):F.currentTime=Math.max(0,Q)}catch{}}else this.primaryEl.style.opacity="0",this.secondaryEl.style.opacity="0",this.activeEl=null,this.primaryEl.paused||this.primaryEl.pause(),this.secondaryEl.paused||this.secondaryEl.pause()}if(u&&(!a||u.actionId!==a.actionId)){const f=this.primaryEl===this.activeEl?this.secondaryEl:this.primaryEl;f&&!this.isLoaded(f,u.src)&&(this.loadVideo(f,u.src),f.currentTime=u.offset)}}makeActive(t,a,g){const u=t===this.primaryEl?this.secondaryEl:this.primaryEl;u&&(u.style.opacity="0"),t.style.opacity="1",this.activeEl=t;const f=Math.max(0,g-a.start+a.offset),p=t.currentTime-f,F=Math.abs(p);if(F>.5)t.currentTime=f,Math.abs(t.playbackRate-this.playbackRate)>.01&&(t.playbackRate=this.playbackRate);else if(this.isPlaying&&F>.05){const Q=p>0?.75:1.25,v=this.playbackRate*Q;Math.abs(t.playbackRate-v)>.01&&(t.playbackRate=v)}else this.isPlaying&&F<=.05&&Math.abs(t.playbackRate-this.playbackRate)>.01&&(t.playbackRate=this.playbackRate);this.isPlaying?t.paused&&t.play().catch(()=>{}):t.paused||t.pause()}loadVideo(t,a){const g=pA.resolve(a);t.getAttribute("data-src-url")!==g&&(t.src=g,t.setAttribute("data-src-url",g),t.load())}isLoaded(t,a){const g=pA.resolve(a);return t.getAttribute("data-src-url")===g}findClipAtTime(t){const a=[];for(const g of this.rowData)for(const u of g.actions)if(u.effectId==="effect1"&&t>=u.start&&t<u.end){const f=u.data,p=f?.previewSrc||f?.src;p&&a.push({actionId:u.id,src:p,start:u.start,end:u.end,offset:Number(f.offset)||0,layer:Number(f.videoLayer)||0})}return a.length===0?null:a.sort((g,u)=>u.layer-g.layer)[0]}findNextVideoClipStartAfter(t){let a=null;for(const g of this.rowData)for(const u of g.actions){if(u.effectId!=="effect1")continue;const f=Number(u.start);if(!Number.isFinite(f)||f<=t)continue;const p=u.data;if((p?.previewSrc||p?.src)&&(Number(p?.videoLayer),a==null||f<a)){a=f;continue}}return a}findNextVideoClipAfter(t){let a=null;for(const g of this.rowData)for(const u of g.actions){if(u.effectId!=="effect1")continue;const f=Number(u.start),p=Number(u.end);if(!Number.isFinite(f)||!Number.isFinite(p)||f<=t)continue;const F=u.data,Q=F?.previewSrc||F?.src;if(!Q)continue;const v=Number(F?.videoLayer)||0,D={actionId:u.id,src:Q,start:f,end:p,offset:Number(F?.offset)||0,layer:v};if(!a){a=D;continue}if(D.start<a.start){a=D;continue}D.start===a.start&&D.layer>a.layer&&(a=D)}return a}play(){this.isPlaying=!0,this.activeEl?.paused&&this.activeEl.play().catch(()=>{})}pause(){this.isPlaying=!1,this.activeEl?.pause(),this.secondaryEl?.pause(),this.primaryEl?.pause()}setRate(t){this.playbackRate=t,this.activeEl&&(this.activeEl.playbackRate=t)}seek(t){this.lastKnownTime=t,this.updateState(t),this.activeEl}warm(t){pA.warm(t)}releaseVideo(t){}setActive(t){}getActiveVideoElement(){return this.activeEl}hasBufferedAhead(t,a){const g=Math.max(0,Number(a)||0),u=Number(t.currentTime);if(!Number.isFinite(u))return!1;try{const f=t.buffered;for(let p=0;p<f.length;p++){const F=f.start(p),Q=f.end(p);if(u>=F&&u<=Q)return Q-u>=g}}catch{}return!1}async waitForActiveBufferedAhead(t){const a=Math.max(0,Number(t?.minSecondsAhead)||0),g=Math.max(0,Number(t?.timeoutMs)||0),u=Math.max(10,Number(t?.pollMs)||50),f=performance.now();for(;performance.now()-f<=g;){const p=this.activeEl;if(!p)return!0;const F=p.readyState>=HTMLMediaElement.HAVE_FUTURE_DATA,Q=!p.seeking,v=a<=0?!0:this.hasBufferedAhead(p,a);if(F&&Q&&v)return!0;await new Promise(D=>{setTimeout(()=>D(),u)})}return!1}}const CA=new Hn,yn=160,kn=5,Nn={effect0:{id:"effect0",name:"Play audio",source:{start:({action:B,engine:t,isPlaying:a,time:g})=>{if(a){const{src:u,offset:f}=B.data;EA.warm(u),EA.start({actionId:B.id,src:u,startTime:B.start,engine:t,time:g,offset:f})}},enter:({action:B,engine:t,isPlaying:a,time:g})=>{if(a){const{src:u,offset:f}=B.data;EA.warm(u),EA.start({actionId:B.id,src:u,startTime:B.start,engine:t,time:g,offset:f})}},leave:({action:B})=>{EA.stop({actionId:B.id})},stop:({action:B})=>{EA.stop({actionId:B.id})}}},effect2:{id:"effect2",name:"Play video audio",source:{start:({action:B,engine:t,isPlaying:a,time:g})=>{if(a){const{src:u,offset:f}=B.data;EA.warm(u),EA.start({actionId:B.id,src:u,startTime:B.start,engine:t,time:g,offset:f})}},enter:({action:B,engine:t,isPlaying:a,time:g})=>{if(a){const{src:u,offset:f}=B.data;EA.warm(u),EA.start({actionId:B.id,src:u,startTime:B.start,engine:t,time:g,offset:f})}},leave:({action:B})=>{EA.stop({actionId:B.id})},stop:({action:B})=>{EA.stop({actionId:B.id})}}},effect1:{id:"effect1",name:"Play video",source:{start:({action:B,engine:t,isPlaying:a,time:g})=>{const{src:u,previewSrc:f,offset:p,videoLayer:F}=B.data??{},Q=f||u;Q&&CA.warm(Q),CA.claimVideo({actionId:String(B.id),layer:Number.isFinite(Number(F))?Number(F):0,src:Q,engine:t,isPlaying:a,time:g,actionStart:Number(B.start),offset:p})},enter:({action:B,engine:t,isPlaying:a,time:g})=>{const{src:u,previewSrc:f,offset:p,videoLayer:F}=B.data??{},Q=f||u;Q&&CA.warm(Q),CA.claimVideo({actionId:String(B.id),layer:Number.isFinite(Number(F))?Number(F):0,src:Q,engine:t,isPlaying:a,time:g,actionStart:Number(B.start),offset:p})},update:({action:B,engine:t,time:a,isPlaying:g})=>{const{src:u,previewSrc:f,offset:p,videoLayer:F}=B.data??{},Q=f||u;CA.claimVideo({actionId:String(B.id),layer:Number.isFinite(Number(F))?Number(F):0,src:Q,engine:t,isPlaying:g,time:a,actionStart:Number(B.start),offset:p})},leave:({action:B})=>{CA.releaseVideo(String(B.id))},stop:({action:B})=>{CA.releaseVideo(String(B.id))}}}},Jn="",Pn="",Un="",Mn="",Ln="",xn="",{Option:Yn}=St.Select,Tn=[.2,.5,1,1.5,2],Kn=({timelineState:B,autoScrollWhenPlay:t,scale:a,scaleWidth:g,startLeft:u,editorData:f,selectedActionId:p,onDeleteSelectedClip:F,onSplitSelectedClip:Q,canUndo:v,canRedo:D,onUndo:L,onRedo:Z})=>{const[dA,wA]=w.useState(!1),[KA,gA]=w.useState(0),[x,G]=w.useState(!1),q=w.useRef(0),vA=w.useRef(0),j=w.useRef(0),jA=w.useRef(0),OA=w.useRef(0),be=w.useRef(0),ae=w.useRef(null);w.useRef(null);const te=!!p,ne=(U=>{const iA=Array.isArray(f)?f:[];for(const AA of iA){const eA=AA?.actions;if(Array.isArray(eA))for(const _ of eA){const tA=String(_?.effectId??"");if(!(tA==="effect0"||tA==="effect1"||tA==="effect2"))continue;const aA=Number(_?.start),VA=Number(_?.end);if(!(!Number.isFinite(aA)||!Number.isFinite(VA))&&U>aA&&U<VA)return!0}}return!1})(KA),JA=U=>{const iA=Array.isArray(f)?f:[];for(const AA of iA){const eA=AA?.actions;if(Array.isArray(eA))for(const _ of eA){if(_?.effectId!=="effect1")continue;const tA=Number(_?.start),fA=Number(_?.end);if(!(!Number.isFinite(tA)||!Number.isFinite(fA))&&U>=tA&&U<fA)return!0}}return!1},PA=U=>{JA(U)};w.useEffect(()=>{if(!B.current)return;const U=B.current;CA.bindEngine(U);const iA=()=>{wA(!0),CA.play()},AA=()=>{wA(!1),CA.pause()},eA=({time:tA})=>{gA(tA),PA(tA)},_=({time:tA})=>{const fA=performance.now();if(fA-q.current<33||(q.current=fA,gA(tA),PA(tA),!t.current))return;const aA=B.current;if(!aA)return;const VA=g/a,UA=u+tA*VA;let re=ae.current;if(!re&&aA.target){const HA=aA.target.querySelector(".ReactVirtualized__Grid");HA&&(ae.current=HA,re=HA)}if(!re)return;const ZA=re.clientWidth,Ie=re.scrollLeft;if(ZA<=0)return;const bA=Math.min(80,ZA/3),_A=Ie+bA,ie=Ie+ZA-bA;let MA=null;UA>ie?MA=UA-(ZA-bA):UA<_A&&(MA=Math.max(0,UA-bA)),MA!=null&&(Math.abs(MA-Ie)<.5||aA.setScrollLeft(MA))};return U.listener.on("play",iA),U.listener.on("paused",AA),U.listener.on("afterSetTime",eA),U.listener.on("setTimeByTick",_),()=>{U.listener.off("play",iA),U.listener.off("paused",AA),U.listener.off("afterSetTime",eA),U.listener.off("setTimeByTick",_),CA.unbindEngine()}},[f,a,g,u,t]);const XA=()=>{B.current&&(B.current.isPlaying?B.current.pause():(EA.unlock(),B.current.play({autoEnd:!0})))},Ce=U=>{B.current&&(B.current.setPlayRate(U),CA.setRate(U))},we=U=>{const iA=(parseInt(U%1*100+"")+"").padStart(2,"0"),AA=(parseInt(U/60+"")+"").padStart(2,"0"),eA=(parseInt(U%60+"")+"").padStart(2,"0");return h.jsx(h.Fragment,{children:`${AA}:${eA}.${iA.replace("0.","")}`})},Fe=()=>{const U=[],iA=new Set,AA=Array.isArray(f)?f:[];for(const eA of AA){const _=eA?.actions;if(Array.isArray(_))for(const tA of _){const fA=tA?.data?.src;if(!fA)continue;const aA=String(fA);iA.has(aA)||(iA.add(aA),U.push(aA))}}return U},WA=(U,iA)=>{const AA=URL.createObjectURL(U),eA=document.createElement("a");eA.href=AA,eA.download=iA,document.body.appendChild(eA),eA.click(),eA.remove(),setTimeout(()=>URL.revokeObjectURL(AA),3e3)},uA=async()=>{if(!x){G(!0);try{const U=Fe(),iA=new FormData;iA.append("timeline",JSON.stringify({editorData:f}));for(const _ of U){const tA=pA.resolve(_),fA=await fetch(tA);if(!fA.ok)throw new Error(`Failed to fetch asset: ${_} (${fA.status})`);const aA=await fA.blob();iA.append("assets",aA,encodeURIComponent(_))}const AA=await fetch("/export",{method:"POST",body:iA});if(!AA.ok){const _=await AA.text().catch(()=>"");throw new Error(_||`Export failed (${AA.status})`)}const eA=await AA.blob();WA(eA,"export.mp4")}finally{G(!1)}}};return h.jsxs("div",{className:"timeline-player",children:[h.jsx("div",{className:"play-control",role:"button",tabIndex:0,"aria-label":dA?"Pause":"Play",onClick:()=>{Date.now()-vA.current<450||XA()},onPointerUp:U=>{U.pointerType!=="mouse"&&(vA.current=Date.now(),XA())},children:h.jsx("img",{src:dA?Pn:Jn,alt:"",draggable:!1})}),h.jsx("div",{className:"time",children:we(KA)}),h.jsxs("div",{className:"history-tools",children:[h.jsx("button",{type:"button",className:"history-tool",disabled:!v,"aria-label":"Undo",onClick:()=>{Date.now()-OA.current<450||v&&L()},onPointerUp:U=>{U.pointerType!=="mouse"&&(OA.current=Date.now(),v&&L())},children:h.jsx("img",{src:Un,alt:"",draggable:!1})}),h.jsx("button",{type:"button",className:"history-tool",disabled:!D,"aria-label":"Redo",onClick:()=>{Date.now()-be.current<450||D&&Z()},onPointerUp:U=>{U.pointerType!=="mouse"&&(be.current=Date.now(),D&&Z())},children:h.jsx("img",{src:Mn,alt:"",draggable:!1})})]}),h.jsx("div",{className:"rate-control",children:h.jsx(St.Select,{size:"small",defaultValue:1,style:{width:120},onChange:Ce,children:Tn.map(U=>h.jsx(Yn,{value:U,children:`${U.toFixed(1)}x`},U))})}),h.jsxs("div",{className:"clip-tools",children:[h.jsx("button",{type:"button",className:"clip-tool clip-tool-delete",disabled:!te,"aria-label":"Delete selected clip",onClick:()=>{Date.now()-j.current<450||te&&F()},onPointerUp:U=>{U.pointerType!=="mouse"&&(j.current=Date.now(),te&&F())},children:h.jsx("img",{src:Ln,alt:"",draggable:!1})}),h.jsx("button",{type:"button",className:"clip-tool clip-tool-split",disabled:!ne,"aria-label":"Split clips at cursor",onClick:()=>{Date.now()-jA.current<450||ne&&Q()},onPointerUp:U=>{U.pointerType!=="mouse"&&(jA.current=Date.now(),ne&&Q())},children:h.jsx("img",{src:xn,alt:"",draggable:!1})})]}),h.jsx("div",{className:"export-control",children:h.jsx(St.Button,{size:"small",type:"primary",loading:x,onClick:uA,children:"Export"})})]})};function Gn(){const B=()=>typeof window>"u"?!1:typeof navigator<"u"&&(navigator.maxTouchPoints??0)>0,[t,a]=w.useState(B);return w.useEffect(()=>{if(typeof window>"u"||typeof window.matchMedia!="function")return;const g=window.matchMedia("(pointer: coarse)"),u=()=>a(!!g.matches||B());return u(),typeof g.addEventListener=="function"?(g.addEventListener("change",u),()=>g.removeEventListener("change",u)):(g.addListener(u),()=>g.removeListener(u))},[]),t}const jn="0.1.7",Xn="",Wn="",qn="",zn="",mt=()=>[{id:"0",actions:[]},{id:"1",actions:[]},{id:"2",actions:[]},{id:"3",actions:[]}],rt=5,Yt=.001,Dt=.01,pt=10,Vn=.03,Tt=70,Kt=70,Gt=.4,jt=1400,Xt=100,Zn=500,Wt=4,qt=.05,zt=360,Vt=.9,Zt=3200,it=B=>new Promise(t=>{setTimeout(()=>t(),Math.max(0,B))}),_t=async B=>{const t=await pA.getDurationSec(B.src,B.kind);if(t!=null&&Number.isFinite(t)&&t>0)return Math.max(Dt,t);const a=Number(B.defaultDuration);return Number.isFinite(a)&&a>0?Math.max(Dt,a):pt},BA=B=>{const t=Number(B);return Number.isFinite(t)?Math.round(t/Yt)*Yt:0},bt=(B,t)=>{const a=Math.max(0,BA(B)),g=Math.max(0,BA(t));return g<=a?{start:a,end:a+Dt}:{start:a,end:g}},ot=B=>{let t=!1;const a=B.map(g=>{const f=(Array.isArray(g?.actions)?g.actions:[]).map(p=>{const F=Number(p?.start),Q=Number(p?.end);if(!Number.isFinite(F)||!Number.isFinite(Q))return p;const v=bt(F,Q);return v.start===F&&v.end===Q?p:(t=!0,{...p,start:v.start,end:v.end})});return{...g,actions:f}});return t?a:B},An=({item:B,hint:t,isDragging:a,listeners:g,attributes:u})=>h.jsxs("div",{className:`footage-card${a?" is-dragging":""}`,title:t,...g,...u,children:[h.jsx("div",{className:"footage-name",children:B.name}),B.kind==="video"?h.jsx("video",{className:"footage-preview",src:B.src,muted:!0,preload:"metadata",draggable:!1,onDragStart:f=>f.preventDefault(),playsInline:!0}):h.jsx("audio",{className:"footage-audio",src:B.src,controls:!0,preload:"metadata",draggable:!1,onDragStart:f=>f.preventDefault()})]}),_n=({item:B})=>{const{attributes:t,listeners:a,setNodeRef:g,transform:u,isDragging:f}=ee.useDraggable({id:`footage-${B.id}`,data:{item:B}}),p=u?{transform:`translate3d(${u.x}px, ${u.y}px, 0)`}:void 0;return h.jsx("div",{ref:g,style:p,className:"draggable-footage-wrapper",children:h.jsx(An,{item:B,isDragging:f,listeners:a,attributes:t})})},$t=B=>{try{return structuredClone(B)}catch{return JSON.parse(JSON.stringify(B))}},en=B=>String(B??"").toLowerCase().match(/\.(mp3|wav|m4a|aac|ogg)(\?|#|$)/)?"audio":"video",$n=(B,t)=>{try{const a=String(B??"").split("/").pop()||"";return decodeURIComponent(a.split("?")[0].split("#")[0])||`Footage ${t+1}`}catch{return`Footage ${t+1}`}},ht=B=>{const t=String(B?.type??"").toLowerCase();return t.startsWith("audio/")?"audio":t.startsWith("video/")?"video":en(B?.name??"")},Ar=w.forwardRef(function({footageUrls:t,footageFiles:a,footageFileHandles:g,autoPlaceFootage:u=!1,initialTimelineSnapshot:f,onTimelineStateChange:p,onFootageImported:F},Q){const[v,D]=w.useState(()=>mt()),[L,Z]=w.useState(null),[dA,wA]=w.useState([]),[KA,gA]=w.useState([]),x=w.useRef(v);w.useEffect(()=>{CA.setEditorData(v)},[v]);const G=Gn(),[q,vA]=w.useState(!1),j=w.useRef(null),jA=w.useRef(null),OA=w.useRef(null),be=w.useRef(!0),ae=w.useRef(null),te=w.useRef([]),Ee=w.useRef(new Map);w.useEffect(()=>()=>{EA.reset()},[]);const ne=w.useMemo(()=>{const A=Array.isArray(t)?t.filter(Boolean):[];return A.length?A.map((r,e)=>({id:`url-${e}`,kind:en(r),name:$n(r,e),src:r})):[]},[t]),[JA,PA]=w.useState([]),[XA,Ce]=w.useState([]),[we,Fe]=w.useState([]);w.useEffect(()=>{const A=Array.isArray(a)?a.filter(Boolean):[];if(A.length===0){PA([]);return}const r=[],e=A.map((o,s)=>{const i=URL.createObjectURL(o);return r.push(i),pA.registerSrcMeta(i,{name:o.name,mimeType:o.type}),{id:`file-${s}`,kind:ht(o),name:o.name||`Footage ${s+1}`,src:i}});return PA(e),()=>{for(const o of r)try{URL.revokeObjectURL(o)}catch{}}},[a]),w.useEffect(()=>{const A=Array.isArray(g)?g.filter(Boolean):[];if(A.length===0){Ce([]);return}let r=!1;const e=[];return(async()=>{const s=[];for(let i=0;i<A.length;i++){const c=A[i];try{const d=await c.getFile();if(r)return;const l=URL.createObjectURL(d);e.push(l),pA.registerSrcMeta(l,{name:d.name||c?.name,mimeType:d.type}),s.push({id:`handle-${i}`,kind:ht(d),name:d.name||c?.name||`Footage ${i+1}`,src:l})}catch(d){console.warn("[MeliesVideoEditor] Failed to load file handle",d)}}r||Ce(s)})(),()=>{r=!0;for(const s of e)try{URL.revokeObjectURL(s)}catch{}}},[g]),w.useEffect(()=>()=>{for(const A of te.current)try{URL.revokeObjectURL(A)}catch{}te.current=[],Ee.current.clear()},[]);const WA=w.useMemo(()=>[...ne,...JA,...XA,...we],[ne,JA,XA,we]);w.useEffect(()=>{for(const A of WA)pA.getDurationSec(A.src,A.kind)},[WA]);const[uA,U]=w.useState(null),[iA,AA]=w.useState(null),[eA,_]=w.useState(null),[tA,fA]=w.useState(0),[aA,VA]=w.useState(0),[UA,re]=w.useState(0),[ZA,Ie]=w.useState(0),[Ne,bA]=w.useState(!1),[_A,ie]=w.useState(null),MA=w.useRef(null),HA=w.useRef(null),Qe=w.useRef(null),ce=w.useRef(null),yA=G?48:32,Re=30,[LA,Je]=w.useState(()=>yn),qA=kn,Pe=()=>({version:1,editorData:$t(x.current),selectedActionId:L,timelineScaleWidth:LA}),qe=A=>{if(!A||A.version!==1)throw new Error("[MeliesVideoEditor] Unsupported snapshot version");try{j.current?.isPlaying&&j.current.pause()}catch{}EA.reset();const r=ot($t(A.editorData??mt())),e=A.selectedActionId??null,o=Number(A.timelineScaleWidth);Z(e),wA([]),gA([]),Number.isFinite(o)&&o>0&&Je(Math.min(600,Math.max(60,Math.round(o)))),D(()=>(x.current=r,r))};w.useImperativeHandle(Q,()=>({getTimelineSnapshot:Pe,setTimelineSnapshot:qe,getImportedFileByFootageId:A=>Ee.current.get(String(A))??null,listImportedFiles:()=>Array.from(Ee.current.entries()).map(([A,r])=>({footageId:A,file:r}))}),[L,LA]),w.useEffect(()=>{p&&p(Pe())},[v,L,LA,p]);const Ue=w.useRef(null);w.useEffect(()=>{if(!f)return;let A;try{A=JSON.stringify(f)}catch{return}if(Ue.current!==A){Ue.current=A;try{qe(f)}catch(r){console.warn("[MeliesVideoEditor] Failed to apply initialTimelineSnapshot",r)}}},[f]);const Me=A=>{Je(r=>{const e=Math.round(r*A);return Math.min(600,Math.max(60,e))})},IA=[1,0],oe=[3,2],ze=["V2","V1","A2","A1"],me=(A,r)=>{if(r.length===0)return null;if(A==null)return r[0];let e=r[0],o=Math.abs(A-e);for(const s of r){const i=Math.abs(A-s);i<o&&(e=s,o=i)}return e},ve=(A,r)=>A?A.kind==="video"?me(r,IA):me(r,oe):null,zA=A=>A===IA[1]?oe[1]:oe[0],Oe=A=>A===oe[1]?IA[1]:IA[0],kA=(A,r)=>{const e=r==="video"?IA:oe;return me(A,e)??e[0]},Le=w.useRef(!1);w.useEffect(()=>{if(!u||Le.current||WA.length===0||x.current.some(c=>Array.isArray(c?.actions)&&c.actions.length>0))return;const e=IA[0],o=zA(e);Le.current=!0;let s=!1;return(async()=>{const c=mt();let d=0;for(const l of WA){if(s)return;const m=await _t(l),I=BA(d),R=BA(d+m);if(d=R,l.kind==="video"){const S=`link-${hA()}`,y=IA.findIndex(k=>k===e);c[e].actions.push({id:`video-${hA()}`,start:I,end:R,effectId:"effect1",data:{src:l.src,previewSrc:l.previewSrc,name:l.name,linkId:S,videoLayer:y}}),c[o].actions.push({id:`video-audio-${hA()}`,start:I,end:R,effectId:"effect2",data:{src:l.src,name:l.name,linkId:S}})}else c[o].actions.push({id:`audio-${hA()}`,start:I,end:R,effectId:"effect0",data:{src:l.src,name:l.name}})}Z(null),wA([]),gA([]),D(()=>(x.current=c,c))})(),()=>{s=!0}},[u,WA]),w.useEffect(()=>{pA.warmFromEditorData(v);const A=new Set,r=new Set;for(const e of v){const o=e.actions;for(const s of o){if(s.effectId==="effect0"||s.effectId==="effect2"){const i=s.data?.src;i&&A.add(i)}if(s.effectId==="effect1"){const i=s.data,c=i?.previewSrc||i?.src;c&&r.add(c)}}}for(const e of A)EA.warm(e);for(const e of r)CA.warm(e)},[v]),w.useEffect(()=>{x.current=v},[v]),w.useLayoutEffect(()=>{const A=OA.current;if(!A)return;const r=()=>{const o=A.getBoundingClientRect(),s=A.querySelector(".timeline-editor-edit-area");if(!s)return;const i=s.getBoundingClientRect();re(i.top-o.top),Ie(i.left-o.left)},e=requestAnimationFrame(r);return window.addEventListener("resize",r),()=>{cancelAnimationFrame(e),window.removeEventListener("resize",r)}},[G,v.length]);const $A=A=>{const r=OA.current;if(!r||!A)return!1;const e=r.getBoundingClientRect();return A.x>=e.left&&A.x<=e.right&&A.y>=e.top&&A.y<=e.bottom},xe=w.useRef(0),hA=()=>globalThis.crypto?.randomUUID?globalThis.crypto.randomUUID():`uid-${++xe.current}`,SA=w.useRef(null),xA=w.useRef(null),ge=w.useRef(null),NA=w.useRef({actionId:null,edge:null}),nA=w.useRef({actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:0,committedRowIndex:0,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:0,initialEnd:0,takeover:!1}),QA=w.useRef({actionId:null,partnerId:null,dir:null,baseStart:0,baseOffset:0,partnerBaseOffset:0}),Ye=w.useRef(!1),he=A=>A.map(r=>{const e=(r.actions??[]).map(o=>`${String(o.id)}@${Number(o.start)}-${Number(o.end)}`).join("|");return`${String(r.id)}:${e}`}).join("||"),se=A=>{const r=structuredClone(A);wA(e=>{const o=[...e,r];return o.length>rt&&o.splice(0,o.length-rt),o}),gA([])},Se=(A,r,e,o)=>A<o&&r>e,Ae=(A,r,e,o)=>{const s=Array.isArray(A?.actions)?A.actions:[];for(const i of s)if(!(!i||i.id===r)&&Se(e,o,Number(i.start),Number(i.end)))return!0;return!1},FA=(A,r)=>{for(let e=0;e<A.length;e++){const o=A[e],s=Array.isArray(o?.actions)?o.actions:[];for(let i=0;i<s.length;i++){const c=s[i];if(String(c?.id)===r)return{rowIndex:e,actionIndex:i,action:c}}}return null},YA=(A,r)=>{const e=FA(A,r),o=e?.action?.data?.linkId;if(!e||!o)return null;for(let s=0;s<A.length;s++){const i=A[s],c=Array.isArray(i?.actions)?i.actions:[];for(let d=0;d<c.length;d++){const l=c[d];if(l?.data?.linkId&&String(l.data.linkId)===String(o)&&String(l.id)!==String(r))return{rowIndex:s,actionIndex:d,action:l}}}return null},st=(A,r)=>{const e=FA(A,r);if(!e)return A;const o=YA(A,r);if(!o)return A;const s=Number(e.action.start),i=Number(e.action.end);if(!Number.isFinite(s)||!Number.isFinite(i)||i<=s||Number(o.action.start)===s&&Number(o.action.end)===i)return A;const c=structuredClone(A),d=c[o.rowIndex],l=Array.isArray(d.actions)?[...d.actions]:[],m={...l[o.actionIndex],start:s,end:i};return l.splice(o.actionIndex,1,m),d.actions=l,c},n=(A,r)=>{const e=structuredClone(A);for(;e.length<4;)e.push({id:`${e.length}`,actions:[]});const o=C=>C&&typeof C=="object"?C:{},s=(C,O)=>{if(!(!C||typeof C!="object"))return C[O]},i=C=>String(s(C,"id")??""),c=C=>String(s(C,"effectId")??""),d=C=>Number(s(C,"start")),l=C=>Number(s(C,"end")),m=C=>s(C,"data"),I=C=>{if(!C||typeof C!="object")return 0;const O=Number(C.start);return Number.isFinite(O)?O:0},R=new Map,S=new Map;for(let C=0;C<e.length;C++){const O=e[C],J=Array.isArray(O?.actions)?O.actions:[];for(let H=0;H<J.length;H++){const P=J[H],Y=i(P);if(!Y)continue;R.set(Y,{rowIndex:C,actionIndex:H,action:P});const W=m(P),$=s(W,"linkId"),cA=$!=null?String($):"";if(!cA)continue;const rA=S.get(cA)??{},oA=c(P);oA==="effect1"?rA.video={rowIndex:C,actionIndex:H,action:P}:oA==="effect2"&&(rA.audio={rowIndex:C,actionIndex:H,action:P}),S.set(cA,rA)}}const y=new Map;for(const C of S.values()){if(!C.video||!C.audio)continue;const O=i(C.video.action),J=i(C.audio.action),H=r&&String(r)===J?"audio":"video",P=H==="audio"?Oe(kA(C.audio.rowIndex,"audio")):kA(C.video.rowIndex,"video"),Y=zA(P),W=H==="audio"?C.audio.action:C.video.action,$=d(W),cA=l(W),rA=Number.isFinite($)&&Number.isFinite(cA)&&cA>$,oA=Math.max(0,IA.findIndex(lA=>lA===P));y.set(O,{targetRowIndex:P,patchStartEnd:rA?{start:$,end:cA}:void 0,patchVideoLayer:oA}),y.set(J,{targetRowIndex:Y,patchStartEnd:rA?{start:$,end:cA}:void 0})}for(const[C,O]of R.entries()){if(y.has(C))continue;const J=c(O.action);if(J==="effect1"){const H=kA(O.rowIndex,"video"),P=Math.max(0,IA.findIndex(Y=>Y===H));y.set(C,{targetRowIndex:H,patchVideoLayer:P})}else if(J==="effect0"||J==="effect2"){const H=kA(O.rowIndex,"audio");y.set(C,{targetRowIndex:H})}}const k=e.map(C=>({...C,actions:[]}));let N=!1;for(let C=0;C<e.length;C++){const O=e[C],J=Array.isArray(O?.actions)?O.actions:[];for(const H of J){const P=H,Y=i(P);if(!Y)continue;const W=y.get(Y),$=W?W.targetRowIndex:C,cA=k[$]??k[C];let rA=P;if(W?.patchStartEnd){const oA=W.patchStartEnd.start,lA=W.patchStartEnd.end;(d(rA)!==oA||l(rA)!==lA)&&(rA={...o(rA),start:oA,end:lA},N=!0)}if(W?.patchVideoLayer!=null&&c(rA)==="effect1"){const oA=Number(s(m(rA),"videoLayer"));if(!Number.isFinite(oA)||oA!==W.patchVideoLayer){const lA={...o(m(rA)),videoLayer:W.patchVideoLayer};rA={...o(rA),data:lA},N=!0}}$!==C&&(N=!0),cA.actions.push(rA)}}for(const C of k){const O=Array.isArray(C.actions)?[...C.actions]:[];O.sort((J,H)=>I(J)-I(H)),C.actions=O}return N?k:A},E=(A,r,e,o)=>{const s=bt(e,o);if(!Number.isFinite(s.start)||!Number.isFinite(s.end)||s.end<=s.start)return A;const i=FA(A,r);if(!i)return A;const c=YA(A,r);if(!c)return A;const d=structuredClone(A),l=d[i.rowIndex],m=Array.isArray(l.actions)?[...l.actions]:[],I={...m[i.actionIndex],start:s.start,end:s.end};m.splice(i.actionIndex,1,I),l.actions=m;const R=d[c.rowIndex],S=Array.isArray(R.actions)?[...R.actions]:[],y={...S[c.actionIndex],start:s.start,end:s.end};return S.splice(c.actionIndex,1,y),R.actions=S,d},b=(A,r,e,o)=>{const s=bt(e,o);if(!Number.isFinite(s.start)||!Number.isFinite(s.end)||s.end<=s.start)return A;const i=FA(A,r);if(!i)return A;const c=Number(i.action.start),d=Number(i.action.end);if(c===s.start&&d===s.end)return A;const l=structuredClone(A),m=l[i.rowIndex],I=Array.isArray(m.actions)?[...m.actions]:[],R={...I[i.actionIndex],start:s.start,end:s.end};return I.splice(i.actionIndex,1,R),m.actions=I,l},M=()=>{const A=j.current?.getTime?Number(j.current.getTime()):0;return Number.isFinite(A)?Math.max(0,A):0},X=A=>{const r=[M()],e=A?YA(x.current,A):null,o=new Set([A,e?.action.id].filter(Boolean));for(const s of x.current)for(const i of s.actions){if(o.has(String(i.id)))continue;const c=Number(i.start),d=Number(i.end);Number.isFinite(c)&&r.push(c),Number.isFinite(d)&&r.push(d)}return r},z=(A,r,e)=>{const o=e-r;if(!Number.isFinite(o)||o<=0)return{start:r,end:e,snapped:!1,edge:null};const s=X(A),i=LA/qA,c=20/i,d=40/i;let l=1/0,m=-1,I=1/0,R=-1;for(const P of s){const Y=Math.abs(r-P);Y<l&&(l=Y,m=P);const W=Math.abs(e-P);W<I&&(I=W,R=P)}const S=l<=I?"start":"end",y=Math.min(l,I),k=NA.current,C=k.actionId===A&&k.edge!=null;if(y<=c)NA.current={actionId:A,edge:S};else if(C){if((k.edge==="start"?l:I)>d)return NA.current={actionId:A,edge:null},{start:r,end:e,snapped:!1,edge:null}}else return{start:r,end:e,snapped:!1,edge:null};const O=NA.current.edge;if(O==="start"){const P=m,Y=P+o;return{start:Math.max(0,P),end:Math.max(Math.max(0,P),Y),snapped:!0,edge:O}}const J=R,H=J-o;return{start:Math.max(0,H),end:Math.max(0,J),snapped:!0,edge:O}},K=(A,r,e,o)=>{const s=X(A),i=LA/qA,c=20/i,d=40/i,l=o==="left"?"start":"end";let m=1/0,I=-1;const R=l==="start"?r:e;for(const O of s){const J=Math.abs(R-O);J<m&&(m=J,I=O)}const S=NA.current,k=S.actionId===A&&S.edge===l;if(m<=c)NA.current={actionId:A,edge:l};else if(k){if(m>d)return NA.current={actionId:A,edge:null},{start:r,end:e,snapped:!1}}else return{start:r,end:e,snapped:!1};if(l==="start"){const O=Math.max(0,I),J=Math.max(O+.01,e);return{start:O,end:J,snapped:!0}}const N=Math.max(0,I),C=Math.min(r,N-.01);return{start:Math.max(0,C),end:Math.max(0,N),snapped:!0,edge:l}},T=async(A,r,e)=>{const o=await _t(A);let s=Math.max(0,BA(r)),i=BA(s+o);const c=j.current;c?.isPlaying&&c.pause(),D(d=>{se(d);const l=structuredClone(d);for(;l.length<4;)l.push({id:`${l.length}`,actions:[]});const m=Number.isFinite(Number(e))?Number(e):null,I=me(m,IA)??IA[0],R=me(m,oe)??oe[0],S=k=>{const N=[];for(const C of k){const O=Array.isArray(l[C]?.actions)?l[C].actions:[];for(const J of O){const H=Number(J?.start),P=Number(J?.end);!Number.isFinite(H)||!Number.isFinite(P)||N.push({start:H,end:P})}}N.sort((C,O)=>C.start-O.start);for(const C of N)Se(s,i,C.start,C.end)&&(s=BA(C.end),i=BA(s+o))};if(A.kind==="video"){const k=I,N=zA(k);S([k,N]);const C=`link-${hA()}`,O=`video-${hA()}`,J=`video-audio-${hA()}`,H=IA.findIndex(P=>P===k);l[k].actions=[...l[k].actions??[],{id:O,start:BA(s),end:BA(i),effectId:"effect1",data:{src:A.src,previewSrc:A.previewSrc,name:A.name,linkId:C,videoLayer:H}}],l[N].actions=[...l[N].actions??[],{id:J,start:BA(s),end:BA(i),effectId:"effect2",data:{src:A.src,name:A.name,linkId:C}}]}else{const k=R;S([k]),l[k].actions=[...l[k].actions??[],{id:`audio-${hA()}`,start:BA(s),end:BA(i),effectId:"effect0",data:{src:A.src,name:A.name}}]}return ot(l)})},mA=()=>{const A=OA.current;return A?A.querySelector(".timeline-editor-edit-area .ReactVirtualized__Grid")?.scrollLeft??0:0},sA=()=>tA,V=A=>{const r=OA.current;if(!r)return 0;const o=(r.querySelector(".timeline-editor-edit-area")??r).getBoundingClientRect(),c=(A-o.x+mA()-Re)*qA/LA;return Math.max(0,c)},RA=A=>{const r=Number(A);return Number.isFinite(r)?Re+r*LA/qA:0},ue=(A,r,e,o)=>{const s=pA.getCachedDurationSec(A.src)??A.defaultDuration??pt;let i=Math.max(0,BA(r)),c=BA(i+s);const d=[];if(A.kind==="video"){const m=e,I=zA(m);d.push(m,I)}else d.push(e);const l=[];for(const m of d){const I=Array.isArray(o[m]?.actions)?o[m].actions:[];for(const R of I){const S=Number(R?.start),y=Number(R?.end);!Number.isFinite(S)||!Number.isFinite(y)||l.push({start:S,end:y})}}l.sort((m,I)=>m.start-I.start);for(const m of l)Se(i,c,m.start,m.end)&&(i=BA(m.end),c=BA(i+s));return Math.max(0,BA(i))},TA=A=>{const r=OA.current;if(!r)return null;const e=r.querySelector(".timeline-editor-edit-area");if(!e)return null;const o=e.getBoundingClientRect(),s=A-o.y;if(s<0||s>o.height)return null;const i=s+sA(),c=Math.floor(i/yA);if(!Number.isFinite(c))return null;const d=Math.max(0,x.current.length-1);return Math.min(Math.max(0,c),d)},DA=A=>{if(!A)return null;if("clientX"in A&&"clientY"in A){const s=Number(A.clientX),i=Number(A.clientY);if(Number.isFinite(s)&&Number.isFinite(i))return{x:s,y:i}}const r=A.touches,e=A.changedTouches,o=(r&&r.length?r[0]:null)||(e&&e.length?e[0]:null);if(o){const s=Number(o.clientX),i=Number(o.clientY);if(Number.isFinite(s)&&Number.isFinite(i))return{x:s,y:i}}return null},le=()=>{if(Ye.current)return;Ye.current=!0;const A=e=>{const o=nA.current;if(!o.actionId||!o.mode||e.isPrimary===!1)return;const s=V(e.clientX);o.basePointerTime==null&&(o.basePointerTime=s),o.lastPointerTime=s,o.basePointerClientY==null&&(o.basePointerClientY=e.clientY),o.lastPointerClientY=e.clientY},r=()=>{const e={actionId:nA.current.actionId,mode:nA.current.mode};requestAnimationFrame(()=>{nA.current.actionId===e.actionId&&nA.current.mode===e.mode&&(nA.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:0,committedRowIndex:0,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:0,initialEnd:0,takeover:!1},NA.current={actionId:null,edge:null})})};window.addEventListener("pointermove",A,{capture:!0}),window.addEventListener("pointerup",r,{capture:!0}),window.addEventListener("pointercancel",r,{capture:!0}),nA.current._removePointerListeners=()=>{window.removeEventListener("pointermove",A,{capture:!0}),window.removeEventListener("pointerup",r,{capture:!0}),window.removeEventListener("pointercancel",r,{capture:!0}),Ye.current=!1}},Ve=()=>{const A=nA.current?._removePointerListeners;A?.(),delete nA.current._removePointerListeners},Te=w.useRef(!1),at=A=>{const r=Number(A?.data?.offset??0);return Number.isFinite(r)?r:0},ct=(A,r,e)=>{const o=FA(A,r);if(!o)return A;const s=Math.max(0,Number.isFinite(e)?e:0);if(at(o.action)===s)return A;const c=structuredClone(A),d=c[o.rowIndex],l=Array.isArray(d.actions)?[...d.actions]:[],m={...l[o.actionIndex],data:{...l[o.actionIndex]?.data??{},offset:s}};return l.splice(o.actionIndex,1,m),d.actions=l,c},Ft=(A,r,e,o)=>{const s=FA(A,r);if(!s)return A;const i=YA(A,r);if(!i)return ct(A,r,e);const c=Math.max(0,Number.isFinite(e)?e:0),d=Math.max(0,Number.isFinite(Number(o))?Number(o):c),l=structuredClone(A),m=l[s.rowIndex],I=Array.isArray(m.actions)?[...m.actions]:[],R={...I[s.actionIndex],data:{...I[s.actionIndex]?.data??{},offset:c}};I.splice(s.actionIndex,1,R),m.actions=I;const S=l[i.rowIndex],y=Array.isArray(S.actions)?[...S.actions]:[],k={...y[i.actionIndex],data:{...y[i.actionIndex]?.data??{},offset:d}};return y.splice(i.actionIndex,1,k),S.actions=y,l},[Be,Ze]=w.useState(null),tn=(A,r,e)=>{const o=FA(A,r);if(!o)return A;const i=String(o.action?.effectId??"")==="effect1"?"video":"audio",c=kA(e,i),d=YA(A,r),l=!!d,m=new Set([String(r)]);d&&m.add(String(d.action.id));const I=Number(o.action?.start),R=Number(o.action?.end);if(!Number.isFinite(I)||!Number.isFinite(R)||R<=I)return A;const S=(H,P,Y)=>{const W=Array.isArray(H?.actions)?H.actions:[];for(const $ of W){const cA=String($?.id??"");if(!(cA&&m.has(cA))&&Se(P,Y,Number($?.start),Number($?.end)))return!1}return!0};let y=null,k=null;if(l&&(i==="video"?(y=c,k=zA(y)):(k=c,y=Oe(k))),i==="video"){if(!S(A[c],I,R))return A}else if(!S(A[c],I,R))return A;if(y!=null&&!S(A[y],I,R)||k!=null&&!S(A[k],I,R)||!l&&o.rowIndex===c)return A;if(l&&i==="video"&&o.rowIndex===y){const H=d?FA(A,String(d.action.id)):null;if(H&&H.rowIndex===k)return A}if(l&&i==="audio"&&o.rowIndex===k){const H=d?FA(A,String(d.action.id)):null;if(H&&H.rowIndex===y)return A}const N=structuredClone(A);for(;N.length<4;)N.push({id:`${N.length}`,actions:[]});const C=(H,P)=>{const Y=Array.isArray(H.actions)?H.actions:[];H.actions=Y.filter(W=>String(W?.id??"")!==P)},O=(H,P)=>{const Y=N[H];Y.actions=[...Y.actions??[],P],Y.actions.sort((W,$)=>Number(W.start)-Number($.start))};C(N[o.rowIndex],String(r));let J=o.action;if(i==="video"){const H=Math.max(0,IA.findIndex(P=>P===c));J={...J,data:{...J.data??{},videoLayer:H}}}if(O(c,J),d&&y!=null&&k!=null){const H=FA(A,String(d.action.id));if(H){C(N[H.rowIndex],String(d.action.id));const P=i==="video"?k:y;let Y=H.action;if(String(Y?.effectId??"")==="effect1"){const $=Math.max(0,IA.findIndex(cA=>cA===P));Y={...Y,data:{...Y.data??{},videoLayer:$}}}O(P,Y)}}return N},nn=A=>A.map(r=>({...r,selected:void 0,actions:(r.actions??[]).map(e=>({...e,selected:void 0}))})),rn=w.useMemo(()=>v.map((A,r)=>{const e=L?(A.actions??[]).some(c=>String(c.id)===L):!1,o=uA!=null&&eA!=null&&r===eA,s=Array.isArray(A.classNames)?A.classNames:[],i=o?[...s,"dnd-drop-hover"]:s;return{...A,classNames:i,selected:e,actions:(A.actions??[]).map(c=>({...c,selected:L?String(c.id)===L:!1}))}}),[v,L,uA,eA]),on=()=>{if(!L)return;const A=j.current;A?.isPlaying&&A.pause(),D(r=>{se(r);let e=null;for(const s of r){const i=Array.isArray(s?.actions)?s.actions:[];for(const c of i){if(String(c?.id)!==L)continue;const d=c?.data?.linkId;d!=null&&(e=String(d));break}if(e!=null)break}return r.map(s=>({...s,actions:(s.actions??[]).filter(i=>!(String(i?.id)===L||e&&String(i?.data?.linkId??"")===e))}))}),Z(null)},sn=()=>{const A=j.current,r=A?.getTime?A.getTime():null;if(r==null)return;const e=Number(r);Number.isFinite(e)&&(A?.isPlaying&&A.pause(),SA.current=null,xA.current=null,D(o=>{const s=new Set(["effect0","effect1","effect2"]),i=I=>{const R=I!=null?String(I):"";return R||void 0},c=[];for(let I=0;I<o.length;I++){const R=o[I],S=Array.isArray(R?.actions)?R.actions:[];for(let y=0;y<S.length;y++){const k=S[y],N=String(k?.effectId??"");if(!s.has(N))continue;const C=Number(k?.start),O=Number(k?.end);!Number.isFinite(C)||!Number.isFinite(O)||C<e&&e<O&&c.push({rowIndex:I,actionIndex:y,action:k})}}if(c.length===0)return o;se(o);const d=new Map,l=new Map;for(const I of c){const R=i(I.action?.data?.linkId);if(!R){d.set(String(I.action?.id??""),{});continue}const S=l.get(R)??[];S.push(I),l.set(R,S)}for(const[I,R]of l.entries()){const S=R.length>1,y=S?`link-${hA()}`:I,k=S?`link-${hA()}`:I;for(const N of R)d.set(String(N.action?.id??""),{leftLinkId:y,rightLinkId:k})}const m=structuredClone(o);for(let I=0;I<m.length;I++){const R=m[I],S=Array.isArray(R.actions)?[...R.actions]:[],y=[];for(const k of S){const N=k,C=String(N?.id??""),O=d.get(C);if(!O){y.push(N);continue}const J=Number(N?.start),H=Number(N?.end);if(!Number.isFinite(J)||!Number.isFinite(H)||!(J<e&&e<H)){y.push(N);continue}const P=i(N?.data?.linkId),Y=O.leftLinkId??P,W=O.rightLinkId??P,$=Number(N?.data?.offset??0),cA=Number.isFinite($)?$:0,rA=e-J,oA=cA+(Number.isFinite(rA)?rA:0),lA={...N,start:J,end:e,id:N.id,data:{...N.data,offset:cA,linkId:Y}},de={...N,start:e,end:H,id:`${C}-r-${hA()}`,data:{...N.data,offset:oA,linkId:W}};y.push(lA,de)}y.sort((k,N)=>Number(k.start)-Number(N.start)),R.actions=y}return m}))},an=()=>{const A=j.current,r=A?.getTime?A.getTime():null;A?.isPlaying&&A.pause(),SA.current=null,xA.current=null,Z(null),wA(e=>{if(e.length===0)return e;const o=e[e.length-1],s=structuredClone(x.current);return gA(i=>[...i,s]),D(structuredClone(o)),e.slice(0,-1)}),r!=null&&requestAnimationFrame(()=>{const e=j.current;e?.setTime&&e.setTime(r)})},cn=()=>{const A=j.current,r=A?.getTime?A.getTime():null;A?.isPlaying&&A.pause(),SA.current=null,xA.current=null,Z(null),gA(e=>{if(e.length===0)return e;const o=e[e.length-1],s=structuredClone(x.current);return wA(i=>{const c=[...i,s];return c.length>rt&&c.splice(0,c.length-rt),c}),D(structuredClone(o)),e.slice(0,-1)}),r!=null&&requestAnimationFrame(()=>{const e=j.current;e?.setTime&&e.setTime(r)})},gn=ee.useSensors(ee.useSensor(ee.MouseSensor,{activationConstraint:{distance:6}}),ee.useSensor(ee.TouchSensor,{activationConstraint:{distance:5}})),{setNodeRef:un,isOver:ln}=ee.useDroppable({id:"timeline-drop"}),Bn=A=>{const r=A.active.data.current?.item;U(r??null);const e=DA(A.activatorEvent);if(MA.current=e,HA.current=e,ie(e),e){const s=$A(e);bA(s);const i=TA(e.y);_(s?ve(r??null,i):null)}else _(null),bA(!1);const o=A.active.rect.current.initial;AA(o?{width:o.width,height:o.height}:null)},dn=A=>{const r=A.active.rect.current.initial;!iA&&r&&AA({width:r.width,height:r.height});const e=HA.current;if(!e){_(null);return}const o=Number(A?.delta?.x??0),s=Number(A?.delta?.y??0),i={x:e.x+(Number.isFinite(o)?o:0),y:e.y+(Number.isFinite(s)?s:0)};MA.current=i,ie(i);const c=$A(i);bA(c);const d=TA(i.y);_(c?ve(uA,d):null)},fn=A=>{const r=A.active.data.current?.item,e=HA.current,o=Number(A?.delta?.x??0),s=Number(A?.delta?.y??0),i=e?{x:e.x+(Number.isFinite(o)?o:0),y:e.y+(Number.isFinite(s)?s:0)}:MA.current;MA.current=i;const d=String(A.over?.id??"")==="timeline-drop"||$A(i);if(r&&d&&i){const l=V(i.x),m=TA(i.y),I=ve(r,m);_(I),T(r,Math.max(0,l),I)}U(null),AA(null),_(null),bA(!1),ie(null),HA.current=null},En=()=>{U(null),AA(null),_(null),bA(!1),ie(null),HA.current=null},De=w.useMemo(()=>{if(!uA||!Ne)return null;const A=_A;if(!A)return null;const r=TA(A.y),e=ve(uA,r);if(e==null)return null;const o=V(A.x),s=ue(uA,o,e,x.current),i=pA.getCachedDurationSec(uA.src)??uA.defaultDuration??pt;return{laneRow:e,desiredStart:o,start:s,end:s+i,duration:i,kind:uA.kind}},[uA,Ne,_A,aA,tA,yA]),Cn=A=>{if(uA)return;const r=()=>{const i=j.current,c=!!i?.isPlaying;He.current=c,c&&i?.pause?.()};G&&A.pointerType!=="mouse"&&(GA.current=!!j.current?.isPlaying);const e=A.target;if(!!e?.closest?.(".timeline-editor-cursor-area, .timeline-editor-cursor")){r(),ce.current={pointerId:A.pointerId},Qe.current=null;try{A.currentTarget.setPointerCapture(A.pointerId)}catch{}A.preventDefault();return}if(!G||A.pointerType==="mouse")return;const s=!!e?.closest?.(".timeline-editor-action, [data-action-id]");Qe.current={x:A.clientX,y:A.clientY,isAction:s}},wn=A=>{if(uA||!(G&&A.pointerType!=="mouse"))return;const e=l=>{const m=performance.now();if(m-gt.current>=Zn){gt.current=m,j.current?.setTime?.(l);return}ut.current=l,!lt.current&&(lt.current=requestAnimationFrame(()=>{lt.current=null;const I=ut.current;ut.current=null,I!=null&&(gt.current=performance.now(),j.current?.setTime?.(I))}))};if(ce.current&&ce.current.pointerId===A.pointerId){e(V(A.clientX)),A.preventDefault();return}const o=Qe.current;if(!o||o.isAction)return;const s=Math.abs(A.clientX-o.x),i=Math.abs(A.clientY-o.y),c=8,d=14;if(!ye.current){if(s<c||i>d)return;ye.current={pointerId:A.pointerId},GA.current&&(He.current=!0,j.current?.pause?.());try{A.currentTarget.setPointerCapture(A.pointerId)}catch{}}ye.current.pointerId===A.pointerId&&(e(V(A.clientX)),A.preventDefault())},Rt=A=>{if(uA)return;if(ye.current&&ye.current.pointerId===A.pointerId){ye.current=null;try{A.currentTarget.releasePointerCapture(A.pointerId)}catch{}const m=V(A.clientX),I=He.current||GA.current;He.current=!1,GA.current=!1,Ke(m,{resume:I,afterSeekMs:zt,bufferAheadSec:Vt,bufferTimeoutMs:Zt}),A.preventDefault();return}if(ce.current&&ce.current.pointerId===A.pointerId){ce.current=null;try{A.currentTarget.releasePointerCapture(A.pointerId)}catch{}const m=V(A.clientX),I=He.current;He.current=!1,Ke(m,{resume:I,afterSeekMs:zt,bufferAheadSec:Vt,bufferTimeoutMs:Zt}),A.preventDefault();return}if(!G||A.pointerType==="mouse")return;const r=Qe.current;Qe.current=null;const e=r?Math.abs(A.clientX-r.x):0,o=r?Math.abs(A.clientY-r.y):0;if(e>10||o>10)return;const i=A.target?.closest?.("[data-action-id]"),c=i?.getAttribute("data-row-id"),d=i?.getAttribute("data-action-id");if(c&&d){Z(d);return}const l=V(A.clientX);Z(null),Ke(l,{resume:GA.current}),GA.current=!1},He=w.useRef(!1),gt=w.useRef(0),ut=w.useRef(null),lt=w.useRef(null),_e=w.useRef(0),GA=w.useRef(!1),ye=w.useRef(null),$e=w.useRef(null),Bt=w.useRef(!1),dt=w.useRef(!1),ft=w.useRef(null),Et=w.useRef(!1),At=w.useRef(0),In=()=>{GA.current=!!j.current?.isPlaying};w.useEffect(()=>{const A=e=>{const o=e.target instanceof Element?e.target:null;if(!o)return;const s=!!o.closest?.(".timeline-editor-time-area-interact, .timeline-editor-time-area, .timeline-editor-time"),i=!!OA.current?.contains(o);if(!s&&!i)return;const c=!!j.current?.isPlaying;GA.current=c,s&&c&&(dt.current=!0,ft.current=Number(j.current?.getTime?.())),G&&e.pointerType!=="mouse"&&s&&Number.isFinite(e.pointerId)&&($e.current={pointerId:e.pointerId})},r=e=>{if(!G||e.pointerType==="mouse")return;const o=e.target instanceof Element?e.target:null;if(!o)return;const s=$e.current;if(!s||s.pointerId!==e.pointerId)return;if(!!!o.closest?.(".timeline-editor-time-area-interact, .timeline-editor-time-area, .timeline-editor-time")){$e.current=null;return}const c=V(e.clientX);Ke(c,{resume:GA.current}),GA.current=!1,Bt.current=!0,$e.current=null};return document.addEventListener("pointerdown",A,!0),document.addEventListener("pointerup",r,!0),()=>{document.removeEventListener("pointerdown",A,!0),document.removeEventListener("pointerup",r,!0)}},[]),w.useEffect(()=>{let A=!1,r=null;const e=()=>{if(A)return;const o=j.current;if(!o?.listener){requestAnimationFrame(e);return}const s=()=>{if(Et.current){Et.current=!1;return}if(!dt.current)return;dt.current=!1;const i=ft.current;ft.current=null;const c=Number(j.current?.getTime?.()),l=i!=null&&Number.isFinite(i)&&Number.isFinite(c)&&c>i+qt?Wt:1,m=Tt,I=Kt*l,R=Gt*(l>1?1.25:1),S=jt*l,y=++At.current;(async()=>{const N=j.current;if(N&&(N.pause?.(),await it(m),At.current===y&&(await it(I),At.current===y&&(await CA.waitForActiveBufferedAhead({minSecondsAhead:R,timeoutMs:S,pollMs:Xt}),At.current===y)))){try{EA.unlock()}catch{}N.play?.({autoEnd:!0})}})()};o.listener.on("afterSetTime",s),r=()=>o.listener.off("afterSetTime",s)};return e(),()=>{A=!0,r?.()}},[]);const Ke=(A,r)=>{const e=j.current;if(!e?.setTime)return;const o=Number.isFinite(Number(A))?Math.max(0,Number(A)):0,s=++_e.current,i=!!r?.resume||!!e.isPlaying,c=Number(e.getTime?.()),d=Number.isFinite(c)&&o>c+qt,l=(r?.enableForwardBoost??!0)&&i&&d?Wt:1,m=Math.max(0,Number(r?.pauseBeforeMs??Tt)),I=Math.max(0,Number(r?.afterSeekMs??Kt))*l,R=Math.max(0,Number(r?.bufferAheadSec??Gt))*(l>1?1.25:1),S=Math.max(0,Number(r?.bufferTimeoutMs??jt))*l;(async()=>{if(i&&e.pause?.(),await it(m),_e.current===s&&(Et.current=!0,e.setTime(o),e.reRender?.(),await it(I),_e.current===s&&i&&(await CA.waitForActiveBufferedAhead({minSecondsAhead:R,timeoutMs:S,pollMs:Xt}),_e.current===s))){try{EA.unlock()}catch{}e.play?.({autoEnd:!0})}})()},Qn=A=>{if(!A||A.length===0)return;const r=Array.from(A).filter(Boolean);if(r.length===0)return;const e=[],o=[],s=[];for(const i of r)try{const c=URL.createObjectURL(i);s.push(c),pA.registerSrcMeta(c,{name:i.name,mimeType:i.type});const d={id:`import-${hA()}`,kind:ht(i),name:i.name||"Imported footage",src:c};Ee.current.set(d.id,i),e.push(d),o.push({item:d,file:i})}catch{}if(e.length){te.current.push(...s),Fe(i=>[...i,...e]);try{F?.({entries:o,items:e,files:o.map(i=>i.file)})}catch(i){console.warn("[MeliesVideoEditor] onFootageImported threw",i)}}},[Ge,Ct]=w.useState(!1),vt=w.useRef(null);return w.useEffect(()=>{if(!Ge)return;const A=e=>{e.key==="Escape"&&Ct(!1)},r=e=>{const o=e.target;if(!o)return;const s=vt.current;s&&(s.contains(o)||Ct(!1))};return document.addEventListener("keydown",A),document.addEventListener("mousedown",r,!0),document.addEventListener("touchstart",r,!0),()=>{document.removeEventListener("keydown",A),document.removeEventListener("mousedown",r,!0),document.removeEventListener("touchstart",r,!0)}},[Ge]),h.jsx(ee.DndContext,{sensors:gn,autoScroll:!0,collisionDetection:ee.rectIntersection,onDragStart:Bn,onDragMove:dn,onDragEnd:fn,onDragCancel:En,children:h.jsxs("div",{className:"timeline-editor-engine",children:[h.jsxs("div",{className:"player-stack",children:[h.jsxs("div",{className:"footage-ribbon",role:"toolbar","aria-label":"Footage",children:[h.jsxs("div",{className:"footage-ribbon-left",children:[h.jsxs("div",{className:"footage-toggle-stack",children:[h.jsx("button",{type:"button",className:`footage-ribbon-toggle${q?" is-open":""}`,"aria-expanded":q,"aria-controls":"footage-bin-panel",onClick:()=>vA(A=>!A),children:h.jsx("img",{src:Xn,alt:"Footage",draggable:!1})}),h.jsx("button",{type:"button",className:`footage-edge-handle${q?" is-open":""}`,"aria-label":q?"Close footage bin":"Open footage bin","aria-expanded":q,"aria-controls":"footage-bin-panel",onClick:()=>vA(A=>!A),children:h.jsx("span",{className:"footage-edge-chevron","aria-hidden":"true"})})]}),h.jsx("div",{className:"footage-ribbon-title",children:"Footage Bin"}),h.jsx("div",{className:`footage-ribbon-hint${q?" is-visible":""}`,"aria-hidden":!q,children:"Drag clips to timeline"})]}),h.jsxs("div",{className:"footage-ribbon-right",children:[h.jsxs("div",{className:`footage-import-container${q?" is-visible":""}`,"aria-hidden":!q,children:[h.jsx("input",{ref:ae,type:"file",accept:"video/*,audio/*",multiple:!0,style:{display:"none"},onChange:A=>{Qn(A.target.files),A.target&&(A.target.value="")}}),h.jsx("button",{type:"button",className:"footage-import-button",onClick:()=>{q&&ae.current?.click()},"aria-label":"Import footage",title:"Import footage",children:h.jsx("img",{src:Wn,alt:"",draggable:!1})})]}),h.jsxs("div",{ref:vt,className:"debug-version",children:[h.jsx("button",{type:"button",className:"debug-version-button","aria-label":Ge?"Hide version":"Show version","aria-expanded":Ge,onClick:()=>Ct(A=>!A),title:"Version",children:h.jsx("span",{"aria-hidden":"true",children:"i"})}),Ge?h.jsxs("div",{className:"debug-version-tooltip",role:"tooltip",children:["v",jn]}):null]})]})]}),h.jsx("div",{id:"footage-bin-panel",className:`footage-bin-panel${q?" is-open":""}${uA?" is-dragging":""}`,"aria-hidden":!q,children:h.jsx("div",{className:"footage-bin",children:WA.map(A=>h.jsx(_n,{item:A},A.id))})}),h.jsxs("div",{className:"player-panel",ref:jA,children:[h.jsx("video",{className:"player-video player-video-primary",preload:"auto",playsInline:!0,muted:!0,controls:!1,disablePictureInPicture:!0,disableRemotePlayback:!0,controlsList:"nodownload noplaybackrate noremoteplayback",tabIndex:-1,onContextMenu:A=>A.preventDefault(),ref:A=>CA.attachPrimary(A)}),h.jsx("video",{className:"player-video player-video-secondary",preload:"auto",playsInline:!0,muted:!0,controls:!1,disablePictureInPicture:!0,disableRemotePlayback:!0,controlsList:"nodownload noplaybackrate noremoteplayback",tabIndex:-1,onContextMenu:A=>A.preventDefault(),ref:A=>CA.attachSecondary(A)})]})]}),h.jsx(Kn,{timelineState:j,autoScrollWhenPlay:be,scale:qA,scaleWidth:LA,startLeft:Re,editorData:v,selectedActionId:L,onDeleteSelectedClip:on,onSplitSelectedClip:sn,canUndo:dA.length>0,canRedo:KA.length>0,onUndo:an,onRedo:cn}),h.jsxs("div",{className:`timeline-drop${ln?" is-over":""}`,ref:A=>{OA.current=A,un(A)},onPointerDownCapture:In,onPointerDown:Cn,onPointerMove:wn,onPointerUp:Rt,onPointerCancel:Rt,children:[h.jsxs("div",{className:"timeline-zoom-controls","aria-label":"Timeline zoom",children:[h.jsx("button",{type:"button",className:"timeline-zoom-control",onClick:()=>Me(1/1.25),"aria-label":"Zoom out",title:"Zoom out",children:h.jsx("img",{src:zn,alt:"",draggable:!1})}),h.jsx("button",{type:"button",className:"timeline-zoom-control",onClick:()=>Me(1.25),"aria-label":"Zoom in",title:"Zoom in",children:h.jsx("img",{src:qn,alt:"",draggable:!1})})]}),h.jsx("div",{className:"timeline-lane-labels",style:{top:UA,transform:`translateY(${-tA}px)`,height:yA*ze.length},children:ze.map((A,r)=>h.jsx("div",{className:`timeline-lane-label${eA===r?" is-hover":""}`,style:{height:yA},children:A},A))}),De?h.jsx("div",{className:"timeline-ghost-layer",style:{top:UA,left:ZA},children:(()=>{const A=LA/qA,r=De.duration*A,e=RA(De.start)-aA,o=[];return De.kind==="video"?(o.push({row:De.laneRow,kind:"video"}),o.push({row:zA(De.laneRow),kind:"audio"})):o.push({row:De.laneRow,kind:"audio"}),o.map(s=>h.jsx("div",{className:`timeline-ghost-clip${s.kind==="video"?" is-video":" is-audio"}`,style:{left:e,top:s.row*yA-tA,width:r,height:yA}},`${s.kind}-${s.row}`))})()}):null,Be?h.jsx("div",{className:"timeline-ghost-layer",style:{top:UA,left:ZA},children:(()=>{const A=LA/qA,r=Be.duration*A,e=RA(Be.start)-aA,o=[];return Be.kind==="video"?(o.push({row:Be.laneRow,kind:"video"}),o.push({row:zA(Be.laneRow),kind:"audio"})):o.push({row:Be.laneRow,kind:"audio"}),o.map(s=>h.jsx("div",{className:`timeline-ghost-clip${s.kind==="video"?" is-video":" is-audio"}`,style:{left:e,top:s.row*yA-tA,width:r,height:yA}},`${Be.actionId}-${s.kind}-${s.row}`))})()}):null,h.jsx(mn.Timeline,{scale:qA,scaleWidth:LA,startLeft:Re,rowHeight:yA,autoScroll:!0,ref:j,editorData:rn,effects:Nn,onScroll:A=>{const r=Number(A?.scrollTop??0),e=Number(A?.scrollLeft??0);Number.isFinite(r)&&fA(r),Number.isFinite(e)&&VA(e)},onClickTimeArea:(A,r)=>{if(Z(null),Bt.current){Bt.current=!1;return}Ke(Number(A),{resume:GA.current||!!j.current?.isPlaying}),GA.current=!1},onClickRow:A=>{A.target?.closest?.(".timeline-editor-action")||Z(null)},onClickActionOnly:(A,{action:r})=>{const e=r;e?.id&&Z(String(e.id))},onActionMoveStart:({action:A})=>{ge.current=String(A?.id??""),NA.current={actionId:String(A?.id??""),edge:null};const r=Number(A?.start),e=Number(A?.end),o=String(A?.id??""),s=o?FA(x.current,o):null,i=s?s.rowIndex:0;nA.current={actionId:o,mode:"move",dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:i,committedRowIndex:i,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:Number.isFinite(r)?r:0,initialEnd:Number.isFinite(e)?e:0,takeover:!0},le(),Ze(null),!SA.current&&(SA.current=structuredClone(v),xA.current=he(v))},onActionMoveEnd:()=>{const A=nA.current,r=String(A.actionId??""),e=A.laneIntentRowIndex;r&&e!=null&&(Te.current=!0,D(i=>{const c=tn(i,r,e);return x.current=c,c})),Ze(null);const o=SA.current,s=xA.current;o&&s&&he(x.current)!==s&&se(o),SA.current=null,xA.current=null,ge.current=null,NA.current={actionId:null,edge:null},nA.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:0,committedRowIndex:0,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:0,initialEnd:0,takeover:!1},Ve()},onActionResizeStart:({action:A})=>{ge.current=String(A?.id??""),NA.current={actionId:String(A?.id??""),edge:null};const r=Number(A?.start),e=Number(A?.end),o=String(A?.id??""),s=o?FA(x.current,o):null,i=s?s.rowIndex:0,c=at(s?.action??A),d=o?YA(x.current,o):null,l=d?String(d.action.id):null,m=d?at(d.action):c;QA.current={actionId:o,partnerId:l,dir:null,baseStart:Number.isFinite(r)?r:0,baseOffset:c,partnerBaseOffset:m},nA.current={actionId:o,mode:"resize",dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:i,committedRowIndex:i,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:Number.isFinite(r)?r:0,initialEnd:Number.isFinite(e)?e:0,takeover:!1},le(),!SA.current&&(SA.current=structuredClone(v),xA.current=he(v))},onActionResizeEnd:()=>{const A=SA.current,r=xA.current;A&&r&&he(x.current)!==r&&se(A),SA.current=null,xA.current=null,ge.current=null,NA.current={actionId:null,edge:null},nA.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:0,committedRowIndex:0,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:0,initialEnd:0,takeover:!1},Ve(),QA.current={actionId:null,partnerId:null,dir:null,baseStart:0,baseOffset:0,partnerBaseOffset:0}},onActionMoving:({action:A,row:r,start:e,end:o})=>{const s=String(A?.id??""),i=nA.current,c=(O,J)=>{const H=Number(O),P=Number(J);if(!Number.isFinite(H)||!Number.isFinite(P))return{start:O,end:J,clamped:!1};if(P<=H)return{start:O,end:J,clamped:!1};if(H>=0)return{start:H,end:P,clamped:!1};const Y=-H;return{start:0,end:P+Y,clamped:!0}},d=O=>{const J=String(O?.id??"");return J?x.current.findIndex(H=>String(H?.id??"")===J):-1};if(i.takeover&&i.mode==="move"&&i.actionId===s){const J=Math.max(10,yA*.45),H=i.basePointerTime,P=i.lastPointerTime,Y=H!=null&&P!=null?P-H:0,W=i.initialStart+Y,$=i.initialEnd+Y,cA=z(s,W,$),rA=c(cA.start,cA.end),oA=rA.start,lA=rA.end,fe=String(A?.effectId??"")==="effect1"?"video":"audio",pe=i.lastPointerClientY,et=pe!=null?TA(pe):null,ke=kA(et??i.committedRowIndex,fe),Ot=i.basePointerClientY,Ht=Ot!=null&&pe!=null?Math.abs(pe-Ot):0,yt=typeof performance<"u"&&performance.now?performance.now():Date.now();ke!==i.committedRowIndex&&Ht>=J?(i.laneCandidateRowIndex!==ke&&(i.laneCandidateRowIndex=ke,i.laneCandidateSinceMs=yt),yt-i.laneCandidateSinceMs>=160&&(i.laneIntentRowIndex=ke)):(i.laneCandidateRowIndex=null,i.laneCandidateSinceMs=0,i.laneIntentRowIndex=null);const kt=ke!==i.committedRowIndex&&Ht>=J?ke:null;kt!=null?Ze({actionId:s,laneRow:kt,start:oA,end:lA,duration:Math.max(.01,lA-oA),kind:fe}):Ze(null);const wt=x.current,Nt=wt[i.committedRowIndex];if(Nt&&Ae(Nt,String(A.id),oA,lA))return!1;const It=YA(wt,String(A.id));if(It){const tt=fe==="video"?zA(kA(i.committedRowIndex,"video")):Oe(kA(i.committedRowIndex,"audio")),je=wt[tt];if(je&&Ae(je,String(It.action.id),oA,lA))return!1}return D(tt=>{const je=It?E(tt,String(A.id),oA,lA):b(tt,String(A.id),oA,lA);return x.current=je,je}),!1}const l=Number(e),m=Number(o);if(!Number.isFinite(l)||!Number.isFinite(m)||m<=l)return!1;const I=z(s,l,m),R=c(I.start,I.end),S=R.start,y=R.end;if(!Number.isFinite(S)||!Number.isFinite(y)||y<=S)return!1;const k=r;if(Ae(k,String(A.id),S,y))return!1;const N=x.current,C=YA(N,String(A.id));if(C){const O=String(A?.effectId??""),J=d(k);let H=C.rowIndex;if(J>=0)if(O==="effect1"){const Y=kA(J,"video");H=zA(Y)}else{const Y=kA(J,"audio");H=Oe(Y)}const P=N[H];if(P&&Ae(P,String(C.action.id),S,y))return!1}if((C||I.snapped||R.clamped)&&D(O=>{const J=C?E(O,String(A.id),S,y):b(O,String(A.id),S,y);return x.current=J,J}),I.snapped||R.clamped){const O=nA.current.lastPointerTime;return nA.current={...nA.current,actionId:s,mode:"move",dir:null,basePointerTime:O,lastPointerTime:nA.current.lastPointerTime,initialStart:l,initialEnd:m,takeover:!0},le(),!1}},onActionResizing:({action:A,row:r,start:e,end:o,dir:s})=>{const i=String(A?.id??""),c=nA.current,d=s??"right";if(c.actionId===i&&c.mode==="resize"&&(c.dir=d),QA.current.actionId===i&&(QA.current.dir=d),c.takeover&&c.mode==="resize"&&c.actionId===i){const C=c.basePointerTime,O=c.lastPointerTime,J=C!=null&&O!=null?O-C:0,H=d==="left"?c.initialStart+J:c.initialStart,P=d==="right"?c.initialEnd+J:c.initialEnd,Y=K(i,H,P,d),W=Y.start,$=Y.end;if(Ae(r,String(A.id),W,$))return!1;const rA=x.current,oA=YA(rA,String(A.id));if(oA){const lA=rA[oA.rowIndex];if(lA&&Ae(lA,String(oA.action.id),W,$))return!1}return D(lA=>{let de=oA?E(lA,String(A.id),W,$):b(lA,String(A.id),W,$);if(d==="left"&&QA.current.actionId===String(A.id)){const fe=W-QA.current.baseStart,pe=QA.current.baseOffset+(Number.isFinite(fe)?fe:0),et=QA.current.partnerBaseOffset+(Number.isFinite(fe)?fe:0);de=oA?Ft(de,String(A.id),pe,et):ct(de,String(A.id),pe)}return x.current=de,de}),!1}const l=Number(e),m=Number(o);if(!Number.isFinite(l)||!Number.isFinite(m)||m<=l)return!1;const I=K(i,l,m,d),R=I.start,S=I.end;if(!Number.isFinite(R)||!Number.isFinite(S)||S<=R||Ae(r,String(A.id),R,S))return!1;const k=x.current,N=YA(k,String(A.id));if(N){const C=k[N.rowIndex];if(C&&Ae(C,String(N.action.id),R,S))return!1}if((N||I.snapped)&&D(C=>{const O=N?E(C,String(A.id),R,S):b(C,String(A.id),R,S);return x.current=O,O}),I.snapped){const C=nA.current.lastPointerTime;return nA.current={...nA.current,actionId:i,mode:"resize",dir:d,basePointerTime:C,lastPointerTime:nA.current.lastPointerTime,initialStart:l,initialEnd:m,takeover:!0},le(),!1}},onChange:A=>{if(Te.current){Te.current=!1;return}const r=nn(A),e=ge.current;let o=e?st(r,e):r;if(e&&QA.current.actionId===e&&QA.current.dir==="left"){const l=FA(o,e);if(l){const I=Number(l.action?.start)-QA.current.baseStart,R=QA.current.baseOffset+(Number.isFinite(I)?I:0),S=QA.current.partnerBaseOffset+(Number.isFinite(I)?I:0);o=!!QA.current.partnerId?Ft(o,e,R,S):ct(o,e,R)}}const s=n(o,e);let i=ot(s);for(const l of IA){const m=i[l],R=(Array.isArray(m?.actions)?m.actions:[]).filter(S=>String(S?.effectId??"")==="effect1").map(S=>({id:String(S?.id??""),start:Number(S?.start),end:Number(S?.end)})).filter(S=>S.id&&Number.isFinite(S.start)&&Number.isFinite(S.end)).sort((S,y)=>S.start-y.start);for(let S=0;S<R.length-1;S++){const y=R[S],k=R[S+1],N=k.start-y.end;if(N>0&&N<=Vn){const C=k.end-k.start,O=BA(y.end),J=BA(O+C);i=YA(i,k.id)?E(i,k.id,O,J):b(i,k.id,O,J)}}}i=ot(i),D(i);const c=SA.current,d=xA.current;c&&d&&(he(i)!==d&&se(c),SA.current=null,xA.current=null)},getActionRender:(A,r)=>{if(A.effectId==="effect0")return h.jsx(pn,{action:A,row:r});if(A.effectId==="effect2")return h.jsx(Fn,{action:A,row:r});if(A.effectId==="effect1")return h.jsx(bn,{action:A,row:r})}})]}),h.jsx(ee.DragOverlay,{children:uA?h.jsx("div",{className:"footage-overlay",style:iA?{width:iA.width,height:iA.height}:void 0,children:h.jsx(An,{item:uA,hint:"Drop on timeline",isDragging:!0})}):null})]})})});exports.MeliesVideoEditor=Ar;
|
|
14
|
+
<%s key={someKey} {...props} />`,Le,SA,be,SA),hA[SA+Le]=!0}}return n===u?tA(uA):kA(uA),uA}}function pe(n,f,R){return ke(n,f,R,!0)}function Be(n,f,R){return ke(n,f,R,!1)}var Ne=Be,_A=pe;Ge.Fragment=u,Ge.jsx=Ne,Ge.jsxs=_A})()),Ge}var Yt;function Fn(){return Yt||(Yt=1,process.env.NODE_ENV==="production"?nt.exports=pn():nt.exports=bn()),nt.exports}var S=Fn();const Rn=({action:B,row:t})=>S.jsx("div",{className:"effect0","data-action-id":B.id,"data-row-id":t.id,children:S.jsx("div",{className:"effect0-text",children:`Audio: ${B.data.name}`})}),vn=({action:B,row:t})=>S.jsx("div",{className:"effect1","data-action-id":B.id,"data-row-id":t.id,children:S.jsx("div",{className:"effect1-text",children:`Video: ${B.data.name}`})}),On=({action:B,row:t})=>S.jsx("div",{className:"effect2","data-action-id":B.id,"data-row-id":t.id,children:S.jsx("div",{className:"effect2-text",children:`Video audio: ${B.data.name}`})}),ht=B=>{const t=B.toLowerCase();return t.endsWith(".mp4")||t.endsWith(".webm")||t.endsWith(".mov")||t.endsWith(".m4v")?"video":t.endsWith(".mp3")||t.endsWith(".wav")||t.endsWith(".ogg")||t.endsWith(".m4a")||t.endsWith(".aac")?"audio":"other"};class yn{blobUrlBySrc=new Map;pendingBySrc=new Map;metaBySrc=new Map;durationSecBySrc=new Map;pendingDurationBySrc=new Map;registerSrcMeta(t,a){const u=String(t??"");if(!u)return;const g={name:a?.name?String(a.name):void 0,mimeType:a?.mimeType?String(a.mimeType):void 0},E=this.metaBySrc.get(u);this.metaBySrc.set(u,{name:E?.name??g.name,mimeType:E?.mimeType??g.mimeType})}getSrcMeta(t){const a=String(t??"");if(a)return this.metaBySrc.get(a)}getCachedDurationSec(t){const a=String(t??"");if(!a)return;const u=this.durationSecBySrc.get(a);if(u!=null&&!(!Number.isFinite(u)||u<=0))return u}async getDurationSec(t,a){const u=String(t??"");if(!u)return null;const g=this.getCachedDurationSec(u);if(g!=null)return g;const E=this.pendingDurationBySrc.get(u);if(E)return E;const p=(async()=>{const F=a??ht(u);if(F!=="video"&&F!=="audio")return null;const h=F==="video"?document.createElement("video"):document.createElement("audio");h.preload="metadata";try{h.crossOrigin="anonymous"}catch{}const P=await new Promise(D=>{let L=!1,q=null;const Z=AA=>{L||(L=!0,aA(),D(AA))},JA=()=>{const AA=Number(h.duration);if(Number.isFinite(AA)&&AA>0){Z(AA);return}queueMicrotask(()=>{const iA=Number(h.duration);Z(Number.isFinite(iA)&&iA>0?iA:null)})},bA=()=>{const AA=Number(h.duration);Number.isFinite(AA)&&AA>0&&Z(AA)},QA=()=>Z(null),aA=()=>{if(q!=null){try{window.clearTimeout(q)}catch{}q=null}h.removeEventListener("loadedmetadata",JA),h.removeEventListener("durationchange",bA),h.removeEventListener("error",QA);try{h.src="",h.load()}catch{}};h.addEventListener("loadedmetadata",JA),h.addEventListener("durationchange",bA),h.addEventListener("error",QA),q=window.setTimeout(()=>Z(null),4e3),h.src=u});return P!=null&&Number.isFinite(P)&&P>0?(this.durationSecBySrc.set(u,P),P):null})().catch(F=>(console.warn("[mediaCache] duration probe failed:",u,F),null)).finally(()=>{this.pendingDurationBySrc.delete(u)});return this.pendingDurationBySrc.set(u,p),p}async preloadToBlobUrl(t){if(!t||t.startsWith("blob:")||t.startsWith("data:"))return t;const a=this.blobUrlBySrc.get(t);if(a)return a;const u=this.pendingBySrc.get(t);if(u)return u;const g=(async()=>{const E=await fetch(t,{cache:"force-cache"});if(!E.ok)throw new Error(`Failed to fetch ${t}: ${E.status}`);const p=await E.blob(),F=URL.createObjectURL(p);return this.blobUrlBySrc.set(t,F),F})().catch(E=>(console.warn("[mediaCache] preload failed:",t,E),t)).finally(()=>{this.pendingBySrc.delete(t)});return this.pendingBySrc.set(t,g),g}resolve(t){return this.blobUrlBySrc.get(t)??t}warm(t){t&&(t.startsWith("blob:")||t.startsWith("data:")||this.preloadToBlobUrl(t))}async warmAll(t,a){const u=[],g=new Set;for(const P of t){const D=String(P??"");if(!D||g.has(D))continue;g.add(D);const L=ht(D);L!=="video"&&L!=="audio"||u.push(D)}if(u.length===0)return;const E=Math.max(1,Math.floor(a?.concurrency??3)),p=a?.yieldBetween!==!1;let F=0;const h=Array.from({length:Math.min(E,u.length)},async()=>{for(;F<u.length;){const P=u[F++];await this.preloadToBlobUrl(P),p&&await new Promise(D=>setTimeout(D,0))}});await Promise.all(h)}warmFromEditorData(t){const a=new Set,u=Array.isArray(t)?t:[];for(const g of u){const E=g?.actions;if(Array.isArray(E))for(const p of E){const F=p?.data?.src,h=p?.data?.previewSrc;typeof F=="string"&&F&&a.add(F),typeof h=="string"&&h&&a.add(h)}}for(const g of a){const E=ht(g);(E==="video"||E==="audio")&&this.warm(g)}}}const pA=new yn,Tt=B=>{if(!B)return;const a=B.split("#")[0].split("?")[0].toLowerCase(),u=a.lastIndexOf(".");if(u<0)return;const g=a.slice(u+1);if(g)return g==="m4a"||g==="m4v"?"mp4":g},Hn=B=>{const t=String(B??"").toLowerCase();if(t){if(t==="audio/mpeg"||t==="audio/mp3")return"mp3";if(t==="audio/wav"||t==="audio/x-wav")return"wav";if(t==="audio/ogg")return"ogg";if(t==="audio/aac")return"aac";if(t==="audio/mp4"||t==="video/mp4")return"mp4"}},Kt=B=>{const t=Tt(B);if(t)return t;const a=pA.getSrcMeta(B),u=a?.name?Tt(a.name):void 0;if(u)return u;const g=a?.mimeType?Hn(a.mimeType):void 0;if(g)return g};class kn{howlBySrc={};activeByActionId={};stopActiveAction(t){const a=this.activeByActionId[t];if(!a)return;const u=this.getHowl(a.src);try{u.stop(a.soundId)}catch{}try{a.time&&a.engine.off("afterSetTime",a.time),a.rate&&a.engine.off("afterSetPlayRate",a.rate)}catch{}delete this.activeByActionId[t]}getHowl(t){const a=pA.resolve(t),u=a,g=u;if(this.howlBySrc[g])return this.howlBySrc[g];const E=Kt(t)??Kt(a),p=typeof navigator<"u"&&/iPhone|iPad|iPod|Android/i.test(navigator.userAgent),F=pA.getSrcMeta(t),P=E==="mp4"||F?.mimeType?.startsWith("video/")||p,D=new Mt.Howl({src:[u],format:E?[E]:void 0,loop:!0,autoplay:!1,preload:!0,html5:P});return this.howlBySrc[g]=D,D}unlock(){try{const t=Mt.Howler.ctx;t&&t.state==="suspended"&&t.resume()}catch{}}warm(t){t&&(pA.warm(t),this.getHowl(t))}seekForEngineTime(t,a,u,g,E){const p=Number(E),F=Number.isFinite(p)?p:0,h=t.duration();if(!Number.isFinite(h)||h<=0){t.seek(Math.max(0,g-u+F),a);return}const P=(g-u+F)%h,D=P<0?P+h:P;t.seek(D,a)}start(t){const{actionId:a,src:u,startTime:g,time:E,engine:p}=t,F=Number(t.offset??0),h=Number.isFinite(F)?F:0,P=this.activeByActionId[a];if(P){const QA=P.src!==u,aA=P.engine!==p;if(QA||aA)this.stopActiveAction(a);else{const U=this.getHowl(P.src);U.rate(p.getPlayRate(),P.soundId);try{U.playing(P.soundId)||U.play(P.soundId)}catch{}p.isPlaying||this.seekForEngineTime(U,P.soundId,P.startTime,E,P.offset);return}}const D=this.getHowl(u),L=D.play();D.rate(p.getPlayRate(),L),this.seekForEngineTime(D,L,g,E,h);const q=()=>{this.activeByActionId[a]?.soundId===L&&this.seekForEngineTime(D,L,g,E,h)};D.state()!=="loaded"&&D.once("load",q,L),D.once("play",q,L);let Z=performance.now();const JA=({time:QA})=>{if(!p.isPlaying){this.seekForEngineTime(D,L,g,QA,h);return}const aA=performance.now();if(!(aA-Z<200)){Z=aA;try{const U=Math.max(0,QA-g+h),AA=Number(D.seek(L));if(Number.isFinite(AA)){const iA=AA-U,qA=Math.abs(iA),K=p.getPlayRate();if(qA>.3){this.seekForEngineTime(D,L,g,QA,h),D.rate(K,L);return}if(qA>.04){const ie=iA>0?.95:1.05;D.rate(K*ie,L)}else D.rate(L)!==K&&D.rate(K,L)}}catch{}}},bA=({rate:QA})=>{D.rate(QA,L)};p.on("afterSetTime",JA),p.on("afterSetPlayRate",bA),this.activeByActionId[a]={src:u,startTime:g,offset:h,soundId:L,engine:p,lastResyncAtMs:Z,time:JA,rate:bA}}stop(t){const{actionId:a}=t;this.stopActiveAction(a)}reset(){const t=Object.keys(this.activeByActionId);for(const u of t)this.stopActiveAction(u);const a=Object.values(this.howlBySrc);for(const u of a)try{u.unload()}catch{}this.howlBySrc={}}}const wA=new kn;class Nn{primaryEl=null;secondaryEl=null;activeEl=null;rowData=[];boundEngine=null;vfcHandle=null;rafHandle=null;isPlaying=!1;playbackRate=1;lastVideoClip=null;lastKnownTime=0;constructor(){this.tickLoop=this.tickLoop.bind(this)}attachPrimary(t){this.primaryEl=t,this.initElement(t)}attachSecondary(t){this.secondaryEl=t,this.initElement(t)}initElement(t){t&&(t.style.position="absolute",t.style.top="0",t.style.left="0",t.style.width="100%",t.style.height="100%",t.style.objectFit="contain",t.style.opacity="0",t.preload="auto")}attach(t){this.attachPrimary(t)}setEditorData(t){this.rowData=t}claimVideo(t){this.isPlaying=!!t.isPlaying;const a=Number(t.time);Number.isFinite(a)&&(this.lastKnownTime=a,this.updateState(a))}bindEngine(t){this.unbindEngine(),this.boundEngine=t,this.startLoop()}unbindEngine(){this.stopLoop(),this.boundEngine=null}startLoop(){this.rafHandle||this.vfcHandle||this.tickLoop()}stopLoop(){this.vfcHandle&&this.activeEl?.cancelVideoFrameCallback&&this.activeEl.cancelVideoFrameCallback(this.vfcHandle),this.rafHandle&&cancelAnimationFrame(this.rafHandle),this.vfcHandle=null,this.rafHandle=null}tickLoop(){if(!this.boundEngine)return;const t=this.boundEngine.getTime();this.lastKnownTime=t,this.updateState(this.lastKnownTime),this.rafHandle=requestAnimationFrame(()=>{this.rafHandle=null,this.tickLoop()})}updateState(t){if(!this.primaryEl||!this.secondaryEl)return;const a=this.findClipAtTime(t),u=t+.5;let g=this.findClipAtTime(u);if((!g||a&&g.actionId===a.actionId)&&(g=this.findNextVideoClipAfter(t)),a)this.isLoaded(this.primaryEl,a.src)?this.makeActive(this.primaryEl,a,t):this.isLoaded(this.secondaryEl,a.src)?this.makeActive(this.secondaryEl,a,t):(this.loadVideo(this.primaryEl,a.src),this.makeActive(this.primaryEl,a,t)),this.lastVideoClip=a;else{const E=this.findNextVideoClipStartAfter(t);if(E!=null&&E-t>0&&E-t<=.1&&this.lastVideoClip!=null&&t-this.lastVideoClip.end>=0&&t-this.lastVideoClip.end<=.1&&this.activeEl!=null){const F=this.activeEl;if(!F)return;const h=Math.max(0,this.lastVideoClip.end-this.lastVideoClip.start+this.lastVideoClip.offset-.02),P=F===this.primaryEl?this.secondaryEl:this.primaryEl;P&&(P.style.opacity="0"),F.style.opacity="1";try{F.paused||F.pause();const D=F.duration;Number.isFinite(D)&&D>0?F.currentTime=Math.min(h,Math.max(0,D-.05)):F.currentTime=Math.max(0,h)}catch{}}else this.primaryEl.style.opacity="0",this.secondaryEl.style.opacity="0",this.activeEl=null,this.primaryEl.paused||this.primaryEl.pause(),this.secondaryEl.paused||this.secondaryEl.pause()}if(g&&(!a||g.actionId!==a.actionId)){const E=this.primaryEl===this.activeEl?this.secondaryEl:this.primaryEl;E&&!this.isLoaded(E,g.src)&&(this.loadVideo(E,g.src),E.currentTime=g.offset)}}makeActive(t,a,u){const g=t===this.primaryEl?this.secondaryEl:this.primaryEl;g&&(g.style.opacity="0"),t.style.opacity="1",this.activeEl=t;const E=Math.max(0,u-a.start+a.offset),p=t.currentTime-E,F=Math.abs(p);if(F>.5)t.currentTime=E,Math.abs(t.playbackRate-this.playbackRate)>.01&&(t.playbackRate=this.playbackRate);else if(this.isPlaying&&F>.05){const h=p>0?.75:1.25,P=this.playbackRate*h;Math.abs(t.playbackRate-P)>.01&&(t.playbackRate=P)}else this.isPlaying&&F<=.05&&Math.abs(t.playbackRate-this.playbackRate)>.01&&(t.playbackRate=this.playbackRate);this.isPlaying?t.paused&&t.play().catch(()=>{}):t.paused||t.pause()}loadVideo(t,a){const u=pA.resolve(a);t.getAttribute("data-src-url")!==u&&(t.src=u,t.setAttribute("data-src-url",u),t.load())}isLoaded(t,a){const u=pA.resolve(a);return t.getAttribute("data-src-url")===u}findClipAtTime(t){const a=[];for(const u of this.rowData)for(const g of u.actions)if(g.effectId==="effect1"&&t>=g.start&&t<g.end){const E=g.data,p=E?.previewSrc||E?.src;p&&a.push({actionId:g.id,src:p,start:g.start,end:g.end,offset:Number(E.offset)||0,layer:Number(E.videoLayer)||0})}return a.length===0?null:a.sort((u,g)=>g.layer-u.layer)[0]}findNextVideoClipStartAfter(t){let a=null;for(const u of this.rowData)for(const g of u.actions){if(g.effectId!=="effect1")continue;const E=Number(g.start);if(!Number.isFinite(E)||E<=t)continue;const p=g.data;if((p?.previewSrc||p?.src)&&(Number(p?.videoLayer),a==null||E<a)){a=E;continue}}return a}findNextVideoClipAfter(t){let a=null;for(const u of this.rowData)for(const g of u.actions){if(g.effectId!=="effect1")continue;const E=Number(g.start),p=Number(g.end);if(!Number.isFinite(E)||!Number.isFinite(p)||E<=t)continue;const F=g.data,h=F?.previewSrc||F?.src;if(!h)continue;const P=Number(F?.videoLayer)||0,D={actionId:g.id,src:h,start:E,end:p,offset:Number(F?.offset)||0,layer:P};if(!a){a=D;continue}if(D.start<a.start){a=D;continue}D.start===a.start&&D.layer>a.layer&&(a=D)}return a}play(){this.isPlaying=!0,this.activeEl?.paused&&this.activeEl.play().catch(()=>{})}pause(){this.isPlaying=!1,this.activeEl?.pause(),this.secondaryEl?.pause(),this.primaryEl?.pause()}setRate(t){this.playbackRate=t,this.activeEl&&(this.activeEl.playbackRate=t)}seek(t){this.lastKnownTime=t,this.updateState(t),this.activeEl}warm(t){pA.warm(t)}releaseVideo(t){}setActive(t){}getActiveVideoElement(){return this.activeEl}hasBufferedAhead(t,a){const u=Math.max(0,Number(a)||0),g=Number(t.currentTime);if(!Number.isFinite(g))return!1;try{const E=t.buffered;for(let p=0;p<E.length;p++){const F=E.start(p),h=E.end(p);if(g>=F&&g<=h)return h-g>=u}}catch{}return!1}async waitForActiveBufferedAhead(t){const a=Math.max(0,Number(t?.minSecondsAhead)||0),u=Math.max(0,Number(t?.timeoutMs)||0),g=Math.max(10,Number(t?.pollMs)||50),E=performance.now();for(;performance.now()-E<=u;){const p=this.activeEl;if(!p)return!0;const F=p.readyState>=HTMLMediaElement.HAVE_FUTURE_DATA,h=!p.seeking,P=a<=0?!0:this.hasBufferedAhead(p,a);if(F&&h&&P)return!0;await new Promise(D=>{setTimeout(()=>D(),g)})}return!1}}const IA=new Nn,Jn=160,Pn=5,Un={effect0:{id:"effect0",name:"Play audio",source:{start:({action:B,engine:t,isPlaying:a,time:u})=>{if(a){const{src:g,offset:E}=B.data;wA.warm(g),wA.start({actionId:B.id,src:g,startTime:B.start,engine:t,time:u,offset:E})}},enter:({action:B,engine:t,isPlaying:a,time:u})=>{if(a){const{src:g,offset:E}=B.data;wA.warm(g),wA.start({actionId:B.id,src:g,startTime:B.start,engine:t,time:u,offset:E})}},leave:({action:B})=>{wA.stop({actionId:B.id})},stop:({action:B})=>{wA.stop({actionId:B.id})}}},effect2:{id:"effect2",name:"Play video audio",source:{start:({action:B,engine:t,isPlaying:a,time:u})=>{if(a){const{src:g,offset:E}=B.data;wA.warm(g),wA.start({actionId:B.id,src:g,startTime:B.start,engine:t,time:u,offset:E})}},enter:({action:B,engine:t,isPlaying:a,time:u})=>{if(a){const{src:g,offset:E}=B.data;wA.warm(g),wA.start({actionId:B.id,src:g,startTime:B.start,engine:t,time:u,offset:E})}},leave:({action:B})=>{wA.stop({actionId:B.id})},stop:({action:B})=>{wA.stop({actionId:B.id})}}},effect1:{id:"effect1",name:"Play video",source:{start:({action:B,engine:t,isPlaying:a,time:u})=>{const{src:g,previewSrc:E,offset:p,videoLayer:F}=B.data??{},h=E||g;h&&IA.warm(h),IA.claimVideo({actionId:String(B.id),layer:Number.isFinite(Number(F))?Number(F):0,src:h,engine:t,isPlaying:a,time:u,actionStart:Number(B.start),offset:p})},enter:({action:B,engine:t,isPlaying:a,time:u})=>{const{src:g,previewSrc:E,offset:p,videoLayer:F}=B.data??{},h=E||g;h&&IA.warm(h),IA.claimVideo({actionId:String(B.id),layer:Number.isFinite(Number(F))?Number(F):0,src:h,engine:t,isPlaying:a,time:u,actionStart:Number(B.start),offset:p})},update:({action:B,engine:t,time:a,isPlaying:u})=>{const{src:g,previewSrc:E,offset:p,videoLayer:F}=B.data??{},h=E||g;IA.claimVideo({actionId:String(B.id),layer:Number.isFinite(Number(F))?Number(F):0,src:h,engine:t,isPlaying:u,time:a,actionStart:Number(B.start),offset:p})},leave:({action:B})=>{IA.releaseVideo(String(B.id))},stop:({action:B})=>{IA.releaseVideo(String(B.id))}}}},Mn="",Ln="",xn="",Yn="",Tn="",Kn="",{Option:Gn}=pt.Select,jn=[.2,.5,1,1.5,2],Xn=({timelineState:B,autoScrollWhenPlay:t,scale:a,scaleWidth:u,startLeft:g,editorData:E,selectedActionId:p,onDeleteSelectedClip:F,onSplitSelectedClip:h,canUndo:P,canRedo:D,onUndo:L,onRedo:q,onExport:Z,buildExportEvent:JA})=>{const[bA,QA]=I.useState(!1),[aA,U]=I.useState(0),[AA,iA]=I.useState(!1),qA=I.useRef(0),K=I.useRef(0),ie=I.useRef(0),UA=I.useRef(0),we=I.useRef(0),Ie=I.useRef(0),oe=I.useRef(null);I.useRef(null);const TA=!!p,vA=(M=>{const oA=Array.isArray(E)?E:[];for(const eA of oA){const z=eA?.actions;if(Array.isArray(z))for(const V of z){const _=String(V?.effectId??"");if(!(_==="effect0"||_==="effect1"||_==="effect2"))continue;const cA=Number(V?.start),ce=Number(V?.end);if(!(!Number.isFinite(cA)||!Number.isFinite(ce))&&M>cA&&M<ce)return!0}}return!1})(aA),VA=M=>{const oA=Array.isArray(E)?E:[];for(const eA of oA){const z=eA?.actions;if(Array.isArray(z))for(const V of z){if(V?.effectId!=="effect1")continue;const _=Number(V?.start),fA=Number(V?.end);if(!(!Number.isFinite(_)||!Number.isFinite(fA))&&M>=_&&M<fA)return!0}}return!1},se=M=>{VA(M)};I.useEffect(()=>{if(!B.current)return;const M=B.current;IA.bindEngine(M);const oA=()=>{QA(!0),IA.play()},eA=()=>{QA(!1),IA.pause()},z=({time:_})=>{U(_),se(_)},V=({time:_})=>{const fA=performance.now();if(fA-qA.current<33||(qA.current=fA,U(_),se(_),!t.current))return;const cA=B.current;if(!cA)return;const ce=u/a,GA=g+_*ce;let Ae=oe.current;if(!Ae&&cA.target){const XA=cA.target.querySelector(".ReactVirtualized__Grid");XA&&(oe.current=XA,Ae=XA)}if(!Ae)return;const ee=Ae.clientWidth,zA=Ae.scrollLeft;if(ee<=0)return;const PA=Math.min(80,ee/3),he=zA+PA,jA=zA+ee-PA;let MA=null;GA>jA?MA=GA-(ee-PA):GA<he&&(MA=Math.max(0,GA-PA)),MA!=null&&(Math.abs(MA-zA)<.5||cA.setScrollLeft(MA))};return M.listener.on("play",oA),M.listener.on("paused",eA),M.listener.on("afterSetTime",z),M.listener.on("setTimeByTick",V),()=>{M.listener.off("play",oA),M.listener.off("paused",eA),M.listener.off("afterSetTime",z),M.listener.off("setTimeByTick",V),IA.unbindEngine()}},[E,a,u,g,t]);const ae=()=>{B.current&&(B.current.isPlaying?B.current.pause():(wA.unlock(),B.current.play({autoEnd:!0})))},Qe=M=>{B.current&&(B.current.setPlayRate(M),IA.setRate(M))},me=M=>{const oA=(parseInt(M%1*100+"")+"").padStart(2,"0"),eA=(parseInt(M/60+"")+"").padStart(2,"0"),z=(parseInt(M%60+"")+"").padStart(2,"0");return S.jsx(S.Fragment,{children:`${eA}:${z}.${oA.replace("0.","")}`})},ve=()=>{const M=[],oA=new Set,eA=Array.isArray(E)?E:[];for(const z of eA){const V=z?.actions;if(Array.isArray(V))for(const _ of V){const fA=_?.data?.src;if(!fA)continue;const cA=String(fA);oA.has(cA)||(oA.add(cA),M.push(cA))}}return M},KA=(M,oA)=>{const eA=URL.createObjectURL(M),z=document.createElement("a");z.href=eA,z.download=oA,document.body.appendChild(z),z.click(),z.remove(),setTimeout(()=>URL.revokeObjectURL(eA),3e3)},lA=async()=>{if(!AA){iA(!0);try{if(Z&&JA){await Promise.resolve(Z(JA()));return}const M=ve(),oA=new FormData;oA.append("timeline",JSON.stringify({editorData:E}));for(const V of M){const _=pA.resolve(V),fA=await fetch(_);if(!fA.ok)throw new Error(`Failed to fetch asset: ${V} (${fA.status})`);const cA=await fA.blob();oA.append("assets",cA,encodeURIComponent(V))}const eA=await fetch("/export",{method:"POST",body:oA});if(!eA.ok){const V=await eA.text().catch(()=>"");throw new Error(V||`Export failed (${eA.status})`)}const z=await eA.blob();KA(z,"export.mp4")}finally{iA(!1)}}};return S.jsxs("div",{className:"timeline-player",children:[S.jsx("div",{className:"play-control",role:"button",tabIndex:0,"aria-label":bA?"Pause":"Play",onClick:()=>{Date.now()-K.current<450||ae()},onPointerUp:M=>{M.pointerType!=="mouse"&&(K.current=Date.now(),ae())},children:S.jsx("img",{src:bA?Ln:Mn,alt:"",draggable:!1})}),S.jsx("div",{className:"time",children:me(aA)}),S.jsxs("div",{className:"history-tools",children:[S.jsx("button",{type:"button",className:"history-tool",disabled:!P,"aria-label":"Undo",onClick:()=>{Date.now()-we.current<450||P&&L()},onPointerUp:M=>{M.pointerType!=="mouse"&&(we.current=Date.now(),P&&L())},children:S.jsx("img",{src:xn,alt:"",draggable:!1})}),S.jsx("button",{type:"button",className:"history-tool",disabled:!D,"aria-label":"Redo",onClick:()=>{Date.now()-Ie.current<450||D&&q()},onPointerUp:M=>{M.pointerType!=="mouse"&&(Ie.current=Date.now(),D&&q())},children:S.jsx("img",{src:Yn,alt:"",draggable:!1})})]}),S.jsx("div",{className:"rate-control",children:S.jsx(pt.Select,{size:"small",defaultValue:1,style:{width:120},onChange:Qe,children:jn.map(M=>S.jsx(Gn,{value:M,children:`${M.toFixed(1)}x`},M))})}),S.jsxs("div",{className:"clip-tools",children:[S.jsx("button",{type:"button",className:"clip-tool clip-tool-delete",disabled:!TA,"aria-label":"Delete selected clip",onClick:()=>{Date.now()-ie.current<450||TA&&F()},onPointerUp:M=>{M.pointerType!=="mouse"&&(ie.current=Date.now(),TA&&F())},children:S.jsx("img",{src:Tn,alt:"",draggable:!1})}),S.jsx("button",{type:"button",className:"clip-tool clip-tool-split",disabled:!vA,"aria-label":"Split clips at cursor",onClick:()=>{Date.now()-UA.current<450||vA&&h()},onPointerUp:M=>{M.pointerType!=="mouse"&&(UA.current=Date.now(),vA&&h())},children:S.jsx("img",{src:Kn,alt:"",draggable:!1})})]}),S.jsx("div",{className:"export-control",children:S.jsx(pt.Button,{size:"small",type:"primary",loading:AA,onClick:lA,children:"Export"})})]})};function Wn(){const B=()=>typeof window>"u"?!1:typeof navigator<"u"&&(navigator.maxTouchPoints??0)>0,[t,a]=I.useState(B);return I.useEffect(()=>{if(typeof window>"u"||typeof window.matchMedia!="function")return;const u=window.matchMedia("(pointer: coarse)"),g=()=>a(!!u.matches||B());return g(),typeof u.addEventListener=="function"?(u.addEventListener("change",g),()=>u.removeEventListener("change",g)):(u.addListener(g),()=>u.removeListener(g))},[]),t}const qn="0.1.8",Vn="",zn="",Zn="",_n="",St=()=>[{id:"0",actions:[]},{id:"1",actions:[]},{id:"2",actions:[]},{id:"3",actions:[]}],rt=5,Gt=.001,bt=.01,Ft=10,$n=.03,jt=70,Xt=70,Wt=.4,qt=1400,Vt=100,Ar=500,zt=4,Zt=.05,_t=360,$t=.9,An=3200,it=B=>new Promise(t=>{setTimeout(()=>t(),Math.max(0,B))}),en=async B=>{const t=await pA.getDurationSec(B.src,B.kind);if(t!=null&&Number.isFinite(t)&&t>0)return Math.max(bt,t);const a=Number(B.defaultDuration);return Number.isFinite(a)&&a>0?Math.max(bt,a):Ft},dA=B=>{const t=Number(B);return Number.isFinite(t)?Math.round(t/Gt)*Gt:0},Rt=(B,t)=>{const a=Math.max(0,dA(B)),u=Math.max(0,dA(t));return u<=a?{start:a,end:a+bt}:{start:a,end:u}},ot=B=>{let t=!1;const a=B.map(u=>{const E=(Array.isArray(u?.actions)?u.actions:[]).map(p=>{const F=Number(p?.start),h=Number(p?.end);if(!Number.isFinite(F)||!Number.isFinite(h))return p;const P=Rt(F,h);return P.start===F&&P.end===h?p:(t=!0,{...p,start:P.start,end:P.end})});return{...u,actions:E}});return t?a:B},nn=({item:B,hint:t,isDragging:a,listeners:u,attributes:g})=>S.jsxs("div",{className:`footage-card${a?" is-dragging":""}`,title:t,...u,...g,children:[S.jsx("div",{className:"footage-name",children:B.name}),B.kind==="video"?S.jsx("video",{className:"footage-preview",src:B.src,muted:!0,preload:"metadata",draggable:!1,onDragStart:E=>E.preventDefault(),playsInline:!0}):S.jsx("audio",{className:"footage-audio",src:B.src,controls:!0,preload:"metadata",draggable:!1,onDragStart:E=>E.preventDefault()})]}),er=({item:B})=>{const{attributes:t,listeners:a,setNodeRef:u,transform:g,isDragging:E}=$A.useDraggable({id:`footage-${B.id}`,data:{item:B}}),p=g?{transform:`translate3d(${g.x}px, ${g.y}px, 0)`}:void 0;return S.jsx("div",{ref:u,style:p,className:"draggable-footage-wrapper",children:S.jsx(nn,{item:B,isDragging:E,listeners:a,attributes:t})})},tn=B=>{try{return structuredClone(B)}catch{return JSON.parse(JSON.stringify(B))}},rn=B=>String(B??"").toLowerCase().match(/\.(mp3|wav|m4a|aac|ogg)(\?|#|$)/)?"audio":"video",tr=(B,t)=>{try{const a=String(B??"").split("/").pop()||"";return decodeURIComponent(a.split("?")[0].split("#")[0])||`Footage ${t+1}`}catch{return`Footage ${t+1}`}},Dt=B=>{const t=String(B?.type??"").toLowerCase();return t.startsWith("audio/")?"audio":t.startsWith("video/")?"video":rn(B?.name??"")},nr=I.forwardRef(function({footageUrls:t,footageFiles:a,footageFileHandles:u,autoPlaceFootage:g=!1,initialTimelineSnapshot:E,onTimelineStateChange:p,onFootageImported:F,onExport:h},P){const[D,L]=I.useState(()=>St()),[q,Z]=I.useState(null),[JA,bA]=I.useState([]),[QA,aA]=I.useState([]),U=I.useRef(D);I.useEffect(()=>{IA.setEditorData(D)},[D]);const AA=Wn(),[iA,qA]=I.useState(!1),K=I.useRef(null),ie=I.useRef(null),UA=I.useRef(null),we=I.useRef(!0),Ie=I.useRef(null),oe=I.useRef([]),TA=I.useRef(new Map),EA=I.useRef(new Map);I.useEffect(()=>()=>{wA.reset()},[]);const vA=I.useMemo(()=>{const A=Array.isArray(t)?t.filter(Boolean):[];return A.length?A.map((i,e)=>({id:`url-${e}`,kind:rn(i),name:tr(i,e),src:i})):[]},[t]),[VA,se]=I.useState([]),[ae,Qe]=I.useState([]),[me,ve]=I.useState([]);I.useEffect(()=>{const A=Array.isArray(a)?a.filter(Boolean):[];if(A.length===0){se([]);return}const i=[],e=A.map((o,s)=>{const r=URL.createObjectURL(o);return i.push(r),EA.current.set(r,o),pA.registerSrcMeta(r,{name:o.name,mimeType:o.type}),{id:`file-${s}`,kind:Dt(o),name:o.name||`Footage ${s+1}`,src:r}});return se(e),()=>{for(const o of i){try{URL.revokeObjectURL(o)}catch{}EA.current.delete(o)}}},[a]),I.useEffect(()=>{const A=Array.isArray(u)?u.filter(Boolean):[];if(A.length===0){Qe([]);return}let i=!1;const e=[];return(async()=>{const s=[];for(let r=0;r<A.length;r++){const c=A[r];try{const d=await c.getFile();if(i)return;const l=URL.createObjectURL(d);e.push(l),EA.current.set(l,d),pA.registerSrcMeta(l,{name:d.name||c?.name,mimeType:d.type}),s.push({id:`handle-${r}`,kind:Dt(d),name:d.name||c?.name||`Footage ${r+1}`,src:l})}catch(d){console.warn("[MeliesVideoEditor] Failed to load file handle",d)}}i||Qe(s)})(),()=>{i=!0;for(const s of e){try{URL.revokeObjectURL(s)}catch{}EA.current.delete(s)}}},[u]),I.useEffect(()=>()=>{for(const A of oe.current){try{URL.revokeObjectURL(A)}catch{}EA.current.delete(A)}oe.current=[],TA.current.clear()},[]);const KA=I.useMemo(()=>[...vA,...VA,...ae,...me],[vA,VA,ae,me]);I.useEffect(()=>{for(const A of KA)pA.getDurationSec(A.src,A.kind)},[KA]);const[lA,M]=I.useState(null),[oA,eA]=I.useState(null),[z,V]=I.useState(null),[_,fA]=I.useState(0),[cA,ce]=I.useState(0),[GA,Ae]=I.useState(0),[ee,zA]=I.useState(0),[te,PA]=I.useState(!1),[he,jA]=I.useState(null),MA=I.useRef(null),XA=I.useRef(null),ne=I.useRef(null),ue=I.useRef(null),LA=AA?48:32,Se=30,[OA,Me]=I.useState(()=>Jn),ZA=Pn,Oe=()=>({version:1,editorData:tn(U.current),selectedActionId:q,timelineScaleWidth:OA}),je=()=>{const A=Oe(),i=new Map,e=Array.isArray(A.editorData)?A.editorData:[];for(const r of e){const c=Array.isArray(r?.actions)?r.actions:[];for(const d of c){const l=d?.data?.src;if(!l)continue;const Q=String(l);if(!Q)continue;const w=String(d?.effectId??""),m={...i.get(Q)??{usesVideo:!1,usesAudio:!1}};w==="effect1"&&(m.usesVideo=!0),(w==="effect0"||w==="effect2")&&(m.usesAudio=!0),i.set(Q,m)}}const o=Array.from(i.keys()),s=o.map(r=>{const c=i.get(r)??{usesVideo:!1,usesAudio:!1},d=pA.getSrcMeta(r),l=c.usesVideo?"video":c.usesAudio?"audio":"unknown";return{src:r,kind:l,name:d?.name,mimeType:d?.mimeType}});return{snapshot:A,assetSrcs:o,assets:s,getFileBySrc:r=>{const c=String(r??"");return c?EA.current.get(c)??null:null},listSessionFiles:()=>Array.from(EA.current.entries()).map(([r,c])=>({src:r,file:c}))}},Xe=A=>{if(!A||A.version!==1)throw new Error("[MeliesVideoEditor] Unsupported snapshot version");try{K.current?.isPlaying&&K.current.pause()}catch{}wA.reset();const i=ot(tn(A.editorData??St())),e=A.selectedActionId??null,o=Number(A.timelineScaleWidth);Z(e),bA([]),aA([]),Number.isFinite(o)&&o>0&&Me(Math.min(600,Math.max(60,Math.round(o)))),L(()=>(U.current=i,i))};I.useImperativeHandle(P,()=>({getTimelineSnapshot:Oe,setTimelineSnapshot:Xe,getImportedFileByFootageId:A=>TA.current.get(String(A))??null,listImportedFiles:()=>Array.from(TA.current.entries()).map(([A,i])=>({footageId:A,file:i}))}),[q,OA]),I.useEffect(()=>{p&&p(Oe())},[D,q,OA,p]);const We=I.useRef(null);I.useEffect(()=>{if(!E)return;let A;try{A=JSON.stringify(E)}catch{return}if(We.current!==A){We.current=A;try{Xe(E)}catch(i){console.warn("[MeliesVideoEditor] Failed to apply initialTimelineSnapshot",i)}}},[E]);const qe=A=>{Me(i=>{const e=Math.round(i*A);return Math.min(600,Math.max(60,e))})},mA=[1,0],re=[3,2],Ve=["V2","V1","A2","A1"],De=(A,i)=>{if(i.length===0)return null;if(A==null)return i[0];let e=i[0],o=Math.abs(A-e);for(const s of i){const r=Math.abs(A-s);r<o&&(e=s,o=r)}return e},ge=(A,i)=>A?A.kind==="video"?De(i,mA):De(i,re):null,xA=A=>A===mA[1]?re[1]:re[0],WA=A=>A===re[1]?mA[1]:mA[0],yA=(A,i)=>{const e=i==="video"?mA:re;return De(A,e)??e[0]},ye=I.useRef(!1);I.useEffect(()=>{if(!g||ye.current||KA.length===0||U.current.some(c=>Array.isArray(c?.actions)&&c.actions.length>0))return;const e=mA[0],o=xA(e);ye.current=!0;let s=!1;return(async()=>{const c=St();let d=0;for(const l of KA){if(s)return;const Q=await en(l),w=dA(d),b=dA(d+Q);if(d=b,l.kind==="video"){const m=`link-${FA()}`,y=mA.findIndex(H=>H===e);c[e].actions.push({id:`video-${FA()}`,start:w,end:b,effectId:"effect1",data:{src:l.src,previewSrc:l.previewSrc,name:l.name,linkId:m,videoLayer:y}}),c[o].actions.push({id:`video-audio-${FA()}`,start:w,end:b,effectId:"effect2",data:{src:l.src,name:l.name,linkId:m}})}else c[o].actions.push({id:`audio-${FA()}`,start:w,end:b,effectId:"effect0",data:{src:l.src,name:l.name}})}Z(null),bA([]),aA([]),L(()=>(U.current=c,c))})(),()=>{s=!0}},[g,KA]),I.useEffect(()=>{pA.warmFromEditorData(D);const A=new Set,i=new Set;for(const e of D){const o=e.actions;for(const s of o){if(s.effectId==="effect0"||s.effectId==="effect2"){const r=s.data?.src;r&&A.add(r)}if(s.effectId==="effect1"){const r=s.data,c=r?.previewSrc||r?.src;c&&i.add(c)}}}for(const e of A)wA.warm(e);for(const e of i)IA.warm(e)},[D]),I.useEffect(()=>{U.current=D},[D]),I.useLayoutEffect(()=>{const A=UA.current;if(!A)return;const i=()=>{const o=A.getBoundingClientRect(),s=A.querySelector(".timeline-editor-edit-area");if(!s)return;const r=s.getBoundingClientRect();Ae(r.top-o.top),zA(r.left-o.left)},e=requestAnimationFrame(i);return window.addEventListener("resize",i),()=>{cancelAnimationFrame(e),window.removeEventListener("resize",i)}},[AA,D.length]);const He=A=>{const i=UA.current;if(!i||!A)return!1;const e=i.getBoundingClientRect();return A.x>=e.left&&A.x<=e.right&&A.y>=e.top&&A.y<=e.bottom},st=I.useRef(0),FA=()=>globalThis.crypto?.randomUUID?globalThis.crypto.randomUUID():`uid-${++st.current}`,RA=I.useRef(null),HA=I.useRef(null),le=I.useRef(null),kA=I.useRef({actionId:null,edge:null}),tA=I.useRef({actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:0,committedRowIndex:0,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:0,initialEnd:0,takeover:!1}),hA=I.useRef({actionId:null,partnerId:null,dir:null,baseStart:0,baseOffset:0,partnerBaseOffset:0}),ke=I.useRef(!1),pe=A=>A.map(i=>{const e=(i.actions??[]).map(o=>`${String(o.id)}@${Number(o.start)}-${Number(o.end)}`).join("|");return`${String(i.id)}:${e}`}).join("||"),Be=A=>{const i=structuredClone(A);bA(e=>{const o=[...e,i];return o.length>rt&&o.splice(0,o.length-rt),o}),aA([])},Ne=(A,i,e,o)=>A<o&&i>e,_A=(A,i,e,o)=>{const s=Array.isArray(A?.actions)?A.actions:[];for(const r of s)if(!(!r||r.id===i)&&Ne(e,o,Number(r.start),Number(r.end)))return!0;return!1},n=(A,i)=>{for(let e=0;e<A.length;e++){const o=A[e],s=Array.isArray(o?.actions)?o.actions:[];for(let r=0;r<s.length;r++){const c=s[r];if(String(c?.id)===i)return{rowIndex:e,actionIndex:r,action:c}}}return null},f=(A,i)=>{const e=n(A,i),o=e?.action?.data?.linkId;if(!e||!o)return null;for(let s=0;s<A.length;s++){const r=A[s],c=Array.isArray(r?.actions)?r.actions:[];for(let d=0;d<c.length;d++){const l=c[d];if(l?.data?.linkId&&String(l.data.linkId)===String(o)&&String(l.id)!==String(i))return{rowIndex:s,actionIndex:d,action:l}}}return null},R=(A,i)=>{const e=n(A,i);if(!e)return A;const o=f(A,i);if(!o)return A;const s=Number(e.action.start),r=Number(e.action.end);if(!Number.isFinite(s)||!Number.isFinite(r)||r<=s||Number(o.action.start)===s&&Number(o.action.end)===r)return A;const c=structuredClone(A),d=c[o.rowIndex],l=Array.isArray(d.actions)?[...d.actions]:[],Q={...l[o.actionIndex],start:s,end:r};return l.splice(o.actionIndex,1,Q),d.actions=l,c},x=(A,i)=>{const e=structuredClone(A);for(;e.length<4;)e.push({id:`${e.length}`,actions:[]});const o=C=>C&&typeof C=="object"?C:{},s=(C,v)=>{if(!(!C||typeof C!="object"))return C[v]},r=C=>String(s(C,"id")??""),c=C=>String(s(C,"effectId")??""),d=C=>Number(s(C,"start")),l=C=>Number(s(C,"end")),Q=C=>s(C,"data"),w=C=>{if(!C||typeof C!="object")return 0;const v=Number(C.start);return Number.isFinite(v)?v:0},b=new Map,m=new Map;for(let C=0;C<e.length;C++){const v=e[C],N=Array.isArray(v?.actions)?v.actions:[];for(let O=0;O<N.length;O++){const J=N[O],Y=r(J);if(!Y)continue;b.set(Y,{rowIndex:C,actionIndex:O,action:J});const W=Q(J),$=s(W,"linkId"),gA=$!=null?String($):"";if(!gA)continue;const nA=m.get(gA)??{},rA=c(J);rA==="effect1"?nA.video={rowIndex:C,actionIndex:O,action:J}:rA==="effect2"&&(nA.audio={rowIndex:C,actionIndex:O,action:J}),m.set(gA,nA)}}const y=new Map;for(const C of m.values()){if(!C.video||!C.audio)continue;const v=r(C.video.action),N=r(C.audio.action),O=i&&String(i)===N?"audio":"video",J=O==="audio"?WA(yA(C.audio.rowIndex,"audio")):yA(C.video.rowIndex,"video"),Y=xA(J),W=O==="audio"?C.audio.action:C.video.action,$=d(W),gA=l(W),nA=Number.isFinite($)&&Number.isFinite(gA)&&gA>$,rA=Math.max(0,mA.findIndex(BA=>BA===J));y.set(v,{targetRowIndex:J,patchStartEnd:nA?{start:$,end:gA}:void 0,patchVideoLayer:rA}),y.set(N,{targetRowIndex:Y,patchStartEnd:nA?{start:$,end:gA}:void 0})}for(const[C,v]of b.entries()){if(y.has(C))continue;const N=c(v.action);if(N==="effect1"){const O=yA(v.rowIndex,"video"),J=Math.max(0,mA.findIndex(Y=>Y===O));y.set(C,{targetRowIndex:O,patchVideoLayer:J})}else if(N==="effect0"||N==="effect2"){const O=yA(v.rowIndex,"audio");y.set(C,{targetRowIndex:O})}}const H=e.map(C=>({...C,actions:[]}));let k=!1;for(let C=0;C<e.length;C++){const v=e[C],N=Array.isArray(v?.actions)?v.actions:[];for(const O of N){const J=O,Y=r(J);if(!Y)continue;const W=y.get(Y),$=W?W.targetRowIndex:C,gA=H[$]??H[C];let nA=J;if(W?.patchStartEnd){const rA=W.patchStartEnd.start,BA=W.patchStartEnd.end;(d(nA)!==rA||l(nA)!==BA)&&(nA={...o(nA),start:rA,end:BA},k=!0)}if(W?.patchVideoLayer!=null&&c(nA)==="effect1"){const rA=Number(s(Q(nA),"videoLayer"));if(!Number.isFinite(rA)||rA!==W.patchVideoLayer){const BA={...o(Q(nA)),videoLayer:W.patchVideoLayer};nA={...o(nA),data:BA},k=!0}}$!==C&&(k=!0),gA.actions.push(nA)}}for(const C of H){const v=Array.isArray(C.actions)?[...C.actions]:[];v.sort((N,O)=>w(N)-w(O)),C.actions=v}return k?H:A},G=(A,i,e,o)=>{const s=Rt(e,o);if(!Number.isFinite(s.start)||!Number.isFinite(s.end)||s.end<=s.start)return A;const r=n(A,i);if(!r)return A;const c=f(A,i);if(!c)return A;const d=structuredClone(A),l=d[r.rowIndex],Q=Array.isArray(l.actions)?[...l.actions]:[],w={...Q[r.actionIndex],start:s.start,end:s.end};Q.splice(r.actionIndex,1,w),l.actions=Q;const b=d[c.rowIndex],m=Array.isArray(b.actions)?[...b.actions]:[],y={...m[c.actionIndex],start:s.start,end:s.end};return m.splice(c.actionIndex,1,y),b.actions=m,d},X=(A,i,e,o)=>{const s=Rt(e,o);if(!Number.isFinite(s.start)||!Number.isFinite(s.end)||s.end<=s.start)return A;const r=n(A,i);if(!r)return A;const c=Number(r.action.start),d=Number(r.action.end);if(c===s.start&&d===s.end)return A;const l=structuredClone(A),Q=l[r.rowIndex],w=Array.isArray(Q.actions)?[...Q.actions]:[],b={...w[r.actionIndex],start:s.start,end:s.end};return w.splice(r.actionIndex,1,b),Q.actions=w,l},j=()=>{const A=K.current?.getTime?Number(K.current.getTime()):0;return Number.isFinite(A)?Math.max(0,A):0},T=A=>{const i=[j()],e=A?f(U.current,A):null,o=new Set([A,e?.action.id].filter(Boolean));for(const s of U.current)for(const r of s.actions){if(o.has(String(r.id)))continue;const c=Number(r.start),d=Number(r.end);Number.isFinite(c)&&i.push(c),Number.isFinite(d)&&i.push(d)}return i},CA=(A,i,e)=>{const o=e-i;if(!Number.isFinite(o)||o<=0)return{start:i,end:e,snapped:!1,edge:null};const s=T(A),r=OA/ZA,c=20/r,d=40/r;let l=1/0,Q=-1,w=1/0,b=-1;for(const J of s){const Y=Math.abs(i-J);Y<l&&(l=Y,Q=J);const W=Math.abs(e-J);W<w&&(w=W,b=J)}const m=l<=w?"start":"end",y=Math.min(l,w),H=kA.current,C=H.actionId===A&&H.edge!=null;if(y<=c)kA.current={actionId:A,edge:m};else if(C){if((H.edge==="start"?l:w)>d)return kA.current={actionId:A,edge:null},{start:i,end:e,snapped:!1,edge:null}}else return{start:i,end:e,snapped:!1,edge:null};const v=kA.current.edge;if(v==="start"){const J=Q,Y=J+o;return{start:Math.max(0,J),end:Math.max(Math.max(0,J),Y),snapped:!0,edge:v}}const N=b,O=N-o;return{start:Math.max(0,O),end:Math.max(0,N),snapped:!0,edge:v}},sA=(A,i,e,o)=>{const s=T(A),r=OA/ZA,c=20/r,d=40/r,l=o==="left"?"start":"end";let Q=1/0,w=-1;const b=l==="start"?i:e;for(const v of s){const N=Math.abs(b-v);N<Q&&(Q=N,w=v)}const m=kA.current,H=m.actionId===A&&m.edge===l;if(Q<=c)kA.current={actionId:A,edge:l};else if(H){if(Q>d)return kA.current={actionId:A,edge:null},{start:i,end:e,snapped:!1}}else return{start:i,end:e,snapped:!1};if(l==="start"){const v=Math.max(0,w),N=Math.max(v+.01,e);return{start:v,end:N,snapped:!0}}const k=Math.max(0,w),C=Math.min(i,k-.01);return{start:Math.max(0,C),end:Math.max(0,k),snapped:!0,edge:l}},uA=async(A,i,e)=>{const o=await en(A);let s=Math.max(0,dA(i)),r=dA(s+o);const c=K.current;c?.isPlaying&&c.pause(),L(d=>{Be(d);const l=structuredClone(d);for(;l.length<4;)l.push({id:`${l.length}`,actions:[]});const Q=Number.isFinite(Number(e))?Number(e):null,w=De(Q,mA)??mA[0],b=De(Q,re)??re[0],m=H=>{const k=[];for(const C of H){const v=Array.isArray(l[C]?.actions)?l[C].actions:[];for(const N of v){const O=Number(N?.start),J=Number(N?.end);!Number.isFinite(O)||!Number.isFinite(J)||k.push({start:O,end:J})}}k.sort((C,v)=>C.start-v.start);for(const C of k)Ne(s,r,C.start,C.end)&&(s=dA(C.end),r=dA(s+o))};if(A.kind==="video"){const H=w,k=xA(H);m([H,k]);const C=`link-${FA()}`,v=`video-${FA()}`,N=`video-audio-${FA()}`,O=mA.findIndex(J=>J===H);l[H].actions=[...l[H].actions??[],{id:v,start:dA(s),end:dA(r),effectId:"effect1",data:{src:A.src,previewSrc:A.previewSrc,name:A.name,linkId:C,videoLayer:O}}],l[k].actions=[...l[k].actions??[],{id:N,start:dA(s),end:dA(r),effectId:"effect2",data:{src:A.src,name:A.name,linkId:C}}]}else{const H=b;m([H]),l[H].actions=[...l[H].actions??[],{id:`audio-${FA()}`,start:dA(s),end:dA(r),effectId:"effect0",data:{src:A.src,name:A.name}}]}return ot(l)})},NA=()=>{const A=UA.current;return A?A.querySelector(".timeline-editor-edit-area .ReactVirtualized__Grid")?.scrollLeft??0:0},de=()=>_,SA=A=>{const i=UA.current;if(!i)return 0;const o=(i.querySelector(".timeline-editor-edit-area")??i).getBoundingClientRect(),c=(A-o.x+NA()-Se)*ZA/OA;return Math.max(0,c)},DA=A=>{const i=Number(A);return Number.isFinite(i)?Se+i*OA/ZA:0},Le=(A,i,e,o)=>{const s=pA.getCachedDurationSec(A.src)??A.defaultDuration??Ft;let r=Math.max(0,dA(i)),c=dA(r+s);const d=[];if(A.kind==="video"){const Q=e,w=xA(Q);d.push(Q,w)}else d.push(e);const l=[];for(const Q of d){const w=Array.isArray(o[Q]?.actions)?o[Q].actions:[];for(const b of w){const m=Number(b?.start),y=Number(b?.end);!Number.isFinite(m)||!Number.isFinite(y)||l.push({start:m,end:y})}}l.sort((Q,w)=>Q.start-w.start);for(const Q of l)Ne(r,c,Q.start,Q.end)&&(r=dA(Q.end),c=dA(r+s));return Math.max(0,dA(r))},be=A=>{const i=UA.current;if(!i)return null;const e=i.querySelector(".timeline-editor-edit-area");if(!e)return null;const o=e.getBoundingClientRect(),s=A-o.y;if(s<0||s>o.height)return null;const r=s+de(),c=Math.floor(r/LA);if(!Number.isFinite(c))return null;const d=Math.max(0,U.current.length-1);return Math.min(Math.max(0,c),d)},at=A=>{if(!A)return null;if("clientX"in A&&"clientY"in A){const s=Number(A.clientX),r=Number(A.clientY);if(Number.isFinite(s)&&Number.isFinite(r))return{x:s,y:r}}const i=A.touches,e=A.changedTouches,o=(i&&i.length?i[0]:null)||(e&&e.length?e[0]:null);if(o){const s=Number(o.clientX),r=Number(o.clientY);if(Number.isFinite(s)&&Number.isFinite(r))return{x:s,y:r}}return null},ze=()=>{if(ke.current)return;ke.current=!0;const A=e=>{const o=tA.current;if(!o.actionId||!o.mode||e.isPrimary===!1)return;const s=SA(e.clientX);o.basePointerTime==null&&(o.basePointerTime=s),o.lastPointerTime=s,o.basePointerClientY==null&&(o.basePointerClientY=e.clientY),o.lastPointerClientY=e.clientY},i=()=>{const e={actionId:tA.current.actionId,mode:tA.current.mode};requestAnimationFrame(()=>{tA.current.actionId===e.actionId&&tA.current.mode===e.mode&&(tA.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:0,committedRowIndex:0,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:0,initialEnd:0,takeover:!1},kA.current={actionId:null,edge:null})})};window.addEventListener("pointermove",A,{capture:!0}),window.addEventListener("pointerup",i,{capture:!0}),window.addEventListener("pointercancel",i,{capture:!0}),tA.current._removePointerListeners=()=>{window.removeEventListener("pointermove",A,{capture:!0}),window.removeEventListener("pointerup",i,{capture:!0}),window.removeEventListener("pointercancel",i,{capture:!0}),ke.current=!1}},vt=()=>{const A=tA.current?._removePointerListeners;A?.(),delete tA.current._removePointerListeners},ct=I.useRef(!1),ut=A=>{const i=Number(A?.data?.offset??0);return Number.isFinite(i)?i:0},gt=(A,i,e)=>{const o=n(A,i);if(!o)return A;const s=Math.max(0,Number.isFinite(e)?e:0);if(ut(o.action)===s)return A;const c=structuredClone(A),d=c[o.rowIndex],l=Array.isArray(d.actions)?[...d.actions]:[],Q={...l[o.actionIndex],data:{...l[o.actionIndex]?.data??{},offset:s}};return l.splice(o.actionIndex,1,Q),d.actions=l,c},Ot=(A,i,e,o)=>{const s=n(A,i);if(!s)return A;const r=f(A,i);if(!r)return gt(A,i,e);const c=Math.max(0,Number.isFinite(e)?e:0),d=Math.max(0,Number.isFinite(Number(o))?Number(o):c),l=structuredClone(A),Q=l[s.rowIndex],w=Array.isArray(Q.actions)?[...Q.actions]:[],b={...w[s.actionIndex],data:{...w[s.actionIndex]?.data??{},offset:c}};w.splice(s.actionIndex,1,b),Q.actions=w;const m=l[r.rowIndex],y=Array.isArray(m.actions)?[...m.actions]:[],H={...y[r.actionIndex],data:{...y[r.actionIndex]?.data??{},offset:d}};return y.splice(r.actionIndex,1,H),m.actions=y,l},[fe,Ze]=I.useState(null),on=(A,i,e)=>{const o=n(A,i);if(!o)return A;const r=String(o.action?.effectId??"")==="effect1"?"video":"audio",c=yA(e,r),d=f(A,i),l=!!d,Q=new Set([String(i)]);d&&Q.add(String(d.action.id));const w=Number(o.action?.start),b=Number(o.action?.end);if(!Number.isFinite(w)||!Number.isFinite(b)||b<=w)return A;const m=(O,J,Y)=>{const W=Array.isArray(O?.actions)?O.actions:[];for(const $ of W){const gA=String($?.id??"");if(!(gA&&Q.has(gA))&&Ne(J,Y,Number($?.start),Number($?.end)))return!1}return!0};let y=null,H=null;if(l&&(r==="video"?(y=c,H=xA(y)):(H=c,y=WA(H))),r==="video"){if(!m(A[c],w,b))return A}else if(!m(A[c],w,b))return A;if(y!=null&&!m(A[y],w,b)||H!=null&&!m(A[H],w,b)||!l&&o.rowIndex===c)return A;if(l&&r==="video"&&o.rowIndex===y){const O=d?n(A,String(d.action.id)):null;if(O&&O.rowIndex===H)return A}if(l&&r==="audio"&&o.rowIndex===H){const O=d?n(A,String(d.action.id)):null;if(O&&O.rowIndex===y)return A}const k=structuredClone(A);for(;k.length<4;)k.push({id:`${k.length}`,actions:[]});const C=(O,J)=>{const Y=Array.isArray(O.actions)?O.actions:[];O.actions=Y.filter(W=>String(W?.id??"")!==J)},v=(O,J)=>{const Y=k[O];Y.actions=[...Y.actions??[],J],Y.actions.sort((W,$)=>Number(W.start)-Number($.start))};C(k[o.rowIndex],String(i));let N=o.action;if(r==="video"){const O=Math.max(0,mA.findIndex(J=>J===c));N={...N,data:{...N.data??{},videoLayer:O}}}if(v(c,N),d&&y!=null&&H!=null){const O=n(A,String(d.action.id));if(O){C(k[O.rowIndex],String(d.action.id));const J=r==="video"?H:y;let Y=O.action;if(String(Y?.effectId??"")==="effect1"){const $=Math.max(0,mA.findIndex(gA=>gA===J));Y={...Y,data:{...Y.data??{},videoLayer:$}}}v(J,Y)}}return k},sn=A=>A.map(i=>({...i,selected:void 0,actions:(i.actions??[]).map(e=>({...e,selected:void 0}))})),an=I.useMemo(()=>D.map((A,i)=>{const e=q?(A.actions??[]).some(c=>String(c.id)===q):!1,o=lA!=null&&z!=null&&i===z,s=Array.isArray(A.classNames)?A.classNames:[],r=o?[...s,"dnd-drop-hover"]:s;return{...A,classNames:r,selected:e,actions:(A.actions??[]).map(c=>({...c,selected:q?String(c.id)===q:!1}))}}),[D,q,lA,z]),cn=()=>{if(!q)return;const A=K.current;A?.isPlaying&&A.pause(),L(i=>{Be(i);let e=null;for(const s of i){const r=Array.isArray(s?.actions)?s.actions:[];for(const c of r){if(String(c?.id)!==q)continue;const d=c?.data?.linkId;d!=null&&(e=String(d));break}if(e!=null)break}return i.map(s=>({...s,actions:(s.actions??[]).filter(r=>!(String(r?.id)===q||e&&String(r?.data?.linkId??"")===e))}))}),Z(null)},un=()=>{const A=K.current,i=A?.getTime?A.getTime():null;if(i==null)return;const e=Number(i);Number.isFinite(e)&&(A?.isPlaying&&A.pause(),RA.current=null,HA.current=null,L(o=>{const s=new Set(["effect0","effect1","effect2"]),r=w=>{const b=w!=null?String(w):"";return b||void 0},c=[];for(let w=0;w<o.length;w++){const b=o[w],m=Array.isArray(b?.actions)?b.actions:[];for(let y=0;y<m.length;y++){const H=m[y],k=String(H?.effectId??"");if(!s.has(k))continue;const C=Number(H?.start),v=Number(H?.end);!Number.isFinite(C)||!Number.isFinite(v)||C<e&&e<v&&c.push({rowIndex:w,actionIndex:y,action:H})}}if(c.length===0)return o;Be(o);const d=new Map,l=new Map;for(const w of c){const b=r(w.action?.data?.linkId);if(!b){d.set(String(w.action?.id??""),{});continue}const m=l.get(b)??[];m.push(w),l.set(b,m)}for(const[w,b]of l.entries()){const m=b.length>1,y=m?`link-${FA()}`:w,H=m?`link-${FA()}`:w;for(const k of b)d.set(String(k.action?.id??""),{leftLinkId:y,rightLinkId:H})}const Q=structuredClone(o);for(let w=0;w<Q.length;w++){const b=Q[w],m=Array.isArray(b.actions)?[...b.actions]:[],y=[];for(const H of m){const k=H,C=String(k?.id??""),v=d.get(C);if(!v){y.push(k);continue}const N=Number(k?.start),O=Number(k?.end);if(!Number.isFinite(N)||!Number.isFinite(O)||!(N<e&&e<O)){y.push(k);continue}const J=r(k?.data?.linkId),Y=v.leftLinkId??J,W=v.rightLinkId??J,$=Number(k?.data?.offset??0),gA=Number.isFinite($)?$:0,nA=e-N,rA=gA+(Number.isFinite(nA)?nA:0),BA={...k,start:N,end:e,id:k.id,data:{...k.data,offset:gA,linkId:Y}},Ee={...k,start:e,end:O,id:`${C}-r-${FA()}`,data:{...k.data,offset:rA,linkId:W}};y.push(BA,Ee)}y.sort((H,k)=>Number(H.start)-Number(k.start)),b.actions=y}return Q}))},gn=()=>{const A=K.current,i=A?.getTime?A.getTime():null;A?.isPlaying&&A.pause(),RA.current=null,HA.current=null,Z(null),bA(e=>{if(e.length===0)return e;const o=e[e.length-1],s=structuredClone(U.current);return aA(r=>[...r,s]),L(structuredClone(o)),e.slice(0,-1)}),i!=null&&requestAnimationFrame(()=>{const e=K.current;e?.setTime&&e.setTime(i)})},ln=()=>{const A=K.current,i=A?.getTime?A.getTime():null;A?.isPlaying&&A.pause(),RA.current=null,HA.current=null,Z(null),aA(e=>{if(e.length===0)return e;const o=e[e.length-1],s=structuredClone(U.current);return bA(r=>{const c=[...r,s];return c.length>rt&&c.splice(0,c.length-rt),c}),L(structuredClone(o)),e.slice(0,-1)}),i!=null&&requestAnimationFrame(()=>{const e=K.current;e?.setTime&&e.setTime(i)})},Bn=$A.useSensors($A.useSensor($A.MouseSensor,{activationConstraint:{distance:6}}),$A.useSensor($A.TouchSensor,{activationConstraint:{distance:5}})),{setNodeRef:dn,isOver:fn}=$A.useDroppable({id:"timeline-drop"}),En=A=>{const i=A.active.data.current?.item;M(i??null);const e=at(A.activatorEvent);if(MA.current=e,XA.current=e,jA(e),e){const s=He(e);PA(s);const r=be(e.y);V(s?ge(i??null,r):null)}else V(null),PA(!1);const o=A.active.rect.current.initial;eA(o?{width:o.width,height:o.height}:null)},Cn=A=>{const i=A.active.rect.current.initial;!oA&&i&&eA({width:i.width,height:i.height});const e=XA.current;if(!e){V(null);return}const o=Number(A?.delta?.x??0),s=Number(A?.delta?.y??0),r={x:e.x+(Number.isFinite(o)?o:0),y:e.y+(Number.isFinite(s)?s:0)};MA.current=r,jA(r);const c=He(r);PA(c);const d=be(r.y);V(c?ge(lA,d):null)},wn=A=>{const i=A.active.data.current?.item,e=XA.current,o=Number(A?.delta?.x??0),s=Number(A?.delta?.y??0),r=e?{x:e.x+(Number.isFinite(o)?o:0),y:e.y+(Number.isFinite(s)?s:0)}:MA.current;MA.current=r;const d=String(A.over?.id??"")==="timeline-drop"||He(r);if(i&&d&&r){const l=SA(r.x),Q=be(r.y),w=ge(i,Q);V(w),uA(i,Math.max(0,l),w)}M(null),eA(null),V(null),PA(!1),jA(null),XA.current=null},In=()=>{M(null),eA(null),V(null),PA(!1),jA(null),XA.current=null},Fe=I.useMemo(()=>{if(!lA||!te)return null;const A=he;if(!A)return null;const i=be(A.y),e=ge(lA,i);if(e==null)return null;const o=SA(A.x),s=Le(lA,o,e,U.current),r=pA.getCachedDurationSec(lA.src)??lA.defaultDuration??Ft;return{laneRow:e,desiredStart:o,start:s,end:s+r,duration:r,kind:lA.kind}},[lA,te,he,cA,_,LA]),Qn=A=>{if(lA)return;const i=()=>{const r=K.current,c=!!r?.isPlaying;Je.current=c,c&&r?.pause?.()};AA&&A.pointerType!=="mouse"&&(YA.current=!!K.current?.isPlaying);const e=A.target;if(!!e?.closest?.(".timeline-editor-cursor-area, .timeline-editor-cursor")){i(),ue.current={pointerId:A.pointerId},ne.current=null;try{A.currentTarget.setPointerCapture(A.pointerId)}catch{}A.preventDefault();return}if(!AA||A.pointerType==="mouse")return;const s=!!e?.closest?.(".timeline-editor-action, [data-action-id]");ne.current={x:A.clientX,y:A.clientY,isAction:s}},mn=A=>{if(lA||!(AA&&A.pointerType!=="mouse"))return;const e=l=>{const Q=performance.now();if(Q-lt.current>=Ar){lt.current=Q,K.current?.setTime?.(l);return}Bt.current=l,!dt.current&&(dt.current=requestAnimationFrame(()=>{dt.current=null;const w=Bt.current;Bt.current=null,w!=null&&(lt.current=performance.now(),K.current?.setTime?.(w))}))};if(ue.current&&ue.current.pointerId===A.pointerId){e(SA(A.clientX)),A.preventDefault();return}const o=ne.current;if(!o||o.isAction)return;const s=Math.abs(A.clientX-o.x),r=Math.abs(A.clientY-o.y),c=8,d=14;if(!Pe.current){if(s<c||r>d)return;Pe.current={pointerId:A.pointerId},YA.current&&(Je.current=!0,K.current?.pause?.());try{A.currentTarget.setPointerCapture(A.pointerId)}catch{}}Pe.current.pointerId===A.pointerId&&(e(SA(A.clientX)),A.preventDefault())},yt=A=>{if(lA)return;if(Pe.current&&Pe.current.pointerId===A.pointerId){Pe.current=null;try{A.currentTarget.releasePointerCapture(A.pointerId)}catch{}const Q=SA(A.clientX),w=Je.current||YA.current;Je.current=!1,YA.current=!1,xe(Q,{resume:w,afterSeekMs:_t,bufferAheadSec:$t,bufferTimeoutMs:An}),A.preventDefault();return}if(ue.current&&ue.current.pointerId===A.pointerId){ue.current=null;try{A.currentTarget.releasePointerCapture(A.pointerId)}catch{}const Q=SA(A.clientX),w=Je.current;Je.current=!1,xe(Q,{resume:w,afterSeekMs:_t,bufferAheadSec:$t,bufferTimeoutMs:An}),A.preventDefault();return}if(!AA||A.pointerType==="mouse")return;const i=ne.current;ne.current=null;const e=i?Math.abs(A.clientX-i.x):0,o=i?Math.abs(A.clientY-i.y):0;if(e>10||o>10)return;const r=A.target?.closest?.("[data-action-id]"),c=r?.getAttribute("data-row-id"),d=r?.getAttribute("data-action-id");if(c&&d){Z(d);return}const l=SA(A.clientX);Z(null),xe(l,{resume:YA.current}),YA.current=!1},Je=I.useRef(!1),lt=I.useRef(0),Bt=I.useRef(null),dt=I.useRef(null),_e=I.useRef(0),YA=I.useRef(!1),Pe=I.useRef(null),$e=I.useRef(null),ft=I.useRef(!1),Et=I.useRef(!1),Ct=I.useRef(null),wt=I.useRef(!1),At=I.useRef(0),hn=()=>{YA.current=!!K.current?.isPlaying};I.useEffect(()=>{const A=e=>{const o=e.target instanceof Element?e.target:null;if(!o)return;const s=!!o.closest?.(".timeline-editor-time-area-interact, .timeline-editor-time-area, .timeline-editor-time"),r=!!UA.current?.contains(o);if(!s&&!r)return;const c=!!K.current?.isPlaying;YA.current=c,s&&c&&(Et.current=!0,Ct.current=Number(K.current?.getTime?.())),AA&&e.pointerType!=="mouse"&&s&&Number.isFinite(e.pointerId)&&($e.current={pointerId:e.pointerId})},i=e=>{if(!AA||e.pointerType==="mouse")return;const o=e.target instanceof Element?e.target:null;if(!o)return;const s=$e.current;if(!s||s.pointerId!==e.pointerId)return;if(!!!o.closest?.(".timeline-editor-time-area-interact, .timeline-editor-time-area, .timeline-editor-time")){$e.current=null;return}const c=SA(e.clientX);xe(c,{resume:YA.current}),YA.current=!1,ft.current=!0,$e.current=null};return document.addEventListener("pointerdown",A,!0),document.addEventListener("pointerup",i,!0),()=>{document.removeEventListener("pointerdown",A,!0),document.removeEventListener("pointerup",i,!0)}},[]),I.useEffect(()=>{let A=!1,i=null;const e=()=>{if(A)return;const o=K.current;if(!o?.listener){requestAnimationFrame(e);return}const s=()=>{if(wt.current){wt.current=!1;return}if(!Et.current)return;Et.current=!1;const r=Ct.current;Ct.current=null;const c=Number(K.current?.getTime?.()),l=r!=null&&Number.isFinite(r)&&Number.isFinite(c)&&c>r+Zt?zt:1,Q=jt,w=Xt*l,b=Wt*(l>1?1.25:1),m=qt*l,y=++At.current;(async()=>{const k=K.current;if(k&&(k.pause?.(),await it(Q),At.current===y&&(await it(w),At.current===y&&(await IA.waitForActiveBufferedAhead({minSecondsAhead:b,timeoutMs:m,pollMs:Vt}),At.current===y)))){try{wA.unlock()}catch{}k.play?.({autoEnd:!0})}})()};o.listener.on("afterSetTime",s),i=()=>o.listener.off("afterSetTime",s)};return e(),()=>{A=!0,i?.()}},[]);const xe=(A,i)=>{const e=K.current;if(!e?.setTime)return;const o=Number.isFinite(Number(A))?Math.max(0,Number(A)):0,s=++_e.current,r=!!i?.resume||!!e.isPlaying,c=Number(e.getTime?.()),d=Number.isFinite(c)&&o>c+Zt,l=(i?.enableForwardBoost??!0)&&r&&d?zt:1,Q=Math.max(0,Number(i?.pauseBeforeMs??jt)),w=Math.max(0,Number(i?.afterSeekMs??Xt))*l,b=Math.max(0,Number(i?.bufferAheadSec??Wt))*(l>1?1.25:1),m=Math.max(0,Number(i?.bufferTimeoutMs??qt))*l;(async()=>{if(r&&e.pause?.(),await it(Q),_e.current===s&&(wt.current=!0,e.setTime(o),e.reRender?.(),await it(w),_e.current===s&&r&&(await IA.waitForActiveBufferedAhead({minSecondsAhead:b,timeoutMs:m,pollMs:Vt}),_e.current===s))){try{wA.unlock()}catch{}e.play?.({autoEnd:!0})}})()},Sn=A=>{if(!A||A.length===0)return;const i=Array.from(A).filter(Boolean);if(i.length===0)return;const e=[],o=[],s=[];for(const r of i)try{const c=URL.createObjectURL(r);s.push(c),EA.current.set(c,r),pA.registerSrcMeta(c,{name:r.name,mimeType:r.type});const d={id:`import-${FA()}`,kind:Dt(r),name:r.name||"Imported footage",src:c};TA.current.set(d.id,r),e.push(d),o.push({item:d,file:r})}catch{}if(e.length){oe.current.push(...s),ve(r=>[...r,...e]);try{F?.({entries:o,items:e,files:o.map(r=>r.file)})}catch(r){console.warn("[MeliesVideoEditor] onFootageImported threw",r)}}},[Ye,It]=I.useState(!1),Ht=I.useRef(null);return I.useEffect(()=>{if(!Ye)return;const A=e=>{e.key==="Escape"&&It(!1)},i=e=>{const o=e.target;if(!o)return;const s=Ht.current;s&&(s.contains(o)||It(!1))};return document.addEventListener("keydown",A),document.addEventListener("mousedown",i,!0),document.addEventListener("touchstart",i,!0),()=>{document.removeEventListener("keydown",A),document.removeEventListener("mousedown",i,!0),document.removeEventListener("touchstart",i,!0)}},[Ye]),S.jsx($A.DndContext,{sensors:Bn,autoScroll:!0,collisionDetection:$A.rectIntersection,onDragStart:En,onDragMove:Cn,onDragEnd:wn,onDragCancel:In,children:S.jsxs("div",{className:"timeline-editor-engine",children:[S.jsxs("div",{className:"player-stack",children:[S.jsxs("div",{className:"footage-ribbon",role:"toolbar","aria-label":"Footage",children:[S.jsxs("div",{className:"footage-ribbon-left",children:[S.jsxs("div",{className:"footage-toggle-stack",children:[S.jsx("button",{type:"button",className:`footage-ribbon-toggle${iA?" is-open":""}`,"aria-expanded":iA,"aria-controls":"footage-bin-panel",onClick:()=>qA(A=>!A),children:S.jsx("img",{src:Vn,alt:"Footage",draggable:!1})}),S.jsx("button",{type:"button",className:`footage-edge-handle${iA?" is-open":""}`,"aria-label":iA?"Close footage bin":"Open footage bin","aria-expanded":iA,"aria-controls":"footage-bin-panel",onClick:()=>qA(A=>!A),children:S.jsx("span",{className:"footage-edge-chevron","aria-hidden":"true"})})]}),S.jsx("div",{className:"footage-ribbon-title",children:"Footage Bin"}),S.jsx("div",{className:`footage-ribbon-hint${iA?" is-visible":""}`,"aria-hidden":!iA,children:"Drag clips to timeline"})]}),S.jsxs("div",{className:"footage-ribbon-right",children:[S.jsxs("div",{className:`footage-import-container${iA?" is-visible":""}`,"aria-hidden":!iA,children:[S.jsx("input",{ref:Ie,type:"file",accept:"video/*,audio/*",multiple:!0,style:{display:"none"},onChange:A=>{Sn(A.target.files),A.target&&(A.target.value="")}}),S.jsx("button",{type:"button",className:"footage-import-button",onClick:()=>{iA&&Ie.current?.click()},"aria-label":"Import footage",title:"Import footage",children:S.jsx("img",{src:zn,alt:"",draggable:!1})})]}),S.jsxs("div",{ref:Ht,className:"debug-version",children:[S.jsx("button",{type:"button",className:"debug-version-button","aria-label":Ye?"Hide version":"Show version","aria-expanded":Ye,onClick:()=>It(A=>!A),title:"Version",children:S.jsx("span",{"aria-hidden":"true",children:"i"})}),Ye?S.jsxs("div",{className:"debug-version-tooltip",role:"tooltip",children:["v",qn]}):null]})]})]}),S.jsx("div",{id:"footage-bin-panel",className:`footage-bin-panel${iA?" is-open":""}${lA?" is-dragging":""}`,"aria-hidden":!iA,children:S.jsx("div",{className:"footage-bin",children:KA.map(A=>S.jsx(er,{item:A},A.id))})}),S.jsxs("div",{className:"player-panel",ref:ie,children:[S.jsx("video",{className:"player-video player-video-primary",preload:"auto",playsInline:!0,muted:!0,controls:!1,disablePictureInPicture:!0,disableRemotePlayback:!0,controlsList:"nodownload noplaybackrate noremoteplayback",tabIndex:-1,onContextMenu:A=>A.preventDefault(),ref:A=>IA.attachPrimary(A)}),S.jsx("video",{className:"player-video player-video-secondary",preload:"auto",playsInline:!0,muted:!0,controls:!1,disablePictureInPicture:!0,disableRemotePlayback:!0,controlsList:"nodownload noplaybackrate noremoteplayback",tabIndex:-1,onContextMenu:A=>A.preventDefault(),ref:A=>IA.attachSecondary(A)})]})]}),S.jsx(Xn,{timelineState:K,autoScrollWhenPlay:we,scale:ZA,scaleWidth:OA,startLeft:Se,editorData:D,selectedActionId:q,onDeleteSelectedClip:cn,onSplitSelectedClip:un,canUndo:JA.length>0,canRedo:QA.length>0,onUndo:gn,onRedo:ln,onExport:h,buildExportEvent:je}),S.jsxs("div",{className:`timeline-drop${fn?" is-over":""}`,ref:A=>{UA.current=A,dn(A)},onPointerDownCapture:hn,onPointerDown:Qn,onPointerMove:mn,onPointerUp:yt,onPointerCancel:yt,children:[S.jsxs("div",{className:"timeline-zoom-controls","aria-label":"Timeline zoom",children:[S.jsx("button",{type:"button",className:"timeline-zoom-control",onClick:()=>qe(1/1.25),"aria-label":"Zoom out",title:"Zoom out",children:S.jsx("img",{src:_n,alt:"",draggable:!1})}),S.jsx("button",{type:"button",className:"timeline-zoom-control",onClick:()=>qe(1.25),"aria-label":"Zoom in",title:"Zoom in",children:S.jsx("img",{src:Zn,alt:"",draggable:!1})})]}),S.jsx("div",{className:"timeline-lane-labels",style:{top:GA,transform:`translateY(${-_}px)`,height:LA*Ve.length},children:Ve.map((A,i)=>S.jsx("div",{className:`timeline-lane-label${z===i?" is-hover":""}`,style:{height:LA},children:A},A))}),Fe?S.jsx("div",{className:"timeline-ghost-layer",style:{top:GA,left:ee},children:(()=>{const A=OA/ZA,i=Fe.duration*A,e=DA(Fe.start)-cA,o=[];return Fe.kind==="video"?(o.push({row:Fe.laneRow,kind:"video"}),o.push({row:xA(Fe.laneRow),kind:"audio"})):o.push({row:Fe.laneRow,kind:"audio"}),o.map(s=>S.jsx("div",{className:`timeline-ghost-clip${s.kind==="video"?" is-video":" is-audio"}`,style:{left:e,top:s.row*LA-_,width:i,height:LA}},`${s.kind}-${s.row}`))})()}):null,fe?S.jsx("div",{className:"timeline-ghost-layer",style:{top:GA,left:ee},children:(()=>{const A=OA/ZA,i=fe.duration*A,e=DA(fe.start)-cA,o=[];return fe.kind==="video"?(o.push({row:fe.laneRow,kind:"video"}),o.push({row:xA(fe.laneRow),kind:"audio"})):o.push({row:fe.laneRow,kind:"audio"}),o.map(s=>S.jsx("div",{className:`timeline-ghost-clip${s.kind==="video"?" is-video":" is-audio"}`,style:{left:e,top:s.row*LA-_,width:i,height:LA}},`${fe.actionId}-${s.kind}-${s.row}`))})()}):null,S.jsx(Dn.Timeline,{scale:ZA,scaleWidth:OA,startLeft:Se,rowHeight:LA,autoScroll:!0,ref:K,editorData:an,effects:Un,onScroll:A=>{const i=Number(A?.scrollTop??0),e=Number(A?.scrollLeft??0);Number.isFinite(i)&&fA(i),Number.isFinite(e)&&ce(e)},onClickTimeArea:(A,i)=>{if(Z(null),ft.current){ft.current=!1;return}xe(Number(A),{resume:YA.current||!!K.current?.isPlaying}),YA.current=!1},onClickRow:A=>{A.target?.closest?.(".timeline-editor-action")||Z(null)},onClickActionOnly:(A,{action:i})=>{const e=i;e?.id&&Z(String(e.id))},onActionMoveStart:({action:A})=>{le.current=String(A?.id??""),kA.current={actionId:String(A?.id??""),edge:null};const i=Number(A?.start),e=Number(A?.end),o=String(A?.id??""),s=o?n(U.current,o):null,r=s?s.rowIndex:0;tA.current={actionId:o,mode:"move",dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:r,committedRowIndex:r,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:Number.isFinite(i)?i:0,initialEnd:Number.isFinite(e)?e:0,takeover:!0},ze(),Ze(null),!RA.current&&(RA.current=structuredClone(D),HA.current=pe(D))},onActionMoveEnd:()=>{const A=tA.current,i=String(A.actionId??""),e=A.laneIntentRowIndex;i&&e!=null&&(ct.current=!0,L(r=>{const c=on(r,i,e);return U.current=c,c})),Ze(null);const o=RA.current,s=HA.current;o&&s&&pe(U.current)!==s&&Be(o),RA.current=null,HA.current=null,le.current=null,kA.current={actionId:null,edge:null},tA.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:0,committedRowIndex:0,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:0,initialEnd:0,takeover:!1},vt()},onActionResizeStart:({action:A})=>{le.current=String(A?.id??""),kA.current={actionId:String(A?.id??""),edge:null};const i=Number(A?.start),e=Number(A?.end),o=String(A?.id??""),s=o?n(U.current,o):null,r=s?s.rowIndex:0,c=ut(s?.action??A),d=o?f(U.current,o):null,l=d?String(d.action.id):null,Q=d?ut(d.action):c;hA.current={actionId:o,partnerId:l,dir:null,baseStart:Number.isFinite(i)?i:0,baseOffset:c,partnerBaseOffset:Q},tA.current={actionId:o,mode:"resize",dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:r,committedRowIndex:r,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:Number.isFinite(i)?i:0,initialEnd:Number.isFinite(e)?e:0,takeover:!1},ze(),!RA.current&&(RA.current=structuredClone(D),HA.current=pe(D))},onActionResizeEnd:()=>{const A=RA.current,i=HA.current;A&&i&&pe(U.current)!==i&&Be(A),RA.current=null,HA.current=null,le.current=null,kA.current={actionId:null,edge:null},tA.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:0,committedRowIndex:0,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:0,initialEnd:0,takeover:!1},vt(),hA.current={actionId:null,partnerId:null,dir:null,baseStart:0,baseOffset:0,partnerBaseOffset:0}},onActionMoving:({action:A,row:i,start:e,end:o})=>{const s=String(A?.id??""),r=tA.current,c=(v,N)=>{const O=Number(v),J=Number(N);if(!Number.isFinite(O)||!Number.isFinite(J))return{start:v,end:N,clamped:!1};if(J<=O)return{start:v,end:N,clamped:!1};if(O>=0)return{start:O,end:J,clamped:!1};const Y=-O;return{start:0,end:J+Y,clamped:!0}},d=v=>{const N=String(v?.id??"");return N?U.current.findIndex(O=>String(O?.id??"")===N):-1};if(r.takeover&&r.mode==="move"&&r.actionId===s){const N=Math.max(10,LA*.45),O=r.basePointerTime,J=r.lastPointerTime,Y=O!=null&&J!=null?J-O:0,W=r.initialStart+Y,$=r.initialEnd+Y,gA=CA(s,W,$),nA=c(gA.start,gA.end),rA=nA.start,BA=nA.end,Ce=String(A?.effectId??"")==="effect1"?"video":"audio",Re=r.lastPointerClientY,et=Re!=null?be(Re):null,Ue=yA(et??r.committedRowIndex,Ce),kt=r.basePointerClientY,Nt=kt!=null&&Re!=null?Math.abs(Re-kt):0,Jt=typeof performance<"u"&&performance.now?performance.now():Date.now();Ue!==r.committedRowIndex&&Nt>=N?(r.laneCandidateRowIndex!==Ue&&(r.laneCandidateRowIndex=Ue,r.laneCandidateSinceMs=Jt),Jt-r.laneCandidateSinceMs>=160&&(r.laneIntentRowIndex=Ue)):(r.laneCandidateRowIndex=null,r.laneCandidateSinceMs=0,r.laneIntentRowIndex=null);const Pt=Ue!==r.committedRowIndex&&Nt>=N?Ue:null;Pt!=null?Ze({actionId:s,laneRow:Pt,start:rA,end:BA,duration:Math.max(.01,BA-rA),kind:Ce}):Ze(null);const Qt=U.current,Ut=Qt[r.committedRowIndex];if(Ut&&_A(Ut,String(A.id),rA,BA))return!1;const mt=f(Qt,String(A.id));if(mt){const tt=Ce==="video"?xA(yA(r.committedRowIndex,"video")):WA(yA(r.committedRowIndex,"audio")),Te=Qt[tt];if(Te&&_A(Te,String(mt.action.id),rA,BA))return!1}return L(tt=>{const Te=mt?G(tt,String(A.id),rA,BA):X(tt,String(A.id),rA,BA);return U.current=Te,Te}),!1}const l=Number(e),Q=Number(o);if(!Number.isFinite(l)||!Number.isFinite(Q)||Q<=l)return!1;const w=CA(s,l,Q),b=c(w.start,w.end),m=b.start,y=b.end;if(!Number.isFinite(m)||!Number.isFinite(y)||y<=m)return!1;const H=i;if(_A(H,String(A.id),m,y))return!1;const k=U.current,C=f(k,String(A.id));if(C){const v=String(A?.effectId??""),N=d(H);let O=C.rowIndex;if(N>=0)if(v==="effect1"){const Y=yA(N,"video");O=xA(Y)}else{const Y=yA(N,"audio");O=WA(Y)}const J=k[O];if(J&&_A(J,String(C.action.id),m,y))return!1}if((C||w.snapped||b.clamped)&&L(v=>{const N=C?G(v,String(A.id),m,y):X(v,String(A.id),m,y);return U.current=N,N}),w.snapped||b.clamped){const v=tA.current.lastPointerTime;return tA.current={...tA.current,actionId:s,mode:"move",dir:null,basePointerTime:v,lastPointerTime:tA.current.lastPointerTime,initialStart:l,initialEnd:Q,takeover:!0},ze(),!1}},onActionResizing:({action:A,row:i,start:e,end:o,dir:s})=>{const r=String(A?.id??""),c=tA.current,d=s??"right";if(c.actionId===r&&c.mode==="resize"&&(c.dir=d),hA.current.actionId===r&&(hA.current.dir=d),c.takeover&&c.mode==="resize"&&c.actionId===r){const C=c.basePointerTime,v=c.lastPointerTime,N=C!=null&&v!=null?v-C:0,O=d==="left"?c.initialStart+N:c.initialStart,J=d==="right"?c.initialEnd+N:c.initialEnd,Y=sA(r,O,J,d),W=Y.start,$=Y.end;if(_A(i,String(A.id),W,$))return!1;const nA=U.current,rA=f(nA,String(A.id));if(rA){const BA=nA[rA.rowIndex];if(BA&&_A(BA,String(rA.action.id),W,$))return!1}return L(BA=>{let Ee=rA?G(BA,String(A.id),W,$):X(BA,String(A.id),W,$);if(d==="left"&&hA.current.actionId===String(A.id)){const Ce=W-hA.current.baseStart,Re=hA.current.baseOffset+(Number.isFinite(Ce)?Ce:0),et=hA.current.partnerBaseOffset+(Number.isFinite(Ce)?Ce:0);Ee=rA?Ot(Ee,String(A.id),Re,et):gt(Ee,String(A.id),Re)}return U.current=Ee,Ee}),!1}const l=Number(e),Q=Number(o);if(!Number.isFinite(l)||!Number.isFinite(Q)||Q<=l)return!1;const w=sA(r,l,Q,d),b=w.start,m=w.end;if(!Number.isFinite(b)||!Number.isFinite(m)||m<=b||_A(i,String(A.id),b,m))return!1;const H=U.current,k=f(H,String(A.id));if(k){const C=H[k.rowIndex];if(C&&_A(C,String(k.action.id),b,m))return!1}if((k||w.snapped)&&L(C=>{const v=k?G(C,String(A.id),b,m):X(C,String(A.id),b,m);return U.current=v,v}),w.snapped){const C=tA.current.lastPointerTime;return tA.current={...tA.current,actionId:r,mode:"resize",dir:d,basePointerTime:C,lastPointerTime:tA.current.lastPointerTime,initialStart:l,initialEnd:Q,takeover:!0},ze(),!1}},onChange:A=>{if(ct.current){ct.current=!1;return}const i=sn(A),e=le.current;let o=e?R(i,e):i;if(e&&hA.current.actionId===e&&hA.current.dir==="left"){const l=n(o,e);if(l){const w=Number(l.action?.start)-hA.current.baseStart,b=hA.current.baseOffset+(Number.isFinite(w)?w:0),m=hA.current.partnerBaseOffset+(Number.isFinite(w)?w:0);o=!!hA.current.partnerId?Ot(o,e,b,m):gt(o,e,b)}}const s=x(o,e);let r=ot(s);for(const l of mA){const Q=r[l],b=(Array.isArray(Q?.actions)?Q.actions:[]).filter(m=>String(m?.effectId??"")==="effect1").map(m=>({id:String(m?.id??""),start:Number(m?.start),end:Number(m?.end)})).filter(m=>m.id&&Number.isFinite(m.start)&&Number.isFinite(m.end)).sort((m,y)=>m.start-y.start);for(let m=0;m<b.length-1;m++){const y=b[m],H=b[m+1],k=H.start-y.end;if(k>0&&k<=$n){const C=H.end-H.start,v=dA(y.end),N=dA(v+C);r=f(r,H.id)?G(r,H.id,v,N):X(r,H.id,v,N)}}}r=ot(r),L(r);const c=RA.current,d=HA.current;c&&d&&(pe(r)!==d&&Be(c),RA.current=null,HA.current=null)},getActionRender:(A,i)=>{if(A.effectId==="effect0")return S.jsx(Rn,{action:A,row:i});if(A.effectId==="effect2")return S.jsx(On,{action:A,row:i});if(A.effectId==="effect1")return S.jsx(vn,{action:A,row:i})}})]}),S.jsx($A.DragOverlay,{children:lA?S.jsx("div",{className:"footage-overlay",style:oA?{width:oA.width,height:oA.height}:void 0,children:S.jsx(nn,{item:lA,hint:"Drop on timeline",isDragging:!0})}):null})]})})});exports.MeliesVideoEditor=nr;
|