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