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