melies-video-editor 0.1.1 → 0.1.2

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 CHANGED
@@ -1,14 +1,14 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const D=require("react"),Te=require("@xzdarcy/react-timeline-editor"),Oe=require("howler"),He=require("antd"),EA=require("@dnd-kit/core");var de={exports:{}},Ae={};var Re;function Le(){if(Re)return Ae;Re=1;var u=D,s=Symbol.for("react.element"),l=Symbol.for("react.fragment"),g=Object.prototype.hasOwnProperty,d=u.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,I={key:!0,ref:!0,__self:!0,__source:!0};function m(b,v,p){var N,F={},q=null,W=null;p!==void 0&&(q=""+p),v.key!==void 0&&(q=""+v.key),v.ref!==void 0&&(W=v.ref);for(N in v)g.call(v,N)&&!I.hasOwnProperty(N)&&(F[N]=v[N]);if(b&&b.defaultProps)for(N in v=b.defaultProps,v)F[N]===void 0&&(F[N]=v[N]);return{$$typeof:s,type:b,key:q,ref:W,props:F,_owner:d.current}}return Ae.Fragment=l,Ae.jsx=m,Ae.jsxs=m,Ae}var ee={};var Se;function je(){return Se||(Se=1,process.env.NODE_ENV!=="production"&&(function(){var u=D,s=Symbol.for("react.element"),l=Symbol.for("react.portal"),g=Symbol.for("react.fragment"),d=Symbol.for("react.strict_mode"),I=Symbol.for("react.profiler"),m=Symbol.for("react.provider"),b=Symbol.for("react.context"),v=Symbol.for("react.forward_ref"),p=Symbol.for("react.suspense"),N=Symbol.for("react.suspense_list"),F=Symbol.for("react.memo"),q=Symbol.for("react.lazy"),W=Symbol.for("react.offscreen"),uA=Symbol.iterator,K="@@iterator";function j(e){if(e===null||typeof e!="object")return null;var c=uA&&e[uA]||e[K];return typeof c=="function"?c:null}var V=u.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function U(e){{for(var c=arguments.length,A=new Array(c>1?c-1:0),t=1;t<c;t++)A[t-1]=arguments[t];gA("error",e,A)}}function gA(e,c,A){{var t=V.ReactDebugCurrentFrame,n=t.getStackAddendum();n!==""&&(c+="%s",A=A.concat([n]));var o=A.map(function(r){return String(r)});o.unshift("Warning: "+c),Function.prototype.apply.call(console[e],console,o)}}var CA=!1,rA=!1,BA=!1,ie=!1,FA=!1,yA;yA=Symbol.for("react.module.reference");function JA(e){return!!(typeof e=="string"||typeof e=="function"||e===g||e===I||FA||e===d||e===p||e===N||ie||e===W||CA||rA||BA||typeof e=="object"&&e!==null&&(e.$$typeof===q||e.$$typeof===F||e.$$typeof===m||e.$$typeof===b||e.$$typeof===v||e.$$typeof===yA||e.getModuleId!==void 0))}function qA(e,c,A){var t=e.displayName;if(t)return t;var n=c.displayName||c.name||"";return n!==""?A+"("+n+")":A}function xA(e){return e.displayName||"Context"}function iA(e){if(e==null)return null;if(typeof e.tag=="number"&&U("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case g:return"Fragment";case l:return"Portal";case I:return"Profiler";case d:return"StrictMode";case p:return"Suspense";case N:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case b:var c=e;return xA(c)+".Consumer";case m:var A=e;return xA(A._context)+".Provider";case v:return qA(e,e.render,"ForwardRef");case F:var t=e.displayName||null;return t!==null?t:iA(e.type)||"Memo";case q:{var n=e,o=n._payload,r=n._init;try{return iA(r(o))}catch{return null}}}return null}var oA=Object.assign,AA=0,UA,wA,w,S,x,H,O;function G(){}G.__reactDisabledLog=!0;function k(){{if(AA===0){UA=console.log,wA=console.info,w=console.warn,S=console.error,x=console.group,H=console.groupCollapsed,O=console.groupEnd;var e={configurable:!0,enumerable:!0,value:G,writable:!0};Object.defineProperties(console,{info:e,log:e,warn:e,error:e,group:e,groupCollapsed:e,groupEnd:e})}AA++}}function IA(){{if(AA--,AA===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:oA({},e,{value:UA}),info:oA({},e,{value:wA}),warn:oA({},e,{value:w}),error:oA({},e,{value:S}),group:oA({},e,{value:x}),groupCollapsed:oA({},e,{value:H}),groupEnd:oA({},e,{value:O})})}AA<0&&U("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var lA=V.ReactCurrentDispatcher,sA;function NA(e,c,A){{if(sA===void 0)try{throw Error()}catch(n){var t=n.stack.trim().match(/\n( *(at )?)/);sA=t&&t[1]||""}return`
2
- `+sA+e}}var GA=!1,WA;{var fA=typeof WeakMap=="function"?WeakMap:Map;WA=new fA}function z(e,c){if(!e||GA)return"";{var A=WA.get(e);if(A!==void 0)return A}var t;GA=!0;var n=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var o;o=lA.current,lA.current=null,k();try{if(c){var r=function(){throw Error()};if(Object.defineProperty(r.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(r,[])}catch(h){t=h}Reflect.construct(e,[],r)}else{try{r.call()}catch(h){t=h}e.call(r.prototype)}}else{try{throw Error()}catch(h){t=h}e()}}catch(h){if(h&&t&&typeof h.stack=="string"){for(var i=h.stack.split(`
3
- `),a=t.stack.split(`
4
- `),B=i.length-1,f=a.length-1;B>=1&&f>=0&&i[B]!==a[f];)f--;for(;B>=1&&f>=0;B--,f--)if(i[B]!==a[f]){if(B!==1||f!==1)do if(B--,f--,f<0||i[B]!==a[f]){var Q=`
5
- `+i[B].replace(" at new "," at ");return e.displayName&&Q.includes("<anonymous>")&&(Q=Q.replace("<anonymous>",e.displayName)),typeof e=="function"&&WA.set(e,Q),Q}while(B>=1&&f>=0);break}}}finally{GA=!1,lA.current=o,IA(),Error.prepareStackTrace=n}var C=e?e.displayName||e.name:"",y=C?NA(C):"";return typeof e=="function"&&WA.set(e,y),y}function eA(e,c,A){return z(e,!1)}function YA(e){var c=e.prototype;return!!(c&&c.isReactComponent)}function TA(e,c,A){if(e==null)return"";if(typeof e=="function")return z(e,YA(e));if(typeof e=="string")return NA(e);switch(e){case p:return NA("Suspense");case N:return NA("SuspenseList")}if(typeof e=="object")switch(e.$$typeof){case v:return eA(e.render);case F:return TA(e.type,c,A);case q:{var t=e,n=t._payload,o=t._init;try{return TA(o(n),c,A)}catch{}}}return""}var MA=Object.prototype.hasOwnProperty,Z={},X=V.ReactDebugCurrentFrame;function PA(e){if(e){var c=e._owner,A=TA(e.type,e._source,c?c.type:null);X.setExtraStackFrame(A)}else X.setExtraStackFrame(null)}function LA(e,c,A,t,n){{var o=Function.call.bind(MA);for(var r in e)if(o(e,r)){var i=void 0;try{if(typeof e[r]!="function"){var a=Error((t||"React class")+": "+A+" type `"+r+"` is invalid; it must be a function, usually from the `prop-types` package, but received `"+typeof e[r]+"`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");throw a.name="Invariant Violation",a}i=e[r](c,r,t,A,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(B){i=B}i&&!(i instanceof Error)&&(PA(n),U("%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).",t||"React class",A,r,typeof i),PA(null)),i instanceof Error&&!(i.message in Z)&&(Z[i.message]=!0,PA(n),U("Failed %s type: %s",A,i.message),PA(null))}}}var HA=Array.isArray;function jA(e){return HA(e)}function dA(e){{var c=typeof Symbol=="function"&&Symbol.toStringTag,A=c&&e[Symbol.toStringTag]||e.constructor.name||"Object";return A}}function KA(e){try{return DA(e),!1}catch{return!0}}function DA(e){return""+e}function oe(e){if(KA(e))return U("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",dA(e)),DA(e)}var XA=V.ReactCurrentOwner,zA={key:!0,ref:!0,__self:!0,__source:!0},ZA,_A;function se(e){if(MA.call(e,"ref")){var c=Object.getOwnPropertyDescriptor(e,"ref").get;if(c&&c.isReactWarning)return!1}return e.ref!==void 0}function Ce(e){if(MA.call(e,"key")){var c=Object.getOwnPropertyDescriptor(e,"key").get;if(c&&c.isReactWarning)return!1}return e.key!==void 0}function we(e,c){typeof e.ref=="string"&&XA.current}function Ie(e,c){{var A=function(){ZA||(ZA=!0,U("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)",c))};A.isReactWarning=!0,Object.defineProperty(e,"key",{get:A,configurable:!0})}}function kA(e,c){{var A=function(){_A||(_A=!0,U("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)",c))};A.isReactWarning=!0,Object.defineProperty(e,"ref",{get:A,configurable:!0})}}var De=function(e,c,A,t,n,o,r){var i={$$typeof:s,type:e,key:c,ref:A,props:r,_owner:o};return i._store={},Object.defineProperty(i._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:!1}),Object.defineProperty(i,"_self",{configurable:!1,enumerable:!1,writable:!1,value:t}),Object.defineProperty(i,"_source",{configurable:!1,enumerable:!1,writable:!1,value:n}),Object.freeze&&(Object.freeze(i.props),Object.freeze(i)),i};function he(e,c,A,t,n){{var o,r={},i=null,a=null;A!==void 0&&(oe(A),i=""+A),Ce(c)&&(oe(c.key),i=""+c.key),se(c)&&(a=c.ref,we(c,n));for(o in c)MA.call(c,o)&&!zA.hasOwnProperty(o)&&(r[o]=c[o]);if(e&&e.defaultProps){var B=e.defaultProps;for(o in B)r[o]===void 0&&(r[o]=B[o])}if(i||a){var f=typeof e=="function"?e.displayName||e.name||"Unknown":e;i&&Ie(r,f),a&&kA(r,f)}return De(e,i,a,n,t,XA.current,r)}}var OA=V.ReactCurrentOwner,ae=V.ReactDebugCurrentFrame;function aA(e){if(e){var c=e._owner,A=TA(e.type,e._source,c?c.type:null);ae.setExtraStackFrame(A)}else ae.setExtraStackFrame(null)}var VA;VA=!1;function $A(e){return typeof e=="object"&&e!==null&&e.$$typeof===s}function ce(){{if(OA.current){var e=iA(OA.current.type);if(e)return`
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const F=require("react"),lt=require("@xzdarcy/react-timeline-editor"),nt=require("howler"),et=require("antd"),jA=require("@dnd-kit/core");var We={exports:{}},He={};var rt;function dt(){if(rt)return He;rt=1;var B=F,s=Symbol.for("react.element"),d=Symbol.for("react.fragment"),c=Object.prototype.hasOwnProperty,f=B.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,Q={key:!0,ref:!0,__self:!0,__source:!0};function b(U,H,Y){var m,X={},G=null,DA=null;Y!==void 0&&(G=""+Y),H.key!==void 0&&(G=""+H.key),H.ref!==void 0&&(DA=H.ref);for(m in H)c.call(H,m)&&!Q.hasOwnProperty(m)&&(X[m]=H[m]);if(U&&U.defaultProps)for(m in H=U.defaultProps,H)X[m]===void 0&&(X[m]=H[m]);return{$$typeof:s,type:U,key:G,ref:DA,props:X,_owner:f.current}}return He.Fragment=d,He.jsx=b,He.jsxs=b,He}var Ne={};var it;function ft(){return it||(it=1,process.env.NODE_ENV!=="production"&&(function(){var B=F,s=Symbol.for("react.element"),d=Symbol.for("react.portal"),c=Symbol.for("react.fragment"),f=Symbol.for("react.strict_mode"),Q=Symbol.for("react.profiler"),b=Symbol.for("react.provider"),U=Symbol.for("react.context"),H=Symbol.for("react.forward_ref"),Y=Symbol.for("react.suspense"),m=Symbol.for("react.suspense_list"),X=Symbol.for("react.memo"),G=Symbol.for("react.lazy"),DA=Symbol.for("react.offscreen"),z=Symbol.iterator,BA="@@iterator";function hA(e){if(e===null||typeof e!="object")return null;var g=z&&e[z]||e[BA];return typeof g=="function"?g:null}var yA=B.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function rA(e){{for(var g=arguments.length,E=new Array(g>1?g-1:0),p=1;p<g;p++)E[p-1]=arguments[p];cA("error",e,E)}}function cA(e,g,E){{var p=yA.ReactDebugCurrentFrame,T=p.getStackAddendum();T!==""&&(g+="%s",E=E.concat([T]));var Z=E.map(function(L){return String(L)});Z.unshift("Warning: "+g),Function.prototype.apply.call(console[e],console,Z)}}var _A=!1,TA=!1,JA=!1,WA=!1,SA=!1,bA;bA=Symbol.for("react.module.reference");function Ue(e){return!!(typeof e=="string"||typeof e=="function"||e===c||e===Q||SA||e===f||e===Y||e===m||WA||e===DA||_A||TA||JA||typeof e=="object"&&e!==null&&(e.$$typeof===G||e.$$typeof===X||e.$$typeof===b||e.$$typeof===U||e.$$typeof===H||e.$$typeof===bA||e.getModuleId!==void 0))}function XA(e,g,E){var p=e.displayName;if(p)return p;var T=g.displayName||g.name||"";return T!==""?E+"("+T+")":E}function $A(e){return e.displayName||"Context"}function mA(e){if(e==null)return null;if(typeof e.tag=="number"&&rA("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case c:return"Fragment";case d:return"Portal";case Q:return"Profiler";case f:return"StrictMode";case Y:return"Suspense";case m:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case U:var g=e;return $A(g)+".Consumer";case b:var E=e;return $A(E._context)+".Provider";case H:return XA(e,e.render,"ForwardRef");case X:var p=e.displayName||null;return p!==null?p:mA(e.type)||"Memo";case G:{var T=e,Z=T._payload,L=T._init;try{return mA(L(Z))}catch{return null}}}return null}var HA=Object.assign,UA=0,de,se,GA,ae,zA,v,AA;function eA(){}eA.__reactDisabledLog=!0;function V(){{if(UA===0){de=console.log,se=console.info,GA=console.warn,ae=console.error,zA=console.group,v=console.groupCollapsed,AA=console.groupEnd;var e={configurable:!0,enumerable:!0,value:eA,writable:!0};Object.defineProperties(console,{info:e,log:e,warn:e,error:e,group:e,groupCollapsed:e,groupEnd:e})}UA++}}function q(){{if(UA--,UA===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:HA({},e,{value:de}),info:HA({},e,{value:se}),warn:HA({},e,{value:GA}),error:HA({},e,{value:ae}),group:HA({},e,{value:zA}),groupCollapsed:HA({},e,{value:v}),groupEnd:HA({},e,{value:AA})})}UA<0&&rA("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var tA=yA.ReactCurrentDispatcher,aA;function PA(e,g,E){{if(aA===void 0)try{throw Error()}catch(T){var p=T.stack.trim().match(/\n( *(at )?)/);aA=p&&p[1]||""}return`
2
+ `+aA+e}}var NA=!1,LA;{var fA=typeof WeakMap=="function"?WeakMap:Map;LA=new fA}function YA(e,g){if(!e||NA)return"";{var E=LA.get(e);if(E!==void 0)return E}var p;NA=!0;var T=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var Z;Z=tA.current,tA.current=null,V();try{if(g){var L=function(){throw Error()};if(Object.defineProperty(L.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(L,[])}catch(EA){p=EA}Reflect.construct(e,[],L)}else{try{L.call()}catch(EA){p=EA}e.call(L.prototype)}}else{try{throw Error()}catch(EA){p=EA}e()}}catch(EA){if(EA&&p&&typeof EA.stack=="string"){for(var M=EA.stack.split(`
3
+ `),lA=p.stack.split(`
4
+ `),iA=M.length-1,sA=lA.length-1;iA>=1&&sA>=0&&M[iA]!==lA[sA];)sA--;for(;iA>=1&&sA>=0;iA--,sA--)if(M[iA]!==lA[sA]){if(iA!==1||sA!==1)do if(iA--,sA--,sA<0||M[iA]!==lA[sA]){var RA=`
5
+ `+M[iA].replace(" at new "," at ");return e.displayName&&RA.includes("<anonymous>")&&(RA=RA.replace("<anonymous>",e.displayName)),typeof e=="function"&&LA.set(e,RA),RA}while(iA>=1&&sA>=0);break}}}finally{NA=!1,tA.current=Z,q(),Error.prepareStackTrace=T}var ie=e?e.displayName||e.name:"",VA=ie?PA(ie):"";return typeof e=="function"&&LA.set(e,VA),VA}function Pe(e,g,E){return YA(e,!1)}function ce(e){var g=e.prototype;return!!(g&&g.isReactComponent)}function qA(e,g,E){if(e==null)return"";if(typeof e=="function")return YA(e,ce(e));if(typeof e=="string")return PA(e);switch(e){case Y:return PA("Suspense");case m:return PA("SuspenseList")}if(typeof e=="object")switch(e.$$typeof){case H:return Pe(e.render);case X:return qA(e.type,g,E);case G:{var p=e,T=p._payload,Z=p._init;try{return qA(Z(T),g,E)}catch{}}}return""}var QA=Object.prototype.hasOwnProperty,ge={},pA=yA.ReactDebugCurrentFrame;function Be(e){if(e){var g=e._owner,E=qA(e.type,e._source,g?g.type:null);pA.setExtraStackFrame(E)}else pA.setExtraStackFrame(null)}function De(e,g,E,p,T){{var Z=Function.call.bind(QA);for(var L in e)if(Z(e,L)){var M=void 0;try{if(typeof e[L]!="function"){var lA=Error((p||"React class")+": "+E+" type `"+L+"` is invalid; it must be a function, usually from the `prop-types` package, but received `"+typeof e[L]+"`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");throw lA.name="Invariant Violation",lA}M=e[L](g,L,p,E,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(iA){M=iA}M&&!(M instanceof Error)&&(Be(T),rA("%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).",p||"React class",E,L,typeof M),Be(null)),M instanceof Error&&!(M.message in ge)&&(ge[M.message]=!0,Be(T),rA("Failed %s type: %s",E,M.message),Be(null))}}}var ze=Array.isArray;function CA(e){return ze(e)}function wA(e){{var g=typeof Symbol=="function"&&Symbol.toStringTag,E=g&&e[Symbol.toStringTag]||e.constructor.name||"Object";return E}}function OA(e){try{return Ae(e),!1}catch{return!0}}function Ae(e){return""+e}function he(e){if(OA(e))return rA("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",wA(e)),Ae(e)}var me=yA.ReactCurrentOwner,FA={key:!0,ref:!0,__self:!0,__source:!0},nA,uA;function Fe(e){if(QA.call(e,"ref")){var g=Object.getOwnPropertyDescriptor(e,"ref").get;if(g&&g.isReactWarning)return!1}return e.ref!==void 0}function ue(e){if(QA.call(e,"key")){var g=Object.getOwnPropertyDescriptor(e,"key").get;if(g&&g.isReactWarning)return!1}return e.key!==void 0}function ee(e,g){typeof e.ref=="string"&&me.current}function fe(e,g){{var E=function(){nA||(nA=!0,rA("%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)",g))};E.isReactWarning=!0,Object.defineProperty(e,"key",{get:E,configurable:!0})}}function KA(e,g){{var E=function(){uA||(uA=!0,rA("%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)",g))};E.isReactWarning=!0,Object.defineProperty(e,"ref",{get:E,configurable:!0})}}var IA=function(e,g,E,p,T,Z,L){var M={$$typeof:s,type:e,key:g,ref:E,props:L,_owner:Z};return M._store={},Object.defineProperty(M._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:!1}),Object.defineProperty(M,"_self",{configurable:!1,enumerable:!1,writable:!1,value:p}),Object.defineProperty(M,"_source",{configurable:!1,enumerable:!1,writable:!1,value:T}),Object.freeze&&(Object.freeze(M.props),Object.freeze(M)),M};function xA(e,g,E,p,T){{var Z,L={},M=null,lA=null;E!==void 0&&(he(E),M=""+E),ue(g)&&(he(g.key),M=""+g.key),Fe(g)&&(lA=g.ref,ee(g,T));for(Z in g)QA.call(g,Z)&&!FA.hasOwnProperty(Z)&&(L[Z]=g[Z]);if(e&&e.defaultProps){var iA=e.defaultProps;for(Z in iA)L[Z]===void 0&&(L[Z]=iA[Z])}if(M||lA){var sA=typeof e=="function"?e.displayName||e.name||"Unknown":e;M&&fe(L,sA),lA&&KA(L,sA)}return IA(e,M,lA,T,p,me.current,L)}}var Re=yA.ReactCurrentOwner,xe=yA.ReactDebugCurrentFrame;function MA(e){if(e){var g=e._owner,E=qA(e.type,e._source,g?g.type:null);xe.setExtraStackFrame(E)}else xe.setExtraStackFrame(null)}var te;te=!1;function Ce(e){return typeof e=="object"&&e!==null&&e.$$typeof===s}function pe(){{if(Re.current){var e=mA(Re.current.type);if(e)return`
6
6
 
7
- Check the render method of \``+e+"`."}return""}}function me(e){return""}var ue={};function ve(e){{var c=ce();if(!c){var A=typeof e=="string"?e:e.displayName||e.name;A&&(c=`
7
+ Check the render method of \``+e+"`."}return""}}function Me(e){return""}var ke={};function qe(e){{var g=pe();if(!g){var E=typeof e=="string"?e:e.displayName||e.name;E&&(g=`
8
8
 
9
- Check the top-level render call using <`+A+">.")}return c}}function ge(e,c){{if(!e._store||e._store.validated||e.key!=null)return;e._store.validated=!0;var A=ve(c);if(ue[A])return;ue[A]=!0;var t="";e&&e._owner&&e._owner!==OA.current&&(t=" It was passed a child from "+iA(e._owner.type)+"."),aA(e),U('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.',A,t),aA(null)}}function Be(e,c){{if(typeof e!="object")return;if(jA(e))for(var A=0;A<e.length;A++){var t=e[A];$A(t)&&ge(t,c)}else if($A(e))e._store&&(e._store.validated=!0);else if(e){var n=j(e);if(typeof n=="function"&&n!==e.entries)for(var o=n.call(e),r;!(r=o.next()).done;)$A(r.value)&&ge(r.value,c)}}}function be(e){{var c=e.type;if(c==null||typeof c=="string")return;var A;if(typeof c=="function")A=c.propTypes;else if(typeof c=="object"&&(c.$$typeof===v||c.$$typeof===F))A=c.propTypes;else return;if(A){var t=iA(c);LA(A,e.props,"prop",t,e)}else if(c.PropTypes!==void 0&&!VA){VA=!0;var n=iA(c);U("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?",n||"Unknown")}typeof c.getDefaultProps=="function"&&!c.getDefaultProps.isReactClassApproved&&U("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.")}}function pe(e){{for(var c=Object.keys(e.props),A=0;A<c.length;A++){var t=c[A];if(t!=="children"&&t!=="key"){aA(e),U("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.",t),aA(null);break}}e.ref!==null&&(aA(e),U("Invalid attribute `ref` supplied to `React.Fragment`."),aA(null))}}var le={};function fe(e,c,A,t,n,o){{var r=JA(e);if(!r){var i="";(e===void 0||typeof e=="object"&&e!==null&&Object.keys(e).length===0)&&(i+=" 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 a=me();a?i+=a:i+=ce();var B;e===null?B="null":jA(e)?B="array":e!==void 0&&e.$$typeof===s?(B="<"+(iA(e.type)||"Unknown")+" />",i=" Did you accidentally export a JSX literal instead of a component?"):B=typeof e,U("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s",B,i)}var f=he(e,c,A,n,o);if(f==null)return f;if(r){var Q=c.children;if(Q!==void 0)if(t)if(jA(Q)){for(var C=0;C<Q.length;C++)Be(Q[C],e);Object.freeze&&Object.freeze(Q)}else U("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");else Be(Q,e)}if(MA.call(c,"key")){var y=iA(e),h=Object.keys(c).filter(function(P){return P!=="key"}),M=h.length>0?"{key: someKey, "+h.join(": ..., ")+": ...}":"{key: someKey}";if(!le[y+M]){var R=h.length>0?"{"+h.join(": ..., ")+": ...}":"{}";U(`A props object containing a "key" prop is being spread into JSX:
9
+ Check the top-level render call using <`+E+">.")}return g}}function Je(e,g){{if(!e._store||e._store.validated||e.key!=null)return;e._store.validated=!0;var E=qe(g);if(ke[E])return;ke[E]=!0;var p="";e&&e._owner&&e._owner!==Re.current&&(p=" It was passed a child from "+mA(e._owner.type)+"."),MA(e),rA('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.',E,p),MA(null)}}function ne(e,g){{if(typeof e!="object")return;if(CA(e))for(var E=0;E<e.length;E++){var p=e[E];Ce(p)&&Je(p,g)}else if(Ce(e))e._store&&(e._store.validated=!0);else if(e){var T=hA(e);if(typeof T=="function"&&T!==e.entries)for(var Z=T.call(e),L;!(L=Z.next()).done;)Ce(L.value)&&Je(L.value,g)}}}function Ge(e){{var g=e.type;if(g==null||typeof g=="string")return;var E;if(typeof g=="function")E=g.propTypes;else if(typeof g=="object"&&(g.$$typeof===H||g.$$typeof===X))E=g.propTypes;else return;if(E){var p=mA(g);De(E,e.props,"prop",p,e)}else if(g.PropTypes!==void 0&&!te){te=!0;var T=mA(g);rA("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?",T||"Unknown")}typeof g.getDefaultProps=="function"&&!g.getDefaultProps.isReactClassApproved&&rA("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.")}}function Ve(e){{for(var g=Object.keys(e.props),E=0;E<g.length;E++){var p=g[E];if(p!=="children"&&p!=="key"){MA(e),rA("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.",p),MA(null);break}}e.ref!==null&&(MA(e),rA("Invalid attribute `ref` supplied to `React.Fragment`."),MA(null))}}var re={};function Le(e,g,E,p,T,Z){{var L=Ue(e);if(!L){var M="";(e===void 0||typeof e=="object"&&e!==null&&Object.keys(e).length===0)&&(M+=" 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 lA=Me();lA?M+=lA:M+=pe();var iA;e===null?iA="null":CA(e)?iA="array":e!==void 0&&e.$$typeof===s?(iA="<"+(mA(e.type)||"Unknown")+" />",M=" Did you accidentally export a JSX literal instead of a component?"):iA=typeof e,rA("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s",iA,M)}var sA=xA(e,g,E,T,Z);if(sA==null)return sA;if(L){var RA=g.children;if(RA!==void 0)if(p)if(CA(RA)){for(var ie=0;ie<RA.length;ie++)ne(RA[ie],e);Object.freeze&&Object.freeze(RA)}else rA("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 ne(RA,e)}if(QA.call(g,"key")){var VA=mA(e),EA=Object.keys(g).filter(function(_e){return _e!=="key"}),Se=EA.length>0?"{key: someKey, "+EA.join(": ..., ")+": ...}":"{key: someKey}";if(!re[VA+Se]){var Ze=EA.length>0?"{"+EA.join(": ..., ")+": ...}":"{}";rA(`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} />`,M,y,R,y),le[y+M]=!0}}return e===g?pe(f):be(f),f}}function Fe(e,c,A){return fe(e,c,A,!0)}function ye(e,c,A){return fe(e,c,A,!1)}var hA=ye,Ne=Fe;ee.Fragment=g,ee.jsx=hA,ee.jsxs=Ne})()),ee}var xe;function Xe(){return xe||(xe=1,process.env.NODE_ENV==="production"?de.exports=Le():de.exports=je()),de.exports}var E=Xe();const ke=({action:u,row:s})=>E.jsx("div",{className:"effect0","data-action-id":u.id,"data-row-id":s.id,children:E.jsx("div",{className:"effect0-text",children:`Audio: ${u.data.name}`})}),Je=({action:u,row:s})=>E.jsx("div",{className:"effect1","data-action-id":u.id,"data-row-id":s.id,children:E.jsx("div",{className:"effect1-text",children:`Video: ${u.data.name}`})}),qe=({action:u,row:s})=>E.jsx("div",{className:"effect2","data-action-id":u.id,"data-row-id":s.id,children:E.jsx("div",{className:"effect2-text",children:`Video audio: ${u.data.name}`})}),We=u=>{const s=u.toLowerCase();return s.endsWith(".mp4")||s.endsWith(".webm")||s.endsWith(".mov")||s.endsWith(".m4v")?"video":s.endsWith(".mp3")||s.endsWith(".wav")||s.endsWith(".ogg")||s.endsWith(".m4a")||s.endsWith(".aac")?"audio":"other"};class Ke{blobUrlBySrc=new Map;pendingBySrc=new Map;async preloadToBlobUrl(s){if(!s)return s;const l=this.blobUrlBySrc.get(s);if(l)return l;const g=this.pendingBySrc.get(s);if(g)return g;const d=(async()=>{const I=await fetch(s,{cache:"force-cache"});if(!I.ok)throw new Error(`Failed to fetch ${s}: ${I.status}`);const m=await I.blob(),b=URL.createObjectURL(m);return this.blobUrlBySrc.set(s,b),b})().catch(I=>(console.warn("[mediaCache] preload failed:",s,I),s)).finally(()=>{this.pendingBySrc.delete(s)});return this.pendingBySrc.set(s,d),d}resolve(s){return this.blobUrlBySrc.get(s)??s}warm(s){this.preloadToBlobUrl(s)}warmFromEditorData(s){const l=new Set,g=Array.isArray(s)?s:[];for(const d of g){const I=d?.actions;if(Array.isArray(I))for(const m of I){const b=m?.data?.src;typeof b=="string"&&b&&l.add(b)}}for(const d of l){const I=We(d);(I==="video"||I==="audio")&&this.warm(d)}}}const re=new Ke,ze=u=>{if(!u)return;const l=u.split("#")[0].split("?")[0].toLowerCase(),g=l.lastIndexOf(".");if(g<0)return;const d=l.slice(g+1);if(d)return d==="m4a"||d==="m4v"?"mp4":d};class Ve{howlBySrc={};activeByActionId={};getHowl(s){const l=re.resolve(s),g=l.startsWith("blob:")?s:l,d=g;if(this.howlBySrc[d])return this.howlBySrc[d];const I=ze(s),m=new Oe.Howl({src:[g],format:I?[I]:void 0,loop:!0,autoplay:!1,preload:!0});return this.howlBySrc[d]=m,m}unlock(){try{const s=Oe.Howler.ctx;s&&s.state==="suspended"&&s.resume()}catch{}}warm(s){s&&(re.warm(s),this.getHowl(s))}seekForEngineTime(s,l,g,d,I){const m=Number(I),b=Number.isFinite(m)?m:0,v=s.duration();if(!Number.isFinite(v)||v<=0){s.seek(Math.max(0,d-g+b),l);return}const p=(d-g+b)%v,N=p<0?p+v:p;s.seek(N,l)}start(s){const{actionId:l,src:g,startTime:d,time:I,engine:m}=s,b=Number(s.offset??0),v=Number.isFinite(b)?b:0,p=this.activeByActionId[l];if(p){const K=this.getHowl(p.src);K.rate(m.getPlayRate(),p.soundId);try{K.playing(p.soundId)||K.play(p.soundId)}catch{}m.isPlaying||this.seekForEngineTime(K,p.soundId,p.startTime,I,p.offset);return}const N=this.getHowl(g),F=N.play();N.rate(m.getPlayRate(),F),this.seekForEngineTime(N,F,d,I,v);let q=performance.now();const W=({time:K})=>{if(!m.isPlaying){this.seekForEngineTime(N,F,d,K,v);return}const j=performance.now();if(!(j-q<500)){q=j;try{const V=Math.max(0,K-d+v),U=Number(N.seek(F));Number.isFinite(U)&&Math.abs(U-V)>.25&&this.seekForEngineTime(N,F,d,K,v)}catch{}}},uA=({rate:K})=>{N.rate(K,F)};m.on("afterSetTime",W),m.on("afterSetPlayRate",uA),this.activeByActionId[l]={src:g,startTime:d,offset:v,soundId:F,engine:m,lastResyncAtMs:q,time:W,rate:uA}}stop(s){const{actionId:l}=s,g=this.activeByActionId[l];if(!g)return;const d=this.getHowl(g.src);try{d.stop(g.soundId)}catch{}g.time&&g.engine.off("afterSetTime",g.time),g.rate&&g.engine.off("afterSetPlayRate",g.rate),delete this.activeByActionId[l]}}const nA=new Ve;class Ze{videoEl=null;currentSrc=null;lastSeekAtMs=0;lastRate=null;boundEngine=null;boundActionStart=0;vfcHandle=null;rafHandle=null;attach(s){this.videoEl=s,this.currentSrc=s?.currentSrc||s?.getAttribute("src")||null,this.lastSeekAtMs=0,this.lastRate=null,this.unbindEngine(),this.setActive(!1)}setActive(s){this.videoEl&&(this.videoEl.style.opacity=s?"1":"0")}bindEngine(s,l){this.unbindEngine(),this.boundEngine=s,this.boundActionStart=l,this.tickFromVideo()}unbindEngine(){const s=this.videoEl;if(this.vfcHandle!=null&&s?.cancelVideoFrameCallback)try{s.cancelVideoFrameCallback(this.vfcHandle)}catch{}this.rafHandle!=null&&cancelAnimationFrame(this.rafHandle),this.vfcHandle=null,this.rafHandle=null,this.boundEngine=null}tickFromVideo=()=>{if(!this.videoEl||!this.boundEngine||this.videoEl.paused)return;const s=this.boundActionStart+this.videoEl.currentTime;Math.abs(this.boundEngine.getTime()-s)>.03&&this.boundEngine.setTime(s,!0);const l=this.videoEl;l?.requestVideoFrameCallback?this.vfcHandle=l.requestVideoFrameCallback(()=>this.tickFromVideo()):this.rafHandle=requestAnimationFrame(()=>this.tickFromVideo())};setSource(s){if(!this.videoEl||!s)return;const l=re.resolve(s);if(!((this.videoEl.currentSrc||this.videoEl.getAttribute("src")||"")===l||this.currentSrc===l)){this.currentSrc=l,this.videoEl.preload="auto",this.videoEl.src=l;try{this.videoEl.load()}catch{}}}warm(s){s&&re.warm(s)}setRate(s){this.videoEl&&this.lastRate!==s&&(this.lastRate=s,this.videoEl.playbackRate=s)}seek(s,l){if(this.videoEl)try{const g=performance.now(),d=l?.force===!0,I=this.videoEl.currentTime;if(!d&&!this.videoEl.paused&&(Math.abs(I-s)<.12||g-this.lastSeekAtMs<150))return;const m=this.videoEl.duration;Number.isFinite(m)&&m>0?this.videoEl.currentTime=Math.min(s,Math.max(0,m-.05)):this.videoEl.currentTime=Math.max(0,s),this.lastSeekAtMs=g}catch{}}async play(){if(this.videoEl)try{await this.videoEl.play(),this.boundEngine&&this.tickFromVideo()}catch{}}pause(){this.videoEl&&this.videoEl.pause()}}const Y=new Ze,te=160,ne=5,Ee=20,_e={effect0:{id:"effect0",name:"Play audio",source:{start:({action:u,engine:s,isPlaying:l,time:g})=>{if(l){const{src:d,offset:I}=u.data;nA.warm(d),nA.start({actionId:u.id,src:d,startTime:u.start,engine:s,time:g,offset:I})}},enter:({action:u,engine:s,isPlaying:l,time:g})=>{if(l){const{src:d,offset:I}=u.data;nA.warm(d),nA.start({actionId:u.id,src:d,startTime:u.start,engine:s,time:g,offset:I})}},leave:({action:u})=>{nA.stop({actionId:u.id})},stop:({action:u})=>{nA.stop({actionId:u.id})}}},effect2:{id:"effect2",name:"Play video audio",source:{start:({action:u,engine:s,isPlaying:l,time:g})=>{if(l){const{src:d,offset:I}=u.data;nA.warm(d),nA.start({actionId:u.id,src:d,startTime:u.start,engine:s,time:g,offset:I})}},enter:({action:u,engine:s,isPlaying:l,time:g})=>{if(l){const{src:d,offset:I}=u.data;nA.warm(d),nA.start({actionId:u.id,src:d,startTime:u.start,engine:s,time:g,offset:I})}},leave:({action:u})=>{nA.stop({actionId:u.id})},stop:({action:u})=>{nA.stop({actionId:u.id})}}},effect1:{id:"effect1",name:"Play video",source:{start:({action:u,engine:s,isPlaying:l,time:g})=>{const{src:d,previewSrc:I,offset:m}=u.data??{},b=I||d;b&&(Y.warm(b),Y.setSource(b)),Y.setActive(!0),Y.setRate(s.getPlayRate());const v=Number(m??0);Y.seek(Math.max(0,g-u.start+(Number.isFinite(v)?v:0)),{force:!0}),l&&Y.play()},enter:({action:u,engine:s,isPlaying:l,time:g})=>{const{src:d,previewSrc:I,offset:m}=u.data??{},b=I||d;b&&(Y.warm(b),Y.setSource(b)),Y.setActive(!0),Y.setRate(s.getPlayRate());const v=Number(m??0);Y.seek(Math.max(0,g-u.start+(Number.isFinite(v)?v:0)),{force:!0}),l&&Y.play()},update:({action:u,engine:s,time:l,isPlaying:g})=>{const{src:d,previewSrc:I,offset:m}=u.data??{},b=I||d;if(b&&Y.setSource(b),Y.setActive(!0),Y.setRate(s.getPlayRate()),!g){const v=Number(m??0);Y.seek(Math.max(0,l-u.start+(Number.isFinite(v)?v:0)),{force:!0})}},leave:()=>{Y.pause(),Y.unbindEngine(),Y.setActive(!1)},stop:()=>{Y.pause(),Y.unbindEngine(),Y.setActive(!1)}}}},$e=[{id:"0",actions:[{id:"action0",start:0,end:10,effectId:"effect1",data:{src:"/footage/Big_Buck_Bunny_720_10s_5MB.mp4",name:"Big Buck Bunny (10s)"}}]},{id:"1",actions:[]},{id:"2",actions:[{id:"action1",start:0,end:10,effectId:"effect0",data:{src:"/footage/file_example_MP3_700KB.mp3",name:"Example MP3 (looped)"}}]},{id:"3",actions:[]}],At="",et="",tt="",nt="",rt="",it="",{Option:ot}=He.Select,st=[.2,.5,1,1.5,2],at=({timelineState:u,autoScrollWhenPlay:s,editorData:l,selectedActionId:g,onDeleteSelectedClip:d,onSplitSelectedClip:I,canUndo:m,canRedo:b,onUndo:v,onRedo:p})=>{const[N,F]=D.useState(!1),[q,W]=D.useState(0),[uA,K]=D.useState(!1),j=D.useRef(0),V=D.useRef(0),U=D.useRef(0),gA=D.useRef(0),CA=D.useRef(0),rA=D.useRef(0),BA=!!g,FA=(()=>{if(!g)return null;const w=Array.isArray(l)?l:[];for(const S of w){const x=S?.actions;if(Array.isArray(x))for(const H of x){if(String(H?.id)!==g)continue;const O=Number(H?.start),G=Number(H?.end);return!Number.isFinite(O)||!Number.isFinite(G)?null:{start:O,end:G}}}return null})(),yA=!!(FA&&q>FA.start&&q<FA.end),JA=w=>{const S=Array.isArray(l)?l:[];for(const x of S){const H=x?.actions;if(Array.isArray(H))for(const O of H){if(O?.effectId!=="effect1")continue;const G=Number(O?.start),k=Number(O?.end);if(!(!Number.isFinite(G)||!Number.isFinite(k))&&w>=G&&w<k)return!0}}return!1},qA=w=>{JA(w)||(Y.pause(),Y.unbindEngine(),Y.setActive(!1))};D.useEffect(()=>{if(!u.current)return;const w=u.current,S=()=>F(!0),x=()=>F(!1),H=({time:G})=>{W(G),qA(G)},O=({time:G})=>{const k=performance.now();if(!(k-j.current<33)&&(j.current=k,W(G),qA(G),s.current)){const lA=G*(te/ne)+Ee-500,sA=u.current;sA&&sA.setScrollLeft(lA)}};return w.listener.on("play",S),w.listener.on("paused",x),w.listener.on("afterSetTime",H),w.listener.on("setTimeByTick",O),()=>{w.listener.off("play",S),w.listener.off("paused",x),w.listener.off("afterSetTime",H),w.listener.off("setTimeByTick",O)}},[l]);const xA=()=>{u.current&&(u.current.isPlaying?u.current.pause():(nA.unlock(),u.current.play({autoEnd:!0})))},iA=w=>{u.current&&u.current.setPlayRate(w)},oA=w=>{const S=(parseInt(w%1*100+"")+"").padStart(2,"0"),x=(parseInt(w/60+"")+"").padStart(2,"0"),H=(parseInt(w%60+"")+"").padStart(2,"0");return E.jsx(E.Fragment,{children:`${x}:${H}.${S.replace("0.","")}`})},AA=()=>{const w=[],S=new Set,x=Array.isArray(l)?l:[];for(const H of x){const O=H?.actions;if(Array.isArray(O))for(const G of O){const k=G?.data?.src;if(!k)continue;const IA=String(k);S.has(IA)||(S.add(IA),w.push(IA))}}return w},UA=(w,S)=>{const x=URL.createObjectURL(w),H=document.createElement("a");H.href=x,H.download=S,document.body.appendChild(H),H.click(),H.remove(),setTimeout(()=>URL.revokeObjectURL(x),3e3)},wA=async()=>{if(!uA){K(!0);try{const w=AA(),S=new FormData;S.append("timeline",JSON.stringify({editorData:l}));for(const O of w){const G=await fetch(O);if(!G.ok)throw new Error(`Failed to fetch asset: ${O} (${G.status})`);const k=await G.blob();S.append("assets",k,encodeURIComponent(O))}const x=await fetch("/export",{method:"POST",body:S});if(!x.ok){const O=await x.text().catch(()=>"");throw new Error(O||`Export failed (${x.status})`)}const H=await x.blob();UA(H,"export.mp4")}finally{K(!1)}}};return E.jsxs("div",{className:"timeline-player",children:[E.jsx("div",{className:"play-control",role:"button",tabIndex:0,"aria-label":N?"Pause":"Play",onClick:()=>{Date.now()-V.current<450||xA()},onPointerUp:w=>{w.pointerType!=="mouse"&&(V.current=Date.now(),xA())},children:E.jsx("img",{src:N?et:At,alt:"",draggable:!1})}),E.jsx("div",{className:"time",children:oA(q)}),E.jsxs("div",{className:"history-tools",children:[E.jsx("button",{type:"button",className:"history-tool",disabled:!m,"aria-label":"Undo",onClick:()=>{Date.now()-CA.current<450||m&&v()},onPointerUp:w=>{w.pointerType!=="mouse"&&(CA.current=Date.now(),m&&v())},children:E.jsx("img",{src:tt,alt:"",draggable:!1})}),E.jsx("button",{type:"button",className:"history-tool",disabled:!b,"aria-label":"Redo",onClick:()=>{Date.now()-rA.current<450||b&&p()},onPointerUp:w=>{w.pointerType!=="mouse"&&(rA.current=Date.now(),b&&p())},children:E.jsx("img",{src:nt,alt:"",draggable:!1})})]}),E.jsx("div",{className:"rate-control",children:E.jsx(He.Select,{size:"small",defaultValue:1,style:{width:120},onChange:iA,children:st.map(w=>E.jsx(ot,{value:w,children:`${w.toFixed(1)}x`},w))})}),E.jsxs("div",{className:"clip-tools",children:[E.jsx("button",{type:"button",className:"clip-tool clip-tool-delete",disabled:!BA,"aria-label":"Delete selected clip",onClick:()=>{Date.now()-U.current<450||BA&&d()},onPointerUp:w=>{w.pointerType!=="mouse"&&(U.current=Date.now(),BA&&d())},children:E.jsx("img",{src:rt,alt:"",draggable:!1})}),E.jsx("button",{type:"button",className:"clip-tool clip-tool-split",disabled:!yA,"aria-label":"Split selected clip at cursor",onClick:()=>{Date.now()-gA.current<450||yA&&I()},onPointerUp:w=>{w.pointerType!=="mouse"&&(gA.current=Date.now(),yA&&I())},children:E.jsx("img",{src:it,alt:"",draggable:!1})})]}),E.jsx("div",{className:"export-control",children:E.jsx(He.Button,{size:"small",type:"primary",loading:uA,onClick:wA,children:"Export"})})]})};function ct(){const u=()=>typeof window>"u"?!1:typeof navigator<"u"&&(navigator.maxTouchPoints??0)>0,[s,l]=D.useState(u);return D.useEffect(()=>{if(typeof window>"u"||typeof window.matchMedia!="function")return;const g=window.matchMedia("(pointer: coarse)"),d=()=>l(!!g.matches||u());return d(),typeof g.addEventListener=="function"?(g.addEventListener("change",d),()=>g.removeEventListener("change",d)):(g.addListener(d),()=>g.removeListener(d))},[]),s}const ut=structuredClone($e),Qe=5,Ue=({item:u,hint:s,isDragging:l})=>E.jsxs("div",{className:`footage-card${l?" is-dragging":""}`,children:[E.jsx("div",{className:"footage-name",children:u.name}),u.kind==="video"?E.jsx("video",{className:"footage-preview",src:u.src,muted:!0,preload:"metadata",draggable:!1,onDragStart:g=>g.preventDefault(),playsInline:!0}):E.jsx("audio",{className:"footage-audio",src:u.src,controls:!0,preload:"metadata",draggable:!1,onDragStart:g=>g.preventDefault()}),E.jsx("div",{className:"footage-kind",children:s})]}),gt=({item:u,hint:s})=>{const{attributes:l,listeners:g,setNodeRef:d,transform:I,isDragging:m}=EA.useDraggable({id:`footage-${u.id}`,data:{item:u}}),b=I?{transform:`translate3d(${I.x}px, ${I.y}px, 0)`}:void 0;return E.jsx("div",{ref:d,style:b,...g,...l,children:E.jsx(Ue,{item:u,hint:s,isDragging:m})})},Bt=u=>String(u??"").toLowerCase().match(/\.(mp3|wav|m4a|aac|ogg)(\?|#|$)/)?"audio":"video",lt=(u,s)=>{try{const l=String(u??"").split("/").pop()||"";return decodeURIComponent(l.split("?")[0].split("#")[0])||`Footage ${s+1}`}catch{return`Footage ${s+1}`}},ft=({footageUrls:u})=>{const[s,l]=D.useState(ut),[g,d]=D.useState(null),[I,m]=D.useState([]),[b,v]=D.useState([]),p=D.useRef(s),N=ct(),F=D.useRef(null),q=D.useRef(null),W=D.useRef(null),uA=D.useRef(!0),K=D.useMemo(()=>{const A=Array.isArray(u)?u.filter(Boolean):[];return A.length?A.map((t,n)=>({id:`url-${n}`,kind:Bt(t),name:lt(t,n),src:t,defaultDuration:10})):[]},[u]),[j,V]=D.useState(null),[U,gA]=D.useState(null),[CA,rA]=D.useState(null),[BA,ie]=D.useState(0),[FA,yA]=D.useState(0),[JA,qA]=D.useState(0),[xA,iA]=D.useState(0),[oA,AA]=D.useState(!1),[UA,wA]=D.useState(null),w=D.useRef(null),S=D.useRef(null),x=D.useRef(null),H=D.useRef(null),O=N?48:32,G=[0,1],k=[2,3],IA=["V1","V2","A1","A2"],lA=(A,t)=>{if(t.length===0)return null;if(A==null)return t[0];let n=t[0],o=Math.abs(A-n);for(const r of t){const i=Math.abs(A-r);i<o&&(n=r,o=i)}return n},sA=(A,t)=>A?A.kind==="video"?lA(t,G):lA(t,k):null,NA=A=>A===G[1]?k[1]:k[0];D.useEffect(()=>{re.warmFromEditorData(s)},[s]),D.useEffect(()=>{p.current=s},[s]),D.useLayoutEffect(()=>{const A=W.current;if(!A)return;const t=()=>{const o=A.getBoundingClientRect(),r=A.querySelector(".timeline-editor-edit-area");if(!r)return;const i=r.getBoundingClientRect();qA(i.top-o.top),iA(i.left-o.left)},n=requestAnimationFrame(t);return window.addEventListener("resize",t),()=>{cancelAnimationFrame(n),window.removeEventListener("resize",t)}},[N,s.length]);const GA=A=>{const t=W.current;if(!t||!A)return!1;const n=t.getBoundingClientRect();return A.x>=n.left&&A.x<=n.right&&A.y>=n.top&&A.y<=n.bottom},WA=D.useRef(0),fA=()=>globalThis.crypto?.randomUUID?globalThis.crypto.randomUUID():`uid-${++WA.current}`,z=D.useRef(null),eA=D.useRef(null),YA=D.useRef(null),TA=.9,MA=1.05,Z=D.useRef({actionId:null,edge:null}),X=D.useRef({actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,initialStart:0,initialEnd:0,takeover:!1}),PA=D.useRef(!1),LA=A=>A.map(t=>{const n=(t.actions??[]).map(o=>`${String(o.id)}@${Number(o.start)}-${Number(o.end)}`).join("|");return`${String(t.id)}:${n}`}).join("||"),HA=A=>{const t=structuredClone(A);m(n=>{const o=[...n,t];return o.length>Qe&&o.splice(0,o.length-Qe),o}),v([])},jA=(A,t,n,o)=>A<o&&t>n,dA=(A,t,n,o)=>{const r=Array.isArray(A?.actions)?A.actions:[];for(const i of r)if(!(!i||i.id===t)&&jA(n,o,Number(i.start),Number(i.end)))return!0;return!1},KA=(A,t)=>{for(let n=0;n<A.length;n++){const o=A[n],r=Array.isArray(o?.actions)?o.actions:[];for(let i=0;i<r.length;i++){const a=r[i];if(String(a?.id)===t)return{rowIndex:n,actionIndex:i,action:a}}}return null},DA=(A,t)=>{const n=KA(A,t),o=n?.action?.data?.linkId;if(!n||!o)return null;for(let r=0;r<A.length;r++){const i=A[r],a=Array.isArray(i?.actions)?i.actions:[];for(let B=0;B<a.length;B++){const f=a[B];if(f?.data?.linkId&&String(f.data.linkId)===String(o)&&String(f.id)!==String(t))return{rowIndex:r,actionIndex:B,action:f}}}return null},oe=(A,t)=>{const n=KA(A,t);if(!n)return A;const o=DA(A,t);if(!o)return A;const r=Number(n.action.start),i=Number(n.action.end);if(!Number.isFinite(r)||!Number.isFinite(i)||i<=r||Number(o.action.start)===r&&Number(o.action.end)===i)return A;const a=structuredClone(A),B=a[o.rowIndex],f=Array.isArray(B.actions)?[...B.actions]:[],Q={...f[o.actionIndex],start:r,end:i};return f.splice(o.actionIndex,1,Q),B.actions=f,a},XA=(A,t,n,o)=>{if(!Number.isFinite(n)||!Number.isFinite(o)||o<=n)return A;const r=KA(A,t);if(!r)return A;const i=DA(A,t);if(!i)return A;const a=structuredClone(A),B=a[r.rowIndex],f=Array.isArray(B.actions)?[...B.actions]:[],Q={...f[r.actionIndex],start:n,end:o};f.splice(r.actionIndex,1,Q),B.actions=f;const C=a[i.rowIndex],y=Array.isArray(C.actions)?[...C.actions]:[],h={...y[i.actionIndex],start:n,end:o};return y.splice(i.actionIndex,1,h),C.actions=y,a},zA=(A,t,n,o)=>{if(!Number.isFinite(n)||!Number.isFinite(o)||o<=n)return A;const r=KA(A,t);if(!r)return A;const i=Number(r.action.start),a=Number(r.action.end);if(i===n&&a===o)return A;const B=structuredClone(A),f=B[r.rowIndex],Q=Array.isArray(f.actions)?[...f.actions]:[],C={...Q[r.actionIndex],start:n,end:o};return Q.splice(r.actionIndex,1,C),f.actions=Q,B},ZA=()=>{const A=F.current?.getTime?Number(F.current.getTime()):0;return Number.isFinite(A)?Math.max(0,A):0},_A=(A,t,n)=>{const o=ZA(),r=n-t;if(!Number.isFinite(r)||r<=0)return{start:t,end:n,snapped:!1,edge:null};const i=Math.abs(t-o),a=Math.abs(n-o),B=i<=a?"start":"end",f=Math.min(i,a),Q=Z.current;if(Q.actionId===A&&Q.edge!=null){if((Q.edge==="start"?i:a)>MA)return Z.current={actionId:A,edge:null},{start:t,end:n,snapped:!1,edge:null}}else{if(f>TA)return{start:t,end:n,snapped:!1,edge:null};Z.current={actionId:A,edge:B}}const h=Z.current.edge;if(h==="start"){const P=o,T=P+r;return{start:Math.max(0,P),end:Math.max(Math.max(0,P),T),snapped:!0,edge:h}}const M=o,R=M-r;return{start:Math.max(0,R),end:Math.max(0,M),snapped:!0,edge:h}},se=(A,t,n,o)=>{const r=ZA(),i=o==="left"?"start":"end",a=Math.abs(i==="start"?t-r:n-r),B=Z.current;if(B.actionId===A&&B.edge===i){if(a>MA)return Z.current={actionId:A,edge:null},{start:t,end:n,snapped:!1}}else{if(a>TA)return{start:t,end:n,snapped:!1};Z.current={actionId:A,edge:i}}if(i==="start"){const h=Math.max(0,r),M=Math.max(h+.01,n);return{start:h,end:M,snapped:!0}}const C=Math.max(0,r),y=Math.min(t,C-.01);return{start:Math.max(0,y),end:C,snapped:!0}},Ce=(A,t,n)=>{const o=A.defaultDuration??10;let r=Math.max(0,t),i=r+o;const a=F.current;a?.isPlaying&&a.pause(),l(B=>{HA(B);const f=structuredClone(B);for(;f.length<4;)f.push({id:`${f.length}`,actions:[]});const Q=Number.isFinite(Number(n))?Number(n):null,C=lA(Q,G)??G[0],y=lA(Q,k)??k[0],h=M=>{const R=[];for(const P of M){const T=Array.isArray(f[P]?.actions)?f[P].actions:[];for(const _ of T){const QA=Number(_?.start),mA=Number(_?.end);!Number.isFinite(QA)||!Number.isFinite(mA)||R.push({start:QA,end:mA})}}R.sort((P,T)=>P.start-T.start);for(const P of R)jA(r,i,P.start,P.end)&&(r=P.end,i=r+o)};if(A.kind==="video"){const M=C,R=NA(M);h([M,R]);const P=`link-${fA()}`,T=`video-${fA()}`,_=`video-audio-${fA()}`;f[M].actions=[...f[M].actions??[],{id:T,start:r,end:i,effectId:"effect1",data:{src:A.src,previewSrc:A.previewSrc,name:A.name,linkId:P}}],f[R].actions=[...f[R].actions??[],{id:_,start:r,end:i,effectId:"effect2",data:{src:A.src,name:A.name,linkId:P}}]}else{const M=y;h([M]),f[M].actions=[...f[M].actions??[],{id:`audio-${fA()}`,start:r,end:i,effectId:"effect0",data:{src:A.src,name:A.name}}]}return f})},we=()=>{const A=W.current;return A?A.querySelector(".timeline-editor-edit-area .ReactVirtualized__Grid")?.scrollLeft??0:0},Ie=()=>BA,kA=A=>{const t=W.current;if(!t)return 0;const o=(t.querySelector(".timeline-editor-edit-area")??t).getBoundingClientRect(),a=(A-o.x+we()-Ee)*ne/te;return Math.max(0,a)},De=A=>{const t=Number(A);return Number.isFinite(t)?Ee+t*te/ne:0},he=(A,t,n,o)=>{const r=A.defaultDuration??10;let i=Math.max(0,t),a=i+r;const B=[];if(A.kind==="video"){const Q=n,C=NA(Q);B.push(Q,C)}else B.push(n);const f=[];for(const Q of B){const C=Array.isArray(o[Q]?.actions)?o[Q].actions:[];for(const y of C){const h=Number(y?.start),M=Number(y?.end);!Number.isFinite(h)||!Number.isFinite(M)||f.push({start:h,end:M})}}f.sort((Q,C)=>Q.start-C.start);for(const Q of f)jA(i,a,Q.start,Q.end)&&(i=Q.end,a=i+r);return Math.max(0,i)},OA=A=>{const t=W.current;if(!t)return null;const n=t.querySelector(".timeline-editor-edit-area");if(!n)return null;const o=n.getBoundingClientRect(),r=A-o.y;if(r<0||r>o.height)return null;const i=r+Ie(),a=Math.floor(i/O);if(!Number.isFinite(a))return null;const B=Math.max(0,p.current.length-1);return Math.min(Math.max(0,a),B)},ae=A=>{if(!A)return null;if("clientX"in A&&"clientY"in A){const r=Number(A.clientX),i=Number(A.clientY);if(Number.isFinite(r)&&Number.isFinite(i))return{x:r,y:i}}const t=A.touches,n=A.changedTouches,o=(t&&t.length?t[0]:null)||(n&&n.length?n[0]:null);if(o){const r=Number(o.clientX),i=Number(o.clientY);if(Number.isFinite(r)&&Number.isFinite(i))return{x:r,y:i}}return null},aA=()=>{if(PA.current)return;PA.current=!0;const A=n=>{const o=X.current;if(!o.actionId||!o.mode||n.isPrimary===!1)return;const r=kA(n.clientX);o.basePointerTime==null&&(o.basePointerTime=r),o.lastPointerTime=r},t=()=>{X.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,initialStart:0,initialEnd:0,takeover:!1},Z.current={actionId:null,edge:null}};window.addEventListener("pointermove",A,{capture:!0}),window.addEventListener("pointerup",t,{capture:!0}),window.addEventListener("pointercancel",t,{capture:!0}),X.current._removePointerListeners=()=>{window.removeEventListener("pointermove",A,{capture:!0}),window.removeEventListener("pointerup",t,{capture:!0}),window.removeEventListener("pointercancel",t,{capture:!0}),PA.current=!1}},VA=()=>{const A=X.current?._removePointerListeners;A?.(),delete X.current._removePointerListeners},$A=A=>A.map(t=>({...t,selected:void 0,actions:(t.actions??[]).map(n=>({...n,selected:void 0}))})),ce=D.useMemo(()=>s.map((A,t)=>{const n=g?(A.actions??[]).some(a=>String(a.id)===g):!1,o=j!=null&&CA!=null&&t===CA,r=Array.isArray(A.classNames)?A.classNames:[],i=o?[...r,"dnd-drop-hover"]:r;return{...A,classNames:i,selected:n,actions:(A.actions??[]).map(a=>({...a,selected:g?String(a.id)===g:!1}))}}),[s,g,j,CA]),me=()=>{if(!g)return;const A=F.current;A?.isPlaying&&A.pause(),l(t=>{HA(t);let n=null;for(const r of t){const i=Array.isArray(r?.actions)?r.actions:[];for(const a of i){if(String(a?.id)!==g)continue;const B=a?.data?.linkId;B!=null&&(n=String(B));break}if(n!=null)break}return t.map(r=>({...r,actions:(r.actions??[]).filter(i=>!(String(i?.id)===g||n&&String(i?.data?.linkId??"")===n))}))}),d(null)},ue=()=>{if(!g)return;const A=F.current,t=A?.getTime?A.getTime():null;if(t==null)return;const n=Number(t);Number.isFinite(n)&&(A?.isPlaying&&A.pause(),z.current=null,eA.current=null,l(o=>{let r=-1,i=-1,a=null;for(let L=0;L<o.length;L++){const J=o[L],tA=Array.isArray(J?.actions)?J.actions:[];for(let $=0;$<tA.length;$++){const SA=tA[$];if(String(SA?.id)===g){r=L,i=$,a=SA;break}}if(a)break}if(!a)return o;const B=a?.data?.linkId?String(a.data.linkId):null;let f=-1,Q=-1,C=null;if(B)for(let L=0;L<o.length;L++){const J=o[L],tA=Array.isArray(J?.actions)?J.actions:[];for(let $=0;$<tA.length;$++){const SA=tA[$];if(String(SA?.id)!==g&&String(SA?.data?.linkId??"")===B){f=L,Q=$,C=SA;break}}if(C)break}const y=Number(a.start),h=Number(a.end);if(!Number.isFinite(y)||!Number.isFinite(h)||!(y<n&&n<h))return o;HA(o);const M=B&&C?`link-${fA()}`:B,R=B&&C?`link-${fA()}`:B,P=`${String(a.id)}-r-${fA()}`,T=Number(a?.data?.offset??0),_=Number.isFinite(T)?T:0,QA=n-y,mA=_+(Number.isFinite(QA)?QA:0),RA={...a,start:y,end:n,id:a.id,data:{...a.data,offset:_,linkId:M??void 0}},vA={...a,start:n,end:h,id:P,data:{...a.data,offset:mA,linkId:R??void 0}},bA=structuredClone(o),cA=bA[r],pA=Array.isArray(cA.actions)?[...cA.actions]:[];if(pA.splice(i,1,RA,vA),pA.sort((L,J)=>Number(L.start)-Number(J.start)),cA.actions=pA,C&&f>=0&&Q>=0){const L=Number(C.start),J=Number(C.end);if(Number.isFinite(L)&&Number.isFinite(J)&&L===y&&J===h){const tA=`${String(C.id)}-r-${fA()}`,$={...C,start:y,end:n,id:C.id,data:{...C.data,linkId:M??void 0}},SA={...C,start:n,end:h,id:tA,data:{...C.data,linkId:R??void 0}},Me=bA[f],Pe=Array.isArray(Me.actions)?[...Me.actions]:[];Pe.splice(Q,1,$,SA),Pe.sort((Ge,Ye)=>Number(Ge.start)-Number(Ye.start)),Me.actions=Pe}}return bA}))},ve=()=>{const A=F.current,t=A?.getTime?A.getTime():null;A?.isPlaying&&A.pause(),z.current=null,eA.current=null,d(null),m(n=>{if(n.length===0)return n;const o=n[n.length-1],r=structuredClone(p.current);return v(i=>[...i,r]),l(structuredClone(o)),n.slice(0,-1)}),t!=null&&requestAnimationFrame(()=>{const n=F.current;n?.setTime&&n.setTime(t)})},ge=()=>{const A=F.current,t=A?.getTime?A.getTime():null;A?.isPlaying&&A.pause(),z.current=null,eA.current=null,d(null),v(n=>{if(n.length===0)return n;const o=n[n.length-1],r=structuredClone(p.current);return m(i=>{const a=[...i,r];return a.length>Qe&&a.splice(0,a.length-Qe),a}),l(structuredClone(o)),n.slice(0,-1)}),t!=null&&requestAnimationFrame(()=>{const n=F.current;n?.setTime&&n.setTime(t)})},Be=EA.useSensors(EA.useSensor(EA.PointerSensor,{activationConstraint:{distance:6}}),EA.useSensor(EA.TouchSensor,{activationConstraint:{delay:180,tolerance:6}})),{setNodeRef:be,isOver:pe}=EA.useDroppable({id:"timeline-drop"}),le=A=>{const t=A.active.data.current?.item;V(t??null);const n=ae(A.activatorEvent);if(w.current=n,S.current=n,wA(n),n){const r=GA(n);AA(r);const i=OA(n.y);rA(r?sA(t??null,i):null)}else rA(null),AA(!1);const o=A.active.rect.current.initial;gA(o?{width:o.width,height:o.height}:null)},fe=A=>{const t=A.active.rect.current.initial;!U&&t&&gA({width:t.width,height:t.height});const n=S.current;if(!n){rA(null);return}const o=Number(A?.delta?.x??0),r=Number(A?.delta?.y??0),i={x:n.x+(Number.isFinite(o)?o:0),y:n.y+(Number.isFinite(r)?r:0)};w.current=i,wA(i);const a=GA(i);AA(a);const B=OA(i.y);rA(a?sA(j,B):null)},Fe=A=>{const t=A.active.data.current?.item,n=S.current,o=Number(A?.delta?.x??0),r=Number(A?.delta?.y??0),i=n?{x:n.x+(Number.isFinite(o)?o:0),y:n.y+(Number.isFinite(r)?r:0)}:w.current;w.current=i;const B=String(A.over?.id??"")==="timeline-drop"||GA(i);if(t&&B&&i){const f=kA(i.x),Q=OA(i.y),C=sA(t,Q);rA(C),Ce(t,Math.max(0,f),C)}V(null),gA(null),rA(null),AA(!1),wA(null),S.current=null},ye=()=>{V(null),gA(null),rA(null),AA(!1),wA(null),S.current=null},hA=D.useMemo(()=>{if(!j||!oA)return null;const A=UA;if(!A)return null;const t=OA(A.y),n=sA(j,t);if(n==null)return null;const o=kA(A.x),r=he(j,o,n,p.current),i=j.defaultDuration??10;return{laneRow:n,desiredStart:o,start:r,end:r+i,duration:i,kind:j.kind}},[j,oA,UA,FA,BA,O]),Ne=A=>{if(!N||A.pointerType==="mouse"||j)return;if(!!A.target?.closest?.(".timeline-editor-cursor-area, .timeline-editor-cursor")){H.current={pointerId:A.pointerId},x.current=null;try{A.currentTarget.setPointerCapture(A.pointerId)}catch{}A.preventDefault();return}x.current={x:A.clientX,y:A.clientY}},e=A=>{if(!N||A.pointerType==="mouse"||j||!H.current||H.current.pointerId!==A.pointerId)return;const t=kA(A.clientX);F.current&&F.current.setTime(t),A.preventDefault()},c=A=>{if(!N||A.pointerType==="mouse"||j)return;if(H.current&&H.current.pointerId===A.pointerId){H.current=null;try{A.currentTarget.releasePointerCapture(A.pointerId)}catch{}A.preventDefault();return}const t=x.current;x.current=null;const n=t?Math.abs(A.clientX-t.x):0,o=t?Math.abs(A.clientY-t.y):0;if(n>10||o>10)return;const i=A.target?.closest?.("[data-action-id]"),a=i?.getAttribute("data-row-id"),B=i?.getAttribute("data-action-id");if(a&&B){d(B);return}const f=kA(A.clientX);d(null),F.current&&F.current.setTime(f)};return E.jsx(EA.DndContext,{sensors:Be,collisionDetection:EA.rectIntersection,onDragStart:le,onDragMove:fe,onDragEnd:Fe,onDragCancel:ye,children:E.jsxs("div",{className:"timeline-editor-engine",children:[E.jsx("div",{className:"player-config",children:E.jsx("div",{className:"footage-bin",children:K.map(A=>E.jsx(gt,{item:A,hint:N?"Press-hold, then drag into timeline":"Drag into timeline"},A.id))})}),E.jsx("div",{className:"player-panel",ref:q,children:E.jsx("video",{className:"player-video",preload:"auto",playsInline:!0,muted:!0,controls:!1,disablePictureInPicture:!0,disableRemotePlayback:!0,controlsList:"nodownload noplaybackrate noremoteplayback",tabIndex:-1,onContextMenu:A=>A.preventDefault(),ref:A=>Y.attach(A)})}),E.jsx(at,{timelineState:F,autoScrollWhenPlay:uA,editorData:s,selectedActionId:g,onDeleteSelectedClip:me,onSplitSelectedClip:ue,canUndo:I.length>0,canRedo:b.length>0,onUndo:ve,onRedo:ge}),E.jsxs("div",{className:`timeline-drop${pe?" is-over":""}`,ref:A=>{W.current=A,be(A)},onPointerDown:Ne,onPointerMove:e,onPointerUp:c,children:[E.jsx("div",{className:"timeline-lane-labels",style:{top:JA,transform:`translateY(${-BA}px)`,height:O*IA.length},children:IA.map((A,t)=>E.jsx("div",{className:`timeline-lane-label${CA===t?" is-hover":""}`,style:{height:O},children:A},A))}),hA?E.jsx("div",{className:"timeline-ghost-layer",style:{top:JA,left:xA},children:(()=>{const A=te/ne,t=hA.duration*A,n=De(hA.start)-FA,o=[];return hA.kind==="video"?(o.push({row:hA.laneRow,kind:"video"}),o.push({row:NA(hA.laneRow),kind:"audio"})):o.push({row:hA.laneRow,kind:"audio"}),o.map(r=>E.jsx("div",{className:`timeline-ghost-clip${r.kind==="video"?" is-video":" is-audio"}`,style:{left:n,top:r.row*O-BA,width:t,height:O}},`${r.kind}-${r.row}`))})()}):null,E.jsx(Te.Timeline,{scale:ne,scaleWidth:te,startLeft:Ee,rowHeight:O,autoScroll:!0,ref:F,editorData:ce,effects:_e,onScroll:A=>{const t=Number(A?.scrollTop??0),n=Number(A?.scrollLeft??0);Number.isFinite(t)&&ie(t),Number.isFinite(n)&&yA(n)},onClickTimeArea:(A,t)=>{d(null)},onClickRow:A=>{A.target?.closest?.(".timeline-editor-action")||d(null)},onClickActionOnly:(A,{action:t})=>{const n=t;n?.id&&d(String(n.id))},onActionMoveStart:({action:A})=>{YA.current=String(A?.id??""),Z.current={actionId:String(A?.id??""),edge:null};const t=Number(A?.start),n=Number(A?.end);X.current={actionId:String(A?.id??""),mode:"move",dir:null,basePointerTime:null,lastPointerTime:null,initialStart:Number.isFinite(t)?t:0,initialEnd:Number.isFinite(n)?n:0,takeover:!1},aA(),!z.current&&(z.current=structuredClone(s),eA.current=LA(s))},onActionMoveEnd:()=>{const A=z.current,t=eA.current;A&&t&&LA(p.current)!==t&&HA(A),z.current=null,eA.current=null,YA.current=null,Z.current={actionId:null,edge:null},X.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,initialStart:0,initialEnd:0,takeover:!1},VA()},onActionResizeStart:({action:A})=>{YA.current=String(A?.id??""),Z.current={actionId:String(A?.id??""),edge:null};const t=Number(A?.start),n=Number(A?.end);X.current={actionId:String(A?.id??""),mode:"resize",dir:null,basePointerTime:null,lastPointerTime:null,initialStart:Number.isFinite(t)?t:0,initialEnd:Number.isFinite(n)?n:0,takeover:!1},aA(),!z.current&&(z.current=structuredClone(s),eA.current=LA(s))},onActionResizeEnd:()=>{const A=z.current,t=eA.current;A&&t&&LA(p.current)!==t&&HA(A),z.current=null,eA.current=null,YA.current=null,Z.current={actionId:null,edge:null},X.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,initialStart:0,initialEnd:0,takeover:!1},VA()},onActionMoving:({action:A,row:t,start:n,end:o})=>{const r=String(A?.id??""),i=X.current;if(i.takeover&&i.mode==="move"&&i.actionId===r){const R=i.basePointerTime,P=i.lastPointerTime,T=R!=null&&P!=null?P-R:0,_=i.initialStart+T,QA=i.initialEnd+T,mA=_A(r,_,QA),RA=mA.start,vA=mA.end;if(dA(t,String(A.id),RA,vA))return!1;const cA=p.current,pA=DA(cA,String(A.id));if(pA){const L=cA[pA.rowIndex];if(L&&dA(L,String(pA.action.id),RA,vA))return!1}return l(L=>{const J=pA?XA(L,String(A.id),RA,vA):zA(L,String(A.id),RA,vA);return p.current=J,J}),!1}const a=Number(n),B=Number(o);if(!Number.isFinite(a)||!Number.isFinite(B)||B<=a)return!1;const f=_A(r,a,B),Q=f.start,C=f.end;if(!Number.isFinite(Q)||!Number.isFinite(C)||C<=Q||dA(t,String(A.id),Q,C))return!1;const h=p.current,M=DA(h,String(A.id));if(M){const R=h[M.rowIndex];if(R&&dA(R,String(M.action.id),Q,C))return!1}if((M||f.snapped)&&l(R=>{const P=M?XA(R,String(A.id),Q,C):zA(R,String(A.id),Q,C);return p.current=P,P}),f.snapped){const R=X.current.lastPointerTime;return X.current={actionId:r,mode:"move",dir:null,basePointerTime:R,lastPointerTime:X.current.lastPointerTime,initialStart:a,initialEnd:B,takeover:!0},aA(),!1}},onActionResizing:({action:A,row:t,start:n,end:o,dir:r})=>{const i=String(A?.id??""),a=X.current,B=r??"right";if(a.takeover&&a.mode==="resize"&&a.actionId===i){const T=a.basePointerTime,_=a.lastPointerTime,QA=T!=null&&_!=null?_-T:0,mA=B==="left"?a.initialStart+QA:a.initialStart,RA=B==="right"?a.initialEnd+QA:a.initialEnd,vA=se(i,mA,RA,B),bA=vA.start,cA=vA.end;if(dA(t,String(A.id),bA,cA))return!1;const L=p.current,J=DA(L,String(A.id));if(J){const tA=L[J.rowIndex];if(tA&&dA(tA,String(J.action.id),bA,cA))return!1}return l(tA=>{const $=J?XA(tA,String(A.id),bA,cA):zA(tA,String(A.id),bA,cA);return p.current=$,$}),!1}const f=Number(n),Q=Number(o);if(!Number.isFinite(f)||!Number.isFinite(Q)||Q<=f)return!1;const C=se(i,f,Q,B),y=C.start,h=C.end;if(!Number.isFinite(y)||!Number.isFinite(h)||h<=y||dA(t,String(A.id),y,h))return!1;const R=p.current,P=DA(R,String(A.id));if(P){const T=R[P.rowIndex];if(T&&dA(T,String(P.action.id),y,h))return!1}if((P||C.snapped)&&l(T=>{const _=P?XA(T,String(A.id),y,h):zA(T,String(A.id),y,h);return p.current=_,_}),C.snapped){const T=X.current.lastPointerTime;return X.current={actionId:i,mode:"resize",dir:B,basePointerTime:T,lastPointerTime:X.current.lastPointerTime,initialStart:f,initialEnd:Q,takeover:!0},aA(),!1}},onChange:A=>{const t=$A(A),n=YA.current,o=n?oe(t,n):t;l(o);const r=z.current,i=eA.current;r&&i&&(LA(o)!==i&&HA(r),z.current=null,eA.current=null)},getActionRender:(A,t)=>{if(A.effectId==="effect0")return E.jsx(ke,{action:A,row:t});if(A.effectId==="effect2")return E.jsx(qe,{action:A,row:t});if(A.effectId==="effect1")return E.jsx(Je,{action:A,row:t})}})]}),E.jsx(EA.DragOverlay,{children:j?E.jsx("div",{className:"footage-overlay",style:U?{width:U.width,height:U.height}:void 0,children:E.jsx(Ue,{item:j,hint:"Drop on timeline",isDragging:!0})}):null})]})})};exports.MeliesVideoEditor=ft;
14
+ <%s key={someKey} {...props} />`,Se,VA,Ze,VA),re[VA+Se]=!0}}return e===c?Ve(sA):Ge(sA),sA}}function Ee(e,g,E){return Le(e,g,E,!0)}function Ye(e,g,E){return Le(e,g,E,!1)}var Oe=Ye,ve=Ee;Ne.Fragment=c,Ne.jsx=Oe,Ne.jsxs=ve})()),Ne}var ot;function Ct(){return ot||(ot=1,process.env.NODE_ENV==="production"?We.exports=dt():We.exports=ft()),We.exports}var D=Ct();const Et=({action:B,row:s})=>D.jsx("div",{className:"effect0","data-action-id":B.id,"data-row-id":s.id,children:D.jsx("div",{className:"effect0-text",children:`Audio: ${B.data.name}`})}),Qt=({action:B,row:s})=>D.jsx("div",{className:"effect1","data-action-id":B.id,"data-row-id":s.id,children:D.jsx("div",{className:"effect1-text",children:`Video: ${B.data.name}`})}),wt=({action:B,row:s})=>D.jsx("div",{className:"effect2","data-action-id":B.id,"data-row-id":s.id,children:D.jsx("div",{className:"effect2-text",children:`Video audio: ${B.data.name}`})}),st=B=>{const s=B.toLowerCase();return s.endsWith(".mp4")||s.endsWith(".webm")||s.endsWith(".mov")||s.endsWith(".m4v")?"video":s.endsWith(".mp3")||s.endsWith(".wav")||s.endsWith(".ogg")||s.endsWith(".m4a")||s.endsWith(".aac")?"audio":"other"};class It{blobUrlBySrc=new Map;pendingBySrc=new Map;async preloadToBlobUrl(s){if(!s)return s;const d=this.blobUrlBySrc.get(s);if(d)return d;const c=this.pendingBySrc.get(s);if(c)return c;const f=(async()=>{const Q=await fetch(s,{cache:"force-cache"});if(!Q.ok)throw new Error(`Failed to fetch ${s}: ${Q.status}`);const b=await Q.blob(),U=URL.createObjectURL(b);return this.blobUrlBySrc.set(s,U),U})().catch(Q=>(console.warn("[mediaCache] preload failed:",s,Q),s)).finally(()=>{this.pendingBySrc.delete(s)});return this.pendingBySrc.set(s,f),f}resolve(s){return this.blobUrlBySrc.get(s)??s}warm(s){this.preloadToBlobUrl(s)}async warmAll(s,d){const c=[],f=new Set;for(const Y of s){const m=String(Y??"");if(!m||f.has(m))continue;f.add(m);const X=st(m);X!=="video"&&X!=="audio"||c.push(m)}if(c.length===0)return;const Q=Math.max(1,Math.floor(d?.concurrency??3)),b=d?.yieldBetween!==!1;let U=0;const H=Array.from({length:Math.min(Q,c.length)},async()=>{for(;U<c.length;){const Y=c[U++];await this.preloadToBlobUrl(Y),b&&await new Promise(m=>setTimeout(m,0))}});await Promise.all(H)}warmFromEditorData(s){const d=new Set,c=Array.isArray(s)?s:[];for(const f of c){const Q=f?.actions;if(Array.isArray(Q))for(const b of Q){const U=b?.data?.src,H=b?.data?.previewSrc;typeof U=="string"&&U&&d.add(U),typeof H=="string"&&H&&d.add(H)}}for(const f of d){const Q=st(f);(Q==="video"||Q==="audio")&&this.warm(f)}}}const ye=new It,Dt=B=>{if(!B)return;const d=B.split("#")[0].split("?")[0].toLowerCase(),c=d.lastIndexOf(".");if(c<0)return;const f=d.slice(c+1);if(f)return f==="m4a"||f==="m4v"?"mp4":f};class ht{howlBySrc={};activeByActionId={};getHowl(s){const d=ye.resolve(s),c=d.startsWith("blob:")?s:d,f=c;if(this.howlBySrc[f])return this.howlBySrc[f];const Q=Dt(s),b=new nt.Howl({src:[c],format:Q?[Q]:void 0,loop:!0,autoplay:!1,preload:!0});return this.howlBySrc[f]=b,b}unlock(){try{const s=nt.Howler.ctx;s&&s.state==="suspended"&&s.resume()}catch{}}warm(s){s&&(ye.warm(s),this.getHowl(s))}seekForEngineTime(s,d,c,f,Q){const b=Number(Q),U=Number.isFinite(b)?b:0,H=s.duration();if(!Number.isFinite(H)||H<=0){s.seek(Math.max(0,f-c+U),d);return}const Y=(f-c+U)%H,m=Y<0?Y+H:Y;s.seek(m,d)}start(s){const{actionId:d,src:c,startTime:f,time:Q,engine:b}=s,U=Number(s.offset??0),H=Number.isFinite(U)?U:0,Y=this.activeByActionId[d];if(Y){const BA=this.getHowl(Y.src);BA.rate(b.getPlayRate(),Y.soundId);try{BA.playing(Y.soundId)||BA.play(Y.soundId)}catch{}b.isPlaying||this.seekForEngineTime(BA,Y.soundId,Y.startTime,Q,Y.offset);return}const m=this.getHowl(c),X=m.play();m.rate(b.getPlayRate(),X),this.seekForEngineTime(m,X,f,Q,H);let G=performance.now();const DA=({time:BA})=>{const hA=performance.now();if(!b.isPlaying){this.seekForEngineTime(m,X,f,BA,H);return}hA-G<120||(G=hA,this.seekForEngineTime(m,X,f,BA,H))},z=({rate:BA})=>{m.rate(BA,X)};b.on("afterSetTime",DA),b.on("afterSetPlayRate",z),this.activeByActionId[d]={src:c,startTime:f,offset:H,soundId:X,engine:b,lastResyncAtMs:G,time:DA,rate:z}}stop(s){const{actionId:d}=s,c=this.activeByActionId[d];if(!c)return;const f=this.getHowl(c.src);try{f.stop(c.soundId)}catch{}c.time&&c.engine.off("afterSetTime",c.time),c.rate&&c.engine.off("afterSetPlayRate",c.rate),delete this.activeByActionId[d]}}const vA=new ht;class mt{videoEl=null;currentSrc=null;lastSeekAtMs=0;lastRate=null;videoClaims={};activeVideoActionId=null;lastEngineTime=0;boundEngine=null;boundActionStart=0;vfcHandle=null;rafHandle=null;attach(s){this.videoEl=s,this.currentSrc=s?.currentSrc||s?.getAttribute("src")||null,this.lastSeekAtMs=0,this.lastRate=null,this.unbindEngine(),this.videoClaims={},this.activeVideoActionId=null,this.lastEngineTime=0,this.setActive(!1)}setActive(s){this.videoEl&&(this.videoEl.style.opacity=s?"1":"0")}claimVideo(s){const d=String(s.actionId),c=Number.isFinite(Number(s.layer))?Number(s.layer):0,f=String(s.src??""),Q=Number(s.actionStart),b=Number(s.time),U=s.engine,H=!!s.isPlaying,Y=Number(s.offset??0),m=Number.isFinite(Y)?Y:0;if(!f||!Number.isFinite(Q)||!Number.isFinite(b))return;const X=performance.now();this.lastEngineTime=b,this.videoClaims[d]={actionId:d,layer:c,src:f,actionStart:Q,offset:m,engine:U,isPlaying:H,time:b,claimedAtMs:X};let G=null;for(const z of Object.values(this.videoClaims)){if(!G){G=z;continue}if(z.layer>G.layer){G=z;continue}z.layer===G.layer&&z.claimedAtMs>G.claimedAtMs&&(G=z)}if(!G)return;this.activeVideoActionId=G.actionId,this.setActive(!0),this.setRate(G.engine.getPlayRate()),this.setSource(G.src);const DA=Math.max(0,G.time-G.actionStart+G.offset);this.seek(DA,{force:!G.isPlaying}),G.isPlaying?this.play():this.pause()}releaseVideo(s){const d=String(s);if(delete this.videoClaims[d],this.activeVideoActionId&&this.activeVideoActionId!==d)return;let c=null;for(const Q of Object.values(this.videoClaims)){if(!c){c=Q;continue}if(Q.layer>c.layer){c=Q;continue}Q.layer===c.layer&&Q.claimedAtMs>c.claimedAtMs&&(c=Q)}if(!c){this.activeVideoActionId=null,this.pause(),this.unbindEngine(),this.setActive(!1);return}this.activeVideoActionId=c.actionId,this.setActive(!0),this.setRate(c.engine.getPlayRate()),this.setSource(c.src);const f=Math.max(0,this.lastEngineTime-c.actionStart+c.offset);this.seek(f,{force:!c.isPlaying}),c.isPlaying?this.play():this.pause()}bindEngine(s,d){this.unbindEngine(),this.boundEngine=s,this.boundActionStart=d,this.tickFromVideo()}unbindEngine(){const s=this.videoEl;if(this.vfcHandle!=null&&s?.cancelVideoFrameCallback)try{s.cancelVideoFrameCallback(this.vfcHandle)}catch{}this.rafHandle!=null&&cancelAnimationFrame(this.rafHandle),this.vfcHandle=null,this.rafHandle=null,this.boundEngine=null}tickFromVideo=()=>{if(!this.videoEl||!this.boundEngine||this.videoEl.paused)return;const s=this.boundActionStart+this.videoEl.currentTime;Math.abs(this.boundEngine.getTime()-s)>.03&&this.boundEngine.setTime(s,!0);const d=this.videoEl;d?.requestVideoFrameCallback?this.vfcHandle=d.requestVideoFrameCallback(()=>this.tickFromVideo()):this.rafHandle=requestAnimationFrame(()=>this.tickFromVideo())};setSource(s){if(!this.videoEl||!s)return;const d=ye.resolve(s);if(!((this.videoEl.currentSrc||this.videoEl.getAttribute("src")||"")===d||this.currentSrc===d)){this.currentSrc=d,this.videoEl.preload="auto",this.videoEl.src=d;try{this.videoEl.load()}catch{}}}warm(s){s&&ye.warm(s)}setRate(s){this.videoEl&&this.lastRate!==s&&(this.lastRate=s,this.videoEl.playbackRate=s)}seek(s,d){if(this.videoEl)try{const c=performance.now(),f=d?.force===!0,Q=this.videoEl.currentTime;if(!f&&!this.videoEl.paused&&(Math.abs(Q-s)<.12||c-this.lastSeekAtMs<150))return;const b=this.videoEl.duration;Number.isFinite(b)&&b>0?this.videoEl.currentTime=Math.min(s,Math.max(0,b-.05)):this.videoEl.currentTime=Math.max(0,s),this.lastSeekAtMs=c}catch{}}async play(){if(this.videoEl)try{await this.videoEl.play(),this.boundEngine&&this.tickFromVideo()}catch{}}pause(){this.videoEl&&this.videoEl.pause()}}const kA=new mt,Ft=160,Rt=5,pt={effect0:{id:"effect0",name:"Play audio",source:{start:({action:B,engine:s,isPlaying:d,time:c})=>{if(d){const{src:f,offset:Q}=B.data;vA.warm(f),vA.start({actionId:B.id,src:f,startTime:B.start,engine:s,time:c,offset:Q})}},enter:({action:B,engine:s,isPlaying:d,time:c})=>{if(d){const{src:f,offset:Q}=B.data;vA.warm(f),vA.start({actionId:B.id,src:f,startTime:B.start,engine:s,time:c,offset:Q})}},leave:({action:B})=>{vA.stop({actionId:B.id})},stop:({action:B})=>{vA.stop({actionId:B.id})}}},effect2:{id:"effect2",name:"Play video audio",source:{start:({action:B,engine:s,isPlaying:d,time:c})=>{if(d){const{src:f,offset:Q}=B.data;vA.warm(f),vA.start({actionId:B.id,src:f,startTime:B.start,engine:s,time:c,offset:Q})}},enter:({action:B,engine:s,isPlaying:d,time:c})=>{if(d){const{src:f,offset:Q}=B.data;vA.warm(f),vA.start({actionId:B.id,src:f,startTime:B.start,engine:s,time:c,offset:Q})}},leave:({action:B})=>{vA.stop({actionId:B.id})},stop:({action:B})=>{vA.stop({actionId:B.id})}}},effect1:{id:"effect1",name:"Play video",source:{start:({action:B,engine:s,isPlaying:d,time:c})=>{const{src:f,previewSrc:Q,offset:b,videoLayer:U}=B.data??{},H=Q||f;H&&kA.warm(H),kA.claimVideo({actionId:String(B.id),layer:Number.isFinite(Number(U))?Number(U):0,src:H,engine:s,isPlaying:d,time:c,actionStart:Number(B.start),offset:b})},enter:({action:B,engine:s,isPlaying:d,time:c})=>{const{src:f,previewSrc:Q,offset:b,videoLayer:U}=B.data??{},H=Q||f;H&&kA.warm(H),kA.claimVideo({actionId:String(B.id),layer:Number.isFinite(Number(U))?Number(U):0,src:H,engine:s,isPlaying:d,time:c,actionStart:Number(B.start),offset:b})},update:({action:B,engine:s,time:d,isPlaying:c})=>{const{src:f,previewSrc:Q,offset:b,videoLayer:U}=B.data??{},H=Q||f;kA.claimVideo({actionId:String(B.id),layer:Number.isFinite(Number(U))?Number(U):0,src:H,engine:s,isPlaying:c,time:d,actionStart:Number(B.start),offset:b})},leave:({action:B})=>{kA.releaseVideo(String(B.id))},stop:({action:B})=>{kA.releaseVideo(String(B.id))}}}},Ot="",vt="",St="",bt="",Ht="",Nt="",{Option:yt}=et.Select,Ut=[.2,.5,1,1.5,2],Pt=({timelineState:B,autoScrollWhenPlay:s,scale:d,scaleWidth:c,startLeft:f,editorData:Q,selectedActionId:b,onDeleteSelectedClip:U,onSplitSelectedClip:H,canUndo:Y,canRedo:m,onUndo:X,onRedo:G})=>{const[DA,z]=F.useState(!1),[BA,hA]=F.useState(0),[yA,rA]=F.useState(!1),cA=F.useRef(0),_A=F.useRef(0),TA=F.useRef(0),JA=F.useRef(0),WA=F.useRef(0),SA=F.useRef(0),bA=!!b,XA=(()=>{if(!b)return null;const v=Array.isArray(Q)?Q:[];for(const AA of v){const eA=AA?.actions;if(Array.isArray(eA))for(const V of eA){if(String(V?.id)!==b)continue;const q=Number(V?.start),tA=Number(V?.end);return!Number.isFinite(q)||!Number.isFinite(tA)?null:{start:q,end:tA}}}return null})(),$A=!!(XA&&BA>XA.start&&BA<XA.end),mA=v=>{const AA=Array.isArray(Q)?Q:[];for(const eA of AA){const V=eA?.actions;if(Array.isArray(V))for(const q of V){if(q?.effectId!=="effect1")continue;const tA=Number(q?.start),aA=Number(q?.end);if(!(!Number.isFinite(tA)||!Number.isFinite(aA))&&v>=tA&&v<aA)return!0}}return!1},HA=v=>{mA(v)||(kA.pause(),kA.unbindEngine(),kA.setActive(!1))};F.useEffect(()=>{if(!B.current)return;const v=B.current,AA=()=>z(!0),eA=()=>z(!1),V=({time:tA})=>{hA(tA),HA(tA)},q=({time:tA})=>{const aA=performance.now();if(!(aA-cA.current<33)&&(cA.current=aA,hA(tA),HA(tA),s.current)){const NA=tA*(c/d)+f-500,LA=B.current;LA&&LA.setScrollLeft(NA)}};return v.listener.on("play",AA),v.listener.on("paused",eA),v.listener.on("afterSetTime",V),v.listener.on("setTimeByTick",q),()=>{v.listener.off("play",AA),v.listener.off("paused",eA),v.listener.off("afterSetTime",V),v.listener.off("setTimeByTick",q)}},[Q]);const UA=()=>{B.current&&(B.current.isPlaying?B.current.pause():(vA.unlock(),B.current.play({autoEnd:!0})))},de=v=>{B.current&&B.current.setPlayRate(v)},se=v=>{const AA=(parseInt(v%1*100+"")+"").padStart(2,"0"),eA=(parseInt(v/60+"")+"").padStart(2,"0"),V=(parseInt(v%60+"")+"").padStart(2,"0");return D.jsx(D.Fragment,{children:`${eA}:${V}.${AA.replace("0.","")}`})},GA=()=>{const v=[],AA=new Set,eA=Array.isArray(Q)?Q:[];for(const V of eA){const q=V?.actions;if(Array.isArray(q))for(const tA of q){const aA=tA?.data?.src;if(!aA)continue;const PA=String(aA);AA.has(PA)||(AA.add(PA),v.push(PA))}}return v},ae=(v,AA)=>{const eA=URL.createObjectURL(v),V=document.createElement("a");V.href=eA,V.download=AA,document.body.appendChild(V),V.click(),V.remove(),setTimeout(()=>URL.revokeObjectURL(eA),3e3)},zA=async()=>{if(!yA){rA(!0);try{const v=GA(),AA=new FormData;AA.append("timeline",JSON.stringify({editorData:Q}));for(const q of v){const tA=await fetch(q);if(!tA.ok)throw new Error(`Failed to fetch asset: ${q} (${tA.status})`);const aA=await tA.blob();AA.append("assets",aA,encodeURIComponent(q))}const eA=await fetch("/export",{method:"POST",body:AA});if(!eA.ok){const q=await eA.text().catch(()=>"");throw new Error(q||`Export failed (${eA.status})`)}const V=await eA.blob();ae(V,"export.mp4")}finally{rA(!1)}}};return D.jsxs("div",{className:"timeline-player",children:[D.jsx("div",{className:"play-control",role:"button",tabIndex:0,"aria-label":DA?"Pause":"Play",onClick:()=>{Date.now()-_A.current<450||UA()},onPointerUp:v=>{v.pointerType!=="mouse"&&(_A.current=Date.now(),UA())},children:D.jsx("img",{src:DA?vt:Ot,alt:"",draggable:!1})}),D.jsx("div",{className:"time",children:se(BA)}),D.jsxs("div",{className:"history-tools",children:[D.jsx("button",{type:"button",className:"history-tool",disabled:!Y,"aria-label":"Undo",onClick:()=>{Date.now()-WA.current<450||Y&&X()},onPointerUp:v=>{v.pointerType!=="mouse"&&(WA.current=Date.now(),Y&&X())},children:D.jsx("img",{src:St,alt:"",draggable:!1})}),D.jsx("button",{type:"button",className:"history-tool",disabled:!m,"aria-label":"Redo",onClick:()=>{Date.now()-SA.current<450||m&&G()},onPointerUp:v=>{v.pointerType!=="mouse"&&(SA.current=Date.now(),m&&G())},children:D.jsx("img",{src:bt,alt:"",draggable:!1})})]}),D.jsx("div",{className:"rate-control",children:D.jsx(et.Select,{size:"small",defaultValue:1,style:{width:120},onChange:de,children:Ut.map(v=>D.jsx(yt,{value:v,children:`${v.toFixed(1)}x`},v))})}),D.jsxs("div",{className:"clip-tools",children:[D.jsx("button",{type:"button",className:"clip-tool clip-tool-delete",disabled:!bA,"aria-label":"Delete selected clip",onClick:()=>{Date.now()-TA.current<450||bA&&U()},onPointerUp:v=>{v.pointerType!=="mouse"&&(TA.current=Date.now(),bA&&U())},children:D.jsx("img",{src:Ht,alt:"",draggable:!1})}),D.jsx("button",{type:"button",className:"clip-tool clip-tool-split",disabled:!$A,"aria-label":"Split selected clip at cursor",onClick:()=>{Date.now()-JA.current<450||$A&&H()},onPointerUp:v=>{v.pointerType!=="mouse"&&(JA.current=Date.now(),$A&&H())},children:D.jsx("img",{src:Nt,alt:"",draggable:!1})})]}),D.jsx("div",{className:"export-control",children:D.jsx(et.Button,{size:"small",type:"primary",loading:yA,onClick:zA,children:"Export"})})]})};function xt(){const B=()=>typeof window>"u"?!1:typeof navigator<"u"&&(navigator.maxTouchPoints??0)>0,[s,d]=F.useState(B);return F.useEffect(()=>{if(typeof window>"u"||typeof window.matchMedia!="function")return;const c=window.matchMedia("(pointer: coarse)"),f=()=>d(!!c.matches||B());return f(),typeof c.addEventListener=="function"?(c.addEventListener("change",f),()=>c.removeEventListener("change",f)):(c.addListener(f),()=>c.removeListener(f))},[]),s}const Mt="",kt="",Jt="",at=()=>[{id:"0",actions:[]},{id:"1",actions:[]},{id:"2",actions:[]},{id:"3",actions:[]}],Xe=5,ct=({item:B,hint:s,isDragging:d})=>D.jsxs("div",{className:`footage-card${d?" is-dragging":""}`,children:[D.jsx("div",{className:"footage-name",children:B.name}),B.kind==="video"?D.jsx("video",{className:"footage-preview",src:B.src,muted:!0,preload:"metadata",draggable:!1,onDragStart:c=>c.preventDefault(),playsInline:!0}):D.jsx("audio",{className:"footage-audio",src:B.src,controls:!0,preload:"metadata",draggable:!1,onDragStart:c=>c.preventDefault()}),D.jsx("div",{className:"footage-kind",children:s})]}),Gt=({item:B,hint:s})=>{const{attributes:d,listeners:c,setNodeRef:f,transform:Q,isDragging:b}=jA.useDraggable({id:`footage-${B.id}`,data:{item:B}}),U=Q?{transform:`translate3d(${Q.x}px, ${Q.y}px, 0)`}:void 0;return D.jsx("div",{ref:f,style:U,...c,...d,children:D.jsx(ct,{item:B,hint:s,isDragging:b})})},Lt=B=>String(B??"").toLowerCase().match(/\.(mp3|wav|m4a|aac|ogg)(\?|#|$)/)?"audio":"video",Yt=(B,s)=>{try{const d=String(B??"").split("/").pop()||"";return decodeURIComponent(d.split("?")[0].split("#")[0])||`Footage ${s+1}`}catch{return`Footage ${s+1}`}},Kt=({footageUrls:B,autoPlaceFootage:s=!1})=>{const[d,c]=F.useState(()=>at()),[f,Q]=F.useState(null),[b,U]=F.useState([]),[H,Y]=F.useState([]),m=F.useRef(d),X=xt(),[G,DA]=F.useState(!1),z=F.useRef(null),BA=F.useRef(null),hA=F.useRef(null),yA=F.useRef(!0),rA=F.useMemo(()=>{const A=Array.isArray(B)?B.filter(Boolean):[];return A.length?A.map((n,t)=>({id:`url-${t}`,kind:Lt(n),name:Yt(n,t),src:n,defaultDuration:10})):[]},[B]),[cA,_A]=F.useState(null),[TA,JA]=F.useState(null),[WA,SA]=F.useState(null),[bA,Ue]=F.useState(0),[XA,$A]=F.useState(0),[mA,HA]=F.useState(0),[UA,de]=F.useState(0),[se,GA]=F.useState(!1),[ae,zA]=F.useState(null),v=F.useRef(null),AA=F.useRef(null),eA=F.useRef(null),V=F.useRef(null),q=X?48:32,tA=30,[aA,PA]=F.useState(()=>Ft),NA=Rt,LA=A=>{PA(n=>{const t=Math.round(n*A);return Math.min(600,Math.max(60,t))})},fA=[1,0],YA=[3,2],Pe=["V2","V1","A2","A1"],ce=(A,n)=>{if(n.length===0)return null;if(A==null)return n[0];let t=n[0],r=Math.abs(A-t);for(const o of n){const i=Math.abs(A-o);i<r&&(t=o,r=i)}return t},qA=(A,n)=>A?A.kind==="video"?ce(n,fA):ce(n,YA):null,QA=A=>A===fA[1]?YA[1]:YA[0],ge=A=>A===YA[1]?fA[1]:fA[0],pA=(A,n)=>{const t=n==="video"?fA:YA;return ce(A,t)??t[0]},Be=F.useRef(!1);F.useEffect(()=>{if(!s||Be.current||rA.length===0||m.current.some(a=>Array.isArray(a?.actions)&&a.actions.length>0))return;const t=fA[0],r=QA(t),o=at();let i=0;for(const a of rA){const u=Math.max(.01,Number(a.defaultDuration??10)),C=i,w=i+u;if(i=w,a.kind==="video"){const I=`link-${CA()}`,y=fA.findIndex(S=>S===t);o[t].actions.push({id:`video-${CA()}`,start:C,end:w,effectId:"effect1",data:{src:a.src,previewSrc:a.previewSrc,name:a.name,linkId:I,videoLayer:y}}),o[r].actions.push({id:`video-audio-${CA()}`,start:C,end:w,effectId:"effect2",data:{src:a.src,name:a.name,linkId:I}})}else o[r].actions.push({id:`audio-${CA()}`,start:C,end:w,effectId:"effect0",data:{src:a.src,name:a.name}})}Q(null),U([]),Y([]),c(()=>(m.current=o,o)),Be.current=!0},[s,rA]),F.useEffect(()=>{ye.warmFromEditorData(d)},[d]),F.useEffect(()=>{m.current=d},[d]),F.useLayoutEffect(()=>{const A=hA.current;if(!A)return;const n=()=>{const r=A.getBoundingClientRect(),o=A.querySelector(".timeline-editor-edit-area");if(!o)return;const i=o.getBoundingClientRect();HA(i.top-r.top),de(i.left-r.left)},t=requestAnimationFrame(n);return window.addEventListener("resize",n),()=>{cancelAnimationFrame(t),window.removeEventListener("resize",n)}},[X,d.length]);const De=A=>{const n=hA.current;if(!n||!A)return!1;const t=n.getBoundingClientRect();return A.x>=t.left&&A.x<=t.right&&A.y>=t.top&&A.y<=t.bottom},ze=F.useRef(0),CA=()=>globalThis.crypto?.randomUUID?globalThis.crypto.randomUUID():`uid-${++ze.current}`,wA=F.useRef(null),OA=F.useRef(null),Ae=F.useRef(null),he=.9,me=1.05,FA=F.useRef({actionId:null,edge:null}),nA=F.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}),uA=F.useRef({actionId:null,partnerId:null,dir:null,baseStart:0,baseOffset:0,partnerBaseOffset:0}),Fe=F.useRef(!1),ue=A=>A.map(n=>{const t=(n.actions??[]).map(r=>`${String(r.id)}@${Number(r.start)}-${Number(r.end)}`).join("|");return`${String(n.id)}:${t}`}).join("||"),ee=A=>{const n=structuredClone(A);U(t=>{const r=[...t,n];return r.length>Xe&&r.splice(0,r.length-Xe),r}),Y([])},fe=(A,n,t,r)=>A<r&&n>t,KA=(A,n,t,r)=>{const o=Array.isArray(A?.actions)?A.actions:[];for(const i of o)if(!(!i||i.id===n)&&fe(t,r,Number(i.start),Number(i.end)))return!0;return!1},IA=(A,n)=>{for(let t=0;t<A.length;t++){const r=A[t],o=Array.isArray(r?.actions)?r.actions:[];for(let i=0;i<o.length;i++){const a=o[i];if(String(a?.id)===n)return{rowIndex:t,actionIndex:i,action:a}}}return null},xA=(A,n)=>{const t=IA(A,n),r=t?.action?.data?.linkId;if(!t||!r)return null;for(let o=0;o<A.length;o++){const i=A[o],a=Array.isArray(i?.actions)?i.actions:[];for(let u=0;u<a.length;u++){const C=a[u];if(C?.data?.linkId&&String(C.data.linkId)===String(r)&&String(C.id)!==String(n))return{rowIndex:o,actionIndex:u,action:C}}}return null},Re=(A,n)=>{const t=IA(A,n);if(!t)return A;const r=xA(A,n);if(!r)return A;const o=Number(t.action.start),i=Number(t.action.end);if(!Number.isFinite(o)||!Number.isFinite(i)||i<=o||Number(r.action.start)===o&&Number(r.action.end)===i)return A;const a=structuredClone(A),u=a[r.rowIndex],C=Array.isArray(u.actions)?[...u.actions]:[],w={...C[r.actionIndex],start:o,end:i};return C.splice(r.actionIndex,1,w),u.actions=C,a},xe=(A,n)=>{const t=structuredClone(A);for(;t.length<4;)t.push({id:`${t.length}`,actions:[]});const r=l=>l&&typeof l=="object"?l:{},o=(l,O)=>{if(!(!l||typeof l!="object"))return l[O]},i=l=>String(o(l,"id")??""),a=l=>String(o(l,"effectId")??""),u=l=>Number(o(l,"start")),C=l=>Number(o(l,"end")),w=l=>o(l,"data"),I=l=>{if(!l||typeof l!="object")return 0;const O=Number(l.start);return Number.isFinite(O)?O:0},y=new Map,S=new Map;for(let l=0;l<t.length;l++){const O=t[l],N=Array.isArray(O?.actions)?O.actions:[];for(let h=0;h<N.length;h++){const P=N[h],J=i(P);if(!J)continue;y.set(J,{rowIndex:l,actionIndex:h,action:P});const W=w(P),_=o(W,"linkId"),oA=_!=null?String(_):"";if(!oA)continue;const k=S.get(oA)??{},j=a(P);j==="effect1"?k.video={rowIndex:l,actionIndex:h,action:P}:j==="effect2"&&(k.audio={rowIndex:l,actionIndex:h,action:P}),S.set(oA,k)}}const R=new Map;for(const l of S.values()){if(!l.video||!l.audio)continue;const O=i(l.video.action),N=i(l.audio.action),h=n&&String(n)===N?"audio":"video",P=h==="audio"?ge(pA(l.audio.rowIndex,"audio")):pA(l.video.rowIndex,"video"),J=QA(P),W=h==="audio"?l.audio.action:l.video.action,_=u(W),oA=C(W),k=Number.isFinite(_)&&Number.isFinite(oA)&&oA>_,j=Math.max(0,fA.findIndex($=>$===P));R.set(O,{targetRowIndex:P,patchStartEnd:k?{start:_,end:oA}:void 0,patchVideoLayer:j}),R.set(N,{targetRowIndex:J,patchStartEnd:k?{start:_,end:oA}:void 0})}for(const[l,O]of y.entries()){if(R.has(l))continue;const N=a(O.action);if(N==="effect1"){const h=pA(O.rowIndex,"video"),P=Math.max(0,fA.findIndex(J=>J===h));R.set(l,{targetRowIndex:h,patchVideoLayer:P})}else if(N==="effect0"||N==="effect2"){const h=pA(O.rowIndex,"audio");R.set(l,{targetRowIndex:h})}}const K=t.map(l=>({...l,actions:[]}));let x=!1;for(let l=0;l<t.length;l++){const O=t[l],N=Array.isArray(O?.actions)?O.actions:[];for(const h of N){const P=h,J=i(P);if(!J)continue;const W=R.get(J),_=W?W.targetRowIndex:l,oA=K[_]??K[l];let k=P;if(W?.patchStartEnd){const j=W.patchStartEnd.start,$=W.patchStartEnd.end;(u(k)!==j||C(k)!==$)&&(k={...r(k),start:j,end:$},x=!0)}if(W?.patchVideoLayer!=null&&a(k)==="effect1"){const j=Number(o(w(k),"videoLayer"));if(!Number.isFinite(j)||j!==W.patchVideoLayer){const $={...r(w(k)),videoLayer:W.patchVideoLayer};k={...r(k),data:$},x=!0}}_!==l&&(x=!0),oA.actions.push(k)}}for(const l of K){const O=Array.isArray(l.actions)?[...l.actions]:[];O.sort((N,h)=>I(N)-I(h)),l.actions=O}return x?K:A},MA=(A,n,t,r)=>{if(!Number.isFinite(t)||!Number.isFinite(r)||r<=t)return A;const o=IA(A,n);if(!o)return A;const i=xA(A,n);if(!i)return A;const a=structuredClone(A),u=a[o.rowIndex],C=Array.isArray(u.actions)?[...u.actions]:[],w={...C[o.actionIndex],start:t,end:r};C.splice(o.actionIndex,1,w),u.actions=C;const I=a[i.rowIndex],y=Array.isArray(I.actions)?[...I.actions]:[],S={...y[i.actionIndex],start:t,end:r};return y.splice(i.actionIndex,1,S),I.actions=y,a},te=(A,n,t,r)=>{if(!Number.isFinite(t)||!Number.isFinite(r)||r<=t)return A;const o=IA(A,n);if(!o)return A;const i=Number(o.action.start),a=Number(o.action.end);if(i===t&&a===r)return A;const u=structuredClone(A),C=u[o.rowIndex],w=Array.isArray(C.actions)?[...C.actions]:[],I={...w[o.actionIndex],start:t,end:r};return w.splice(o.actionIndex,1,I),C.actions=w,u},Ce=()=>{const A=z.current?.getTime?Number(z.current.getTime()):0;return Number.isFinite(A)?Math.max(0,A):0},pe=(A,n,t)=>{const r=Ce(),o=t-n;if(!Number.isFinite(o)||o<=0)return{start:n,end:t,snapped:!1,edge:null};const i=Math.abs(n-r),a=Math.abs(t-r),u=i<=a?"start":"end",C=Math.min(i,a),w=FA.current;if(w.actionId===A&&w.edge!=null){if((w.edge==="start"?i:a)>me)return FA.current={actionId:A,edge:null},{start:n,end:t,snapped:!1,edge:null}}else{if(C>he)return{start:n,end:t,snapped:!1,edge:null};FA.current={actionId:A,edge:u}}const S=FA.current.edge;if(S==="start"){const x=r,l=x+o;return{start:Math.max(0,x),end:Math.max(Math.max(0,x),l),snapped:!0,edge:S}}const R=r,K=R-o;return{start:Math.max(0,K),end:Math.max(0,R),snapped:!0,edge:S}},Me=(A,n,t,r)=>{const o=Ce(),i=r==="left"?"start":"end",a=Math.abs(i==="start"?n-o:t-o),u=FA.current;if(u.actionId===A&&u.edge===i){if(a>me)return FA.current={actionId:A,edge:null},{start:n,end:t,snapped:!1}}else{if(a>he)return{start:n,end:t,snapped:!1};FA.current={actionId:A,edge:i}}if(i==="start"){const S=Math.max(0,o),R=Math.max(S+.01,t);return{start:S,end:R,snapped:!0}}const I=Math.max(0,o),y=Math.min(n,I-.01);return{start:Math.max(0,y),end:I,snapped:!0}},ke=(A,n,t)=>{const r=A.defaultDuration??10;let o=Math.max(0,n),i=o+r;const a=z.current;a?.isPlaying&&a.pause(),c(u=>{ee(u);const C=structuredClone(u);for(;C.length<4;)C.push({id:`${C.length}`,actions:[]});const w=Number.isFinite(Number(t))?Number(t):null,I=ce(w,fA)??fA[0],y=ce(w,YA)??YA[0],S=R=>{const K=[];for(const x of R){const l=Array.isArray(C[x]?.actions)?C[x].actions:[];for(const O of l){const N=Number(O?.start),h=Number(O?.end);!Number.isFinite(N)||!Number.isFinite(h)||K.push({start:N,end:h})}}K.sort((x,l)=>x.start-l.start);for(const x of K)fe(o,i,x.start,x.end)&&(o=x.end,i=o+r)};if(A.kind==="video"){const R=I,K=QA(R);S([R,K]);const x=`link-${CA()}`,l=`video-${CA()}`,O=`video-audio-${CA()}`,N=fA.findIndex(h=>h===R);C[R].actions=[...C[R].actions??[],{id:l,start:o,end:i,effectId:"effect1",data:{src:A.src,previewSrc:A.previewSrc,name:A.name,linkId:x,videoLayer:N}}],C[K].actions=[...C[K].actions??[],{id:O,start:o,end:i,effectId:"effect2",data:{src:A.src,name:A.name,linkId:x}}]}else{const R=y;S([R]),C[R].actions=[...C[R].actions??[],{id:`audio-${CA()}`,start:o,end:i,effectId:"effect0",data:{src:A.src,name:A.name}}]}return C})},qe=()=>{const A=hA.current;return A?A.querySelector(".timeline-editor-edit-area .ReactVirtualized__Grid")?.scrollLeft??0:0},Je=()=>bA,ne=A=>{const n=hA.current;if(!n)return 0;const r=(n.querySelector(".timeline-editor-edit-area")??n).getBoundingClientRect(),a=(A-r.x+qe()-tA)*NA/aA;return Math.max(0,a)},Ge=A=>{const n=Number(A);return Number.isFinite(n)?tA+n*aA/NA:0},Ve=(A,n,t,r)=>{const o=A.defaultDuration??10;let i=Math.max(0,n),a=i+o;const u=[];if(A.kind==="video"){const w=t,I=QA(w);u.push(w,I)}else u.push(t);const C=[];for(const w of u){const I=Array.isArray(r[w]?.actions)?r[w].actions:[];for(const y of I){const S=Number(y?.start),R=Number(y?.end);!Number.isFinite(S)||!Number.isFinite(R)||C.push({start:S,end:R})}}C.sort((w,I)=>w.start-I.start);for(const w of C)fe(i,a,w.start,w.end)&&(i=w.end,a=i+o);return Math.max(0,i)},re=A=>{const n=hA.current;if(!n)return null;const t=n.querySelector(".timeline-editor-edit-area");if(!t)return null;const r=t.getBoundingClientRect(),o=A-r.y;if(o<0||o>r.height)return null;const i=o+Je(),a=Math.floor(i/q);if(!Number.isFinite(a))return null;const u=Math.max(0,m.current.length-1);return Math.min(Math.max(0,a),u)},Le=A=>{if(!A)return null;if("clientX"in A&&"clientY"in A){const o=Number(A.clientX),i=Number(A.clientY);if(Number.isFinite(o)&&Number.isFinite(i))return{x:o,y:i}}const n=A.touches,t=A.changedTouches,r=(n&&n.length?n[0]:null)||(t&&t.length?t[0]:null);if(r){const o=Number(r.clientX),i=Number(r.clientY);if(Number.isFinite(o)&&Number.isFinite(i))return{x:o,y:i}}return null},Ee=()=>{if(Fe.current)return;Fe.current=!0;const A=t=>{const r=nA.current;if(!r.actionId||!r.mode||t.isPrimary===!1)return;const o=ne(t.clientX);r.basePointerTime==null&&(r.basePointerTime=o),r.lastPointerTime=o,r.basePointerClientY==null&&(r.basePointerClientY=t.clientY),r.lastPointerClientY=t.clientY},n=()=>{const t={actionId:nA.current.actionId,mode:nA.current.mode};requestAnimationFrame(()=>{nA.current.actionId===t.actionId&&nA.current.mode===t.mode&&(nA.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:0,committedRowIndex:0,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:0,initialEnd:0,takeover:!1},FA.current={actionId:null,edge:null})})};window.addEventListener("pointermove",A,{capture:!0}),window.addEventListener("pointerup",n,{capture:!0}),window.addEventListener("pointercancel",n,{capture:!0}),nA.current._removePointerListeners=()=>{window.removeEventListener("pointermove",A,{capture:!0}),window.removeEventListener("pointerup",n,{capture:!0}),window.removeEventListener("pointercancel",n,{capture:!0}),Fe.current=!1}},Ye=()=>{const A=nA.current?._removePointerListeners;A?.(),delete nA.current._removePointerListeners},Oe=F.useRef(!1),ve=A=>{const n=Number(A?.data?.offset??0);return Number.isFinite(n)?n:0},e=(A,n,t)=>{const r=IA(A,n);if(!r)return A;const o=Math.max(0,Number.isFinite(t)?t:0);if(ve(r.action)===o)return A;const a=structuredClone(A),u=a[r.rowIndex],C=Array.isArray(u.actions)?[...u.actions]:[],w={...C[r.actionIndex],data:{...C[r.actionIndex]?.data??{},offset:o}};return C.splice(r.actionIndex,1,w),u.actions=C,a},g=(A,n,t,r)=>{const o=IA(A,n);if(!o)return A;const i=xA(A,n);if(!i)return e(A,n,t);const a=Math.max(0,Number.isFinite(t)?t:0),u=Math.max(0,Number.isFinite(Number(r))?Number(r):a),C=structuredClone(A),w=C[o.rowIndex],I=Array.isArray(w.actions)?[...w.actions]:[],y={...I[o.actionIndex],data:{...I[o.actionIndex]?.data??{},offset:a}};I.splice(o.actionIndex,1,y),w.actions=I;const S=C[i.rowIndex],R=Array.isArray(S.actions)?[...S.actions]:[],K={...R[i.actionIndex],data:{...R[i.actionIndex]?.data??{},offset:u}};return R.splice(i.actionIndex,1,K),S.actions=R,C},[E,p]=F.useState(null),T=(A,n,t)=>{const r=IA(A,n);if(!r)return A;const i=String(r.action?.effectId??"")==="effect1"?"video":"audio",a=pA(t,i),u=xA(A,n),C=!!u,w=new Set([String(n)]);u&&w.add(String(u.action.id));const I=Number(r.action?.start),y=Number(r.action?.end);if(!Number.isFinite(I)||!Number.isFinite(y)||y<=I)return A;const S=(h,P,J)=>{const W=Array.isArray(h?.actions)?h.actions:[];for(const _ of W){const oA=String(_?.id??"");if(!(oA&&w.has(oA))&&fe(P,J,Number(_?.start),Number(_?.end)))return!1}return!0};let R=null,K=null;if(C&&(i==="video"?(R=a,K=QA(R)):(K=a,R=ge(K))),i==="video"){if(!S(A[a],I,y))return A}else if(!S(A[a],I,y))return A;if(R!=null&&!S(A[R],I,y)||K!=null&&!S(A[K],I,y)||!C&&r.rowIndex===a)return A;if(C&&i==="video"&&r.rowIndex===R){const h=u?IA(A,String(u.action.id)):null;if(h&&h.rowIndex===K)return A}if(C&&i==="audio"&&r.rowIndex===K){const h=u?IA(A,String(u.action.id)):null;if(h&&h.rowIndex===R)return A}const x=structuredClone(A);for(;x.length<4;)x.push({id:`${x.length}`,actions:[]});const l=(h,P)=>{const J=Array.isArray(h.actions)?h.actions:[];h.actions=J.filter(W=>String(W?.id??"")!==P)},O=(h,P)=>{const J=x[h];J.actions=[...J.actions??[],P],J.actions.sort((W,_)=>Number(W.start)-Number(_.start))};l(x[r.rowIndex],String(n));let N=r.action;if(i==="video"){const h=Math.max(0,fA.findIndex(P=>P===a));N={...N,data:{...N.data??{},videoLayer:h}}}if(O(a,N),u&&R!=null&&K!=null){const h=IA(A,String(u.action.id));if(h){l(x[h.rowIndex],String(u.action.id));const P=i==="video"?K:R;let J=h.action;if(String(J?.effectId??"")==="effect1"){const _=Math.max(0,fA.findIndex(oA=>oA===P));J={...J,data:{...J.data??{},videoLayer:_}}}O(P,J)}}return x},Z=A=>A.map(n=>({...n,selected:void 0,actions:(n.actions??[]).map(t=>({...t,selected:void 0}))})),L=F.useMemo(()=>d.map((A,n)=>{const t=f?(A.actions??[]).some(a=>String(a.id)===f):!1,r=cA!=null&&WA!=null&&n===WA,o=Array.isArray(A.classNames)?A.classNames:[],i=r?[...o,"dnd-drop-hover"]:o;return{...A,classNames:i,selected:t,actions:(A.actions??[]).map(a=>({...a,selected:f?String(a.id)===f:!1}))}}),[d,f,cA,WA]),M=()=>{if(!f)return;const A=z.current;A?.isPlaying&&A.pause(),c(n=>{ee(n);let t=null;for(const o of n){const i=Array.isArray(o?.actions)?o.actions:[];for(const a of i){if(String(a?.id)!==f)continue;const u=a?.data?.linkId;u!=null&&(t=String(u));break}if(t!=null)break}return n.map(o=>({...o,actions:(o.actions??[]).filter(i=>!(String(i?.id)===f||t&&String(i?.data?.linkId??"")===t))}))}),Q(null)},lA=()=>{if(!f)return;const A=z.current,n=A?.getTime?A.getTime():null;if(n==null)return;const t=Number(n);Number.isFinite(t)&&(A?.isPlaying&&A.pause(),wA.current=null,OA.current=null,c(r=>{let o=-1,i=-1,a=null;for(let k=0;k<r.length;k++){const j=r[k],$=Array.isArray(j?.actions)?j.actions:[];for(let gA=0;gA<$.length;gA++){const dA=$[gA];if(String(dA?.id)===f){o=k,i=gA,a=dA;break}}if(a)break}if(!a)return r;const u=a?.data?.linkId?String(a.data.linkId):null;let C=-1,w=-1,I=null;if(u)for(let k=0;k<r.length;k++){const j=r[k],$=Array.isArray(j?.actions)?j.actions:[];for(let gA=0;gA<$.length;gA++){const dA=$[gA];if(String(dA?.id)!==f&&String(dA?.data?.linkId??"")===u){C=k,w=gA,I=dA;break}}if(I)break}const y=Number(a.start),S=Number(a.end);if(!Number.isFinite(y)||!Number.isFinite(S)||!(y<t&&t<S))return r;ee(r);const R=u&&I?`link-${CA()}`:u,K=u&&I?`link-${CA()}`:u,x=`${String(a.id)}-r-${CA()}`,l=Number(a?.data?.offset??0),O=Number.isFinite(l)?l:0,N=t-y,h=O+(Number.isFinite(N)?N:0),P={...a,start:y,end:t,id:a.id,data:{...a.data,offset:O,linkId:R??void 0}},J={...a,start:t,end:S,id:x,data:{...a.data,offset:h,linkId:K??void 0}},W=structuredClone(r),_=W[o],oA=Array.isArray(_.actions)?[..._.actions]:[];if(oA.splice(i,1,P,J),oA.sort((k,j)=>Number(k.start)-Number(j.start)),_.actions=oA,I&&C>=0&&w>=0){const k=Number(I.start),j=Number(I.end);if(Number.isFinite(k)&&Number.isFinite(j)&&k===y&&j===S){const $=Number(I?.data?.offset),gA=Number.isFinite($)?$:O,dA=gA+(Number.isFinite(N)?N:0),ZA=`${String(I.id)}-r-${CA()}`,Qe={...I,start:y,end:t,id:I.id,data:{...I.data,offset:gA,linkId:R??void 0}},oe={...I,start:t,end:S,id:ZA,data:{...I.data,offset:dA,linkId:K??void 0}},we=W[C],Ie=Array.isArray(we.actions)?[...we.actions]:[];Ie.splice(w,1,Qe,oe),Ie.sort((Ke,je)=>Number(Ke.start)-Number(je.start)),we.actions=Ie}}return W}))},iA=()=>{const A=z.current,n=A?.getTime?A.getTime():null;A?.isPlaying&&A.pause(),wA.current=null,OA.current=null,Q(null),U(t=>{if(t.length===0)return t;const r=t[t.length-1],o=structuredClone(m.current);return Y(i=>[...i,o]),c(structuredClone(r)),t.slice(0,-1)}),n!=null&&requestAnimationFrame(()=>{const t=z.current;t?.setTime&&t.setTime(n)})},sA=()=>{const A=z.current,n=A?.getTime?A.getTime():null;A?.isPlaying&&A.pause(),wA.current=null,OA.current=null,Q(null),Y(t=>{if(t.length===0)return t;const r=t[t.length-1],o=structuredClone(m.current);return U(i=>{const a=[...i,o];return a.length>Xe&&a.splice(0,a.length-Xe),a}),c(structuredClone(r)),t.slice(0,-1)}),n!=null&&requestAnimationFrame(()=>{const t=z.current;t?.setTime&&t.setTime(n)})},RA=jA.useSensors(jA.useSensor(jA.PointerSensor,{activationConstraint:{distance:6}}),jA.useSensor(jA.TouchSensor,{activationConstraint:{delay:180,tolerance:6}})),{setNodeRef:ie,isOver:VA}=jA.useDroppable({id:"timeline-drop"}),EA=A=>{const n=A.active.data.current?.item;_A(n??null);const t=Le(A.activatorEvent);if(v.current=t,AA.current=t,zA(t),t){const o=De(t);GA(o);const i=re(t.y);SA(o?qA(n??null,i):null)}else SA(null),GA(!1);const r=A.active.rect.current.initial;JA(r?{width:r.width,height:r.height}:null)},Se=A=>{const n=A.active.rect.current.initial;!TA&&n&&JA({width:n.width,height:n.height});const t=AA.current;if(!t){SA(null);return}const r=Number(A?.delta?.x??0),o=Number(A?.delta?.y??0),i={x:t.x+(Number.isFinite(r)?r:0),y:t.y+(Number.isFinite(o)?o:0)};v.current=i,zA(i);const a=De(i);GA(a);const u=re(i.y);SA(a?qA(cA,u):null)},Ze=A=>{const n=A.active.data.current?.item,t=AA.current,r=Number(A?.delta?.x??0),o=Number(A?.delta?.y??0),i=t?{x:t.x+(Number.isFinite(r)?r:0),y:t.y+(Number.isFinite(o)?o:0)}:v.current;v.current=i;const u=String(A.over?.id??"")==="timeline-drop"||De(i);if(n&&u&&i){const C=ne(i.x),w=re(i.y),I=qA(n,w);SA(I),ke(n,Math.max(0,C),I)}_A(null),JA(null),SA(null),GA(!1),zA(null),AA.current=null},_e=()=>{_A(null),JA(null),SA(null),GA(!1),zA(null),AA.current=null},le=F.useMemo(()=>{if(!cA||!se)return null;const A=ae;if(!A)return null;const n=re(A.y),t=qA(cA,n);if(t==null)return null;const r=ne(A.x),o=Ve(cA,r,t,m.current),i=cA.defaultDuration??10;return{laneRow:t,desiredStart:r,start:o,end:o+i,duration:i,kind:cA.kind}},[cA,se,ae,XA,bA,q]),gt=A=>{if(!X||A.pointerType==="mouse"||cA)return;if(!!A.target?.closest?.(".timeline-editor-cursor-area, .timeline-editor-cursor")){V.current={pointerId:A.pointerId},eA.current=null;try{A.currentTarget.setPointerCapture(A.pointerId)}catch{}A.preventDefault();return}eA.current={x:A.clientX,y:A.clientY}},Bt=A=>{if(!X||A.pointerType==="mouse"||cA||!V.current||V.current.pointerId!==A.pointerId)return;const n=ne(A.clientX);z.current&&z.current.setTime(n),A.preventDefault()},ut=A=>{if(!X||A.pointerType==="mouse"||cA)return;if(V.current&&V.current.pointerId===A.pointerId){V.current=null;try{A.currentTarget.releasePointerCapture(A.pointerId)}catch{}A.preventDefault();return}const n=eA.current;eA.current=null;const t=n?Math.abs(A.clientX-n.x):0,r=n?Math.abs(A.clientY-n.y):0;if(t>10||r>10)return;const i=A.target?.closest?.("[data-action-id]"),a=i?.getAttribute("data-row-id"),u=i?.getAttribute("data-action-id");if(a&&u){Q(u);return}const C=ne(A.clientX);Q(null),z.current&&z.current.setTime(C)};return D.jsx(jA.DndContext,{sensors:RA,collisionDetection:jA.rectIntersection,onDragStart:EA,onDragMove:Se,onDragEnd:Ze,onDragCancel:_e,children:D.jsxs("div",{className:"timeline-editor-engine",children:[D.jsxs("div",{className:"player-stack",children:[D.jsx("div",{className:"footage-ribbon",role:"toolbar","aria-label":"Footage",children:D.jsx("button",{type:"button",className:`footage-ribbon-toggle${G?" is-open":""}`,"aria-expanded":G,"aria-controls":"footage-bin-panel",onClick:()=>DA(A=>!A),children:D.jsx("img",{src:Mt,alt:"Footage",draggable:!1})})}),D.jsx("div",{id:"footage-bin-panel",className:`footage-bin-panel${G?" is-open":""}${cA?" is-dragging":""}`,"aria-hidden":!G,children:D.jsx("div",{className:"footage-bin",children:rA.map(A=>D.jsx(Gt,{item:A,hint:X?"Press-hold, then drag into timeline":"Drag into timeline"},A.id))})}),D.jsx("div",{className:"player-panel",ref:BA,children:D.jsx("video",{className:"player-video",preload:"auto",playsInline:!0,muted:!0,controls:!1,disablePictureInPicture:!0,disableRemotePlayback:!0,controlsList:"nodownload noplaybackrate noremoteplayback",tabIndex:-1,onContextMenu:A=>A.preventDefault(),ref:A=>kA.attach(A)})})]}),D.jsx(Pt,{timelineState:z,autoScrollWhenPlay:yA,scale:NA,scaleWidth:aA,startLeft:tA,editorData:d,selectedActionId:f,onDeleteSelectedClip:M,onSplitSelectedClip:lA,canUndo:b.length>0,canRedo:H.length>0,onUndo:iA,onRedo:sA}),D.jsxs("div",{className:`timeline-drop${VA?" is-over":""}`,ref:A=>{hA.current=A,ie(A)},onPointerDown:gt,onPointerMove:Bt,onPointerUp:ut,children:[D.jsxs("div",{className:"timeline-zoom-controls","aria-label":"Timeline zoom",children:[D.jsx("button",{type:"button",className:"timeline-zoom-control",onClick:()=>LA(1/1.25),"aria-label":"Zoom out",title:"Zoom out",children:D.jsx("img",{src:Jt,alt:"",draggable:!1})}),D.jsx("button",{type:"button",className:"timeline-zoom-control",onClick:()=>LA(1.25),"aria-label":"Zoom in",title:"Zoom in",children:D.jsx("img",{src:kt,alt:"",draggable:!1})})]}),D.jsx("div",{className:"timeline-lane-labels",style:{top:mA,transform:`translateY(${-bA}px)`,height:q*Pe.length},children:Pe.map((A,n)=>D.jsx("div",{className:`timeline-lane-label${WA===n?" is-hover":""}`,style:{height:q},children:A},A))}),le?D.jsx("div",{className:"timeline-ghost-layer",style:{top:mA,left:UA},children:(()=>{const A=aA/NA,n=le.duration*A,t=Ge(le.start)-XA,r=[];return le.kind==="video"?(r.push({row:le.laneRow,kind:"video"}),r.push({row:QA(le.laneRow),kind:"audio"})):r.push({row:le.laneRow,kind:"audio"}),r.map(o=>D.jsx("div",{className:`timeline-ghost-clip${o.kind==="video"?" is-video":" is-audio"}`,style:{left:t,top:o.row*q-bA,width:n,height:q}},`${o.kind}-${o.row}`))})()}):null,E?D.jsx("div",{className:"timeline-ghost-layer",style:{top:mA,left:UA},children:(()=>{const A=aA/NA,n=E.duration*A,t=Ge(E.start)-XA,r=[];return E.kind==="video"?(r.push({row:E.laneRow,kind:"video"}),r.push({row:QA(E.laneRow),kind:"audio"})):r.push({row:E.laneRow,kind:"audio"}),r.map(o=>D.jsx("div",{className:`timeline-ghost-clip${o.kind==="video"?" is-video":" is-audio"}`,style:{left:t,top:o.row*q-bA,width:n,height:q}},`${E.actionId}-${o.kind}-${o.row}`))})()}):null,D.jsx(lt.Timeline,{scale:NA,scaleWidth:aA,startLeft:tA,rowHeight:q,autoScroll:!0,ref:z,editorData:L,effects:pt,onScroll:A=>{const n=Number(A?.scrollTop??0),t=Number(A?.scrollLeft??0);Number.isFinite(n)&&Ue(n),Number.isFinite(t)&&$A(t)},onClickTimeArea:(A,n)=>{Q(null)},onClickRow:A=>{A.target?.closest?.(".timeline-editor-action")||Q(null)},onClickActionOnly:(A,{action:n})=>{const t=n;t?.id&&Q(String(t.id))},onActionMoveStart:({action:A})=>{Ae.current=String(A?.id??""),FA.current={actionId:String(A?.id??""),edge:null};const n=Number(A?.start),t=Number(A?.end),r=String(A?.id??""),o=r?IA(m.current,r):null,i=o?o.rowIndex:0;nA.current={actionId:r,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(n)?n:0,initialEnd:Number.isFinite(t)?t:0,takeover:!0},Ee(),p(null),!wA.current&&(wA.current=structuredClone(d),OA.current=ue(d))},onActionMoveEnd:()=>{const A=nA.current,n=String(A.actionId??""),t=A.laneIntentRowIndex;n&&t!=null&&(Oe.current=!0,c(i=>{const a=T(i,n,t);return m.current=a,a})),p(null);const r=wA.current,o=OA.current;r&&o&&ue(m.current)!==o&&ee(r),wA.current=null,OA.current=null,Ae.current=null,FA.current={actionId:null,edge:null},nA.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:0,committedRowIndex:0,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:0,initialEnd:0,takeover:!1},Ye()},onActionResizeStart:({action:A})=>{Ae.current=String(A?.id??""),FA.current={actionId:String(A?.id??""),edge:null};const n=Number(A?.start),t=Number(A?.end),r=String(A?.id??""),o=r?IA(m.current,r):null,i=o?o.rowIndex:0,a=ve(o?.action??A),u=r?xA(m.current,r):null,C=u?String(u.action.id):null,w=u?ve(u.action):a;uA.current={actionId:r,partnerId:C,dir:null,baseStart:Number.isFinite(n)?n:0,baseOffset:a,partnerBaseOffset:w},nA.current={actionId:r,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(n)?n:0,initialEnd:Number.isFinite(t)?t:0,takeover:!1},Ee(),!wA.current&&(wA.current=structuredClone(d),OA.current=ue(d))},onActionResizeEnd:()=>{const A=wA.current,n=OA.current;A&&n&&ue(m.current)!==n&&ee(A),wA.current=null,OA.current=null,Ae.current=null,FA.current={actionId:null,edge:null},nA.current={actionId:null,mode:null,dir:null,basePointerTime:null,lastPointerTime:null,basePointerClientY:null,lastPointerClientY:null,initialRowIndex:0,committedRowIndex:0,laneCandidateRowIndex:null,laneCandidateSinceMs:0,laneIntentRowIndex:null,initialStart:0,initialEnd:0,takeover:!1},Ye(),uA.current={actionId:null,partnerId:null,dir:null,baseStart:0,baseOffset:0,partnerBaseOffset:0}},onActionMoving:({action:A,row:n,start:t,end:r})=>{const o=String(A?.id??""),i=nA.current,a=(O,N)=>{const h=Number(O),P=Number(N);if(!Number.isFinite(h)||!Number.isFinite(P))return{start:O,end:N,clamped:!1};if(P<=h)return{start:O,end:N,clamped:!1};if(h>=0)return{start:h,end:P,clamped:!1};const J=-h;return{start:0,end:P+J,clamped:!0}},u=O=>{const N=String(O?.id??"");return N?m.current.findIndex(h=>String(h?.id??"")===N):-1};if(i.takeover&&i.mode==="move"&&i.actionId===o){const N=Math.max(10,q*.45),h=i.basePointerTime,P=i.lastPointerTime,J=h!=null&&P!=null?P-h:0,W=i.initialStart+J,_=i.initialEnd+J,oA=pe(o,W,_),k=a(oA.start,oA.end),j=k.start,$=k.end,dA=String(A?.effectId??"")==="effect1"?"video":"audio",ZA=i.lastPointerClientY,Qe=ZA!=null?re(ZA):null,oe=pA(Qe??i.committedRowIndex,dA),we=i.basePointerClientY,Ie=we!=null&&ZA!=null?Math.abs(ZA-we):0,Ke=typeof performance<"u"&&performance.now?performance.now():Date.now();oe!==i.committedRowIndex&&Ie>=N?(i.laneCandidateRowIndex!==oe&&(i.laneCandidateRowIndex=oe,i.laneCandidateSinceMs=Ke),Ke-i.laneCandidateSinceMs>=160&&(i.laneIntentRowIndex=oe)):(i.laneCandidateRowIndex=null,i.laneCandidateSinceMs=0,i.laneIntentRowIndex=null);const je=oe!==i.committedRowIndex&&Ie>=N?oe:null;je!=null?p({actionId:o,laneRow:je,start:j,end:$,duration:Math.max(.01,$-j),kind:dA}):p(null);const $e=m.current,tt=$e[i.committedRowIndex];if(tt&&KA(tt,String(A.id),j,$))return!1;const At=xA($e,String(A.id));if(At){const Te=dA==="video"?QA(pA(i.committedRowIndex,"video")):ge(pA(i.committedRowIndex,"audio")),be=$e[Te];if(be&&KA(be,String(At.action.id),j,$))return!1}return c(Te=>{const be=At?MA(Te,String(A.id),j,$):te(Te,String(A.id),j,$);return m.current=be,be}),!1}const C=Number(t),w=Number(r);if(!Number.isFinite(C)||!Number.isFinite(w)||w<=C)return!1;const I=pe(o,C,w),y=a(I.start,I.end),S=y.start,R=y.end;if(!Number.isFinite(S)||!Number.isFinite(R)||R<=S)return!1;const K=n;if(KA(K,String(A.id),S,R))return!1;const x=m.current,l=xA(x,String(A.id));if(l){const O=String(A?.effectId??""),N=u(K);let h=l.rowIndex;if(N>=0)if(O==="effect1"){const J=pA(N,"video");h=QA(J)}else{const J=pA(N,"audio");h=ge(J)}const P=x[h];if(P&&KA(P,String(l.action.id),S,R))return!1}if((l||I.snapped||y.clamped)&&c(O=>{const N=l?MA(O,String(A.id),S,R):te(O,String(A.id),S,R);return m.current=N,N}),I.snapped||y.clamped){const O=nA.current.lastPointerTime;return nA.current={...nA.current,actionId:o,mode:"move",dir:null,basePointerTime:O,lastPointerTime:nA.current.lastPointerTime,initialStart:C,initialEnd:w,takeover:!0},Ee(),!1}},onActionResizing:({action:A,row:n,start:t,end:r,dir:o})=>{const i=String(A?.id??""),a=nA.current,u=o??"right";if(a.actionId===i&&a.mode==="resize"&&(a.dir=u),uA.current.actionId===i&&(uA.current.dir=u),a.takeover&&a.mode==="resize"&&a.actionId===i){const l=a.basePointerTime,O=a.lastPointerTime,N=l!=null&&O!=null?O-l:0,h=u==="left"?a.initialStart+N:a.initialStart,P=u==="right"?a.initialEnd+N:a.initialEnd,J=Me(i,h,P,u),W=J.start,_=J.end;if(KA(n,String(A.id),W,_))return!1;const k=m.current,j=xA(k,String(A.id));if(j){const $=k[j.rowIndex];if($&&KA($,String(j.action.id),W,_))return!1}return c($=>{let gA=j?MA($,String(A.id),W,_):te($,String(A.id),W,_);if(u==="left"&&uA.current.actionId===String(A.id)){const dA=W-uA.current.baseStart,ZA=uA.current.baseOffset+(Number.isFinite(dA)?dA:0),Qe=uA.current.partnerBaseOffset+(Number.isFinite(dA)?dA:0);gA=j?g(gA,String(A.id),ZA,Qe):e(gA,String(A.id),ZA)}return m.current=gA,gA}),!1}const C=Number(t),w=Number(r);if(!Number.isFinite(C)||!Number.isFinite(w)||w<=C)return!1;const I=Me(i,C,w,u),y=I.start,S=I.end;if(!Number.isFinite(y)||!Number.isFinite(S)||S<=y||KA(n,String(A.id),y,S))return!1;const K=m.current,x=xA(K,String(A.id));if(x){const l=K[x.rowIndex];if(l&&KA(l,String(x.action.id),y,S))return!1}if((x||I.snapped)&&c(l=>{const O=x?MA(l,String(A.id),y,S):te(l,String(A.id),y,S);return m.current=O,O}),I.snapped){const l=nA.current.lastPointerTime;return nA.current={...nA.current,actionId:i,mode:"resize",dir:u,basePointerTime:l,lastPointerTime:nA.current.lastPointerTime,initialStart:C,initialEnd:w,takeover:!0},Ee(),!1}},onChange:A=>{if(Oe.current){Oe.current=!1;return}const n=Z(A),t=Ae.current;let r=t?Re(n,t):n;if(t&&uA.current.actionId===t&&uA.current.dir==="left"){const u=IA(r,t);if(u){const w=Number(u.action?.start)-uA.current.baseStart,I=uA.current.baseOffset+(Number.isFinite(w)?w:0),y=uA.current.partnerBaseOffset+(Number.isFinite(w)?w:0);r=!!uA.current.partnerId?g(r,t,I,y):e(r,t,I)}}const o=xe(r,t);c(o);const i=wA.current,a=OA.current;i&&a&&(ue(o)!==a&&ee(i),wA.current=null,OA.current=null)},getActionRender:(A,n)=>{if(A.effectId==="effect0")return D.jsx(Et,{action:A,row:n});if(A.effectId==="effect2")return D.jsx(wt,{action:A,row:n});if(A.effectId==="effect1")return D.jsx(Qt,{action:A,row:n})}})]}),D.jsx(jA.DragOverlay,{children:cA?D.jsx("div",{className:"footage-overlay",style:TA?{width:TA.width,height:TA.height}:void 0,children:D.jsx(ct,{item:cA,hint:"Drop on timeline",isDragging:!0})}):null})]})})};exports.MeliesVideoEditor=Kt;