melies-video-editor 0.1.1 → 0.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,109 +1,109 @@
1
- import Ge, { useState as z, useRef as j, useEffect as Ce, useMemo as Oe, useLayoutEffect as Xe } from "react";
2
- import { Timeline as ke } from "@xzdarcy/react-timeline-editor";
3
- import { Howl as Je, Howler as qe } from "howler";
4
- import { Select as Ye, Button as We } from "antd";
5
- import { useSensors as Ke, useSensor as xe, PointerSensor as ze, TouchSensor as Ve, useDroppable as Ze, DndContext as _e, rectIntersection as $e, DragOverlay as At, useDraggable as et } from "@dnd-kit/core";
6
- var fe = { exports: {} }, Ae = {};
7
- var Re;
8
- function tt() {
9
- if (Re) return Ae;
10
- Re = 1;
11
- var g = Ge, s = /* @__PURE__ */ Symbol.for("react.element"), l = /* @__PURE__ */ Symbol.for("react.fragment"), u = Object.prototype.hasOwnProperty, f = g.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, I = { key: !0, ref: !0, __self: !0, __source: !0 };
12
- function h(v, m, b) {
13
- var y, p = {}, q = null, W = null;
14
- b !== void 0 && (q = "" + b), m.key !== void 0 && (q = "" + m.key), m.ref !== void 0 && (W = m.ref);
15
- for (y in m) u.call(m, y) && !I.hasOwnProperty(y) && (p[y] = m[y]);
16
- if (v && v.defaultProps) for (y in m = v.defaultProps, m) p[y] === void 0 && (p[y] = m[y]);
17
- return { $$typeof: s, type: v, key: q, ref: W, props: p, _owner: f.current };
1
+ import lt, { useState as cA, useRef as tA, useEffect as Ee, useMemo as We, useLayoutEffect as Rt } from "react";
2
+ import { Timeline as Ot } from "@xzdarcy/react-timeline-editor";
3
+ import { Howl as bt, Howler as St } from "howler";
4
+ import { Select as dt, Button as Ht } from "antd";
5
+ import { useSensors as yt, useSensor as rt, PointerSensor as Nt, TouchSensor as Ut, useDroppable as Pt, DndContext as xt, rectIntersection as Mt, DragOverlay as kt, useDraggable as Jt } from "@dnd-kit/core";
6
+ var Xe = { exports: {} }, Ne = {};
7
+ var it;
8
+ function Lt() {
9
+ if (it) return Ne;
10
+ it = 1;
11
+ var B = lt, o = /* @__PURE__ */ Symbol.for("react.element"), d = /* @__PURE__ */ Symbol.for("react.fragment"), c = Object.prototype.hasOwnProperty, l = B.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, E = { key: !0, ref: !0, __self: !0, __source: !0 };
12
+ function m(O, S, G) {
13
+ var M, z = {}, F = null, BA = null;
14
+ G !== void 0 && (F = "" + G), S.key !== void 0 && (F = "" + S.key), S.ref !== void 0 && (BA = S.ref);
15
+ for (M in S) c.call(S, M) && !E.hasOwnProperty(M) && (z[M] = S[M]);
16
+ if (O && O.defaultProps) for (M in S = O.defaultProps, S) z[M] === void 0 && (z[M] = S[M]);
17
+ return { $$typeof: o, type: O, key: F, ref: BA, props: z, _owner: l.current };
18
18
  }
19
- return Ae.Fragment = l, Ae.jsx = h, Ae.jsxs = h, Ae;
19
+ return Ne.Fragment = d, Ne.jsx = m, Ne.jsxs = m, Ne;
20
20
  }
21
- var ee = {};
22
- var Se;
23
- function nt() {
24
- return Se || (Se = 1, process.env.NODE_ENV !== "production" && (function() {
25
- var g = Ge, s = /* @__PURE__ */ Symbol.for("react.element"), l = /* @__PURE__ */ Symbol.for("react.portal"), u = /* @__PURE__ */ Symbol.for("react.fragment"), f = /* @__PURE__ */ Symbol.for("react.strict_mode"), I = /* @__PURE__ */ Symbol.for("react.profiler"), h = /* @__PURE__ */ Symbol.for("react.provider"), v = /* @__PURE__ */ Symbol.for("react.context"), m = /* @__PURE__ */ Symbol.for("react.forward_ref"), b = /* @__PURE__ */ Symbol.for("react.suspense"), y = /* @__PURE__ */ Symbol.for("react.suspense_list"), p = /* @__PURE__ */ Symbol.for("react.memo"), q = /* @__PURE__ */ Symbol.for("react.lazy"), W = /* @__PURE__ */ Symbol.for("react.offscreen"), uA = Symbol.iterator, K = "@@iterator";
26
- function L(e) {
21
+ var Ue = {};
22
+ var ot;
23
+ function Gt() {
24
+ return ot || (ot = 1, process.env.NODE_ENV !== "production" && (function() {
25
+ var B = lt, o = /* @__PURE__ */ Symbol.for("react.element"), d = /* @__PURE__ */ Symbol.for("react.portal"), c = /* @__PURE__ */ Symbol.for("react.fragment"), l = /* @__PURE__ */ Symbol.for("react.strict_mode"), E = /* @__PURE__ */ Symbol.for("react.profiler"), m = /* @__PURE__ */ Symbol.for("react.provider"), O = /* @__PURE__ */ Symbol.for("react.context"), S = /* @__PURE__ */ Symbol.for("react.forward_ref"), G = /* @__PURE__ */ Symbol.for("react.suspense"), M = /* @__PURE__ */ Symbol.for("react.suspense_list"), z = /* @__PURE__ */ Symbol.for("react.memo"), F = /* @__PURE__ */ Symbol.for("react.lazy"), BA = /* @__PURE__ */ Symbol.for("react.offscreen"), iA = Symbol.iterator, lA = "@@iterator";
26
+ function oA(e) {
27
27
  if (e === null || typeof e != "object")
28
28
  return null;
29
- var c = uA && e[uA] || e[K];
30
- return typeof c == "function" ? c : null;
29
+ var g = iA && e[iA] || e[lA];
30
+ return typeof g == "function" ? g : null;
31
31
  }
32
- var Z = g.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;
33
- function S(e) {
32
+ var kA = B.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;
33
+ function AA(e) {
34
34
  {
35
- for (var c = arguments.length, A = new Array(c > 1 ? c - 1 : 0), t = 1; t < c; t++)
36
- A[t - 1] = arguments[t];
37
- BA("error", e, A);
35
+ for (var g = arguments.length, Q = new Array(g > 1 ? g - 1 : 0), v = 1; v < g; v++)
36
+ Q[v - 1] = arguments[v];
37
+ Qe("error", e, Q);
38
38
  }
39
39
  }
40
- function BA(e, c, A) {
40
+ function Qe(e, g, Q) {
41
41
  {
42
- var t = Z.ReactDebugCurrentFrame, n = t.getStackAddendum();
43
- n !== "" && (c += "%s", A = A.concat([n]));
44
- var o = A.map(function(r) {
45
- return String(r);
42
+ var v = kA.ReactDebugCurrentFrame, j = v.getStackAddendum();
43
+ j !== "" && (g += "%s", Q = Q.concat([j]));
44
+ var W = Q.map(function(k) {
45
+ return String(k);
46
46
  });
47
- o.unshift("Warning: " + c), Function.prototype.apply.call(console[e], console, o);
47
+ W.unshift("Warning: " + g), Function.prototype.apply.call(console[e], console, W);
48
48
  }
49
49
  }
50
- var CA = !1, iA = !1, lA = !1, ie = !1, FA = !1, yA;
51
- yA = /* @__PURE__ */ Symbol.for("react.module.reference");
52
- function JA(e) {
53
- return !!(typeof e == "string" || typeof e == "function" || e === u || e === I || FA || e === f || e === b || e === y || ie || e === W || CA || iA || lA || typeof e == "object" && e !== null && (e.$$typeof === q || e.$$typeof === p || e.$$typeof === h || e.$$typeof === v || e.$$typeof === m || // This needs to include all possible module reference object
50
+ var ie = !1, oe = !1, se = !1, ae = !1, ce = !1, JA;
51
+ JA = /* @__PURE__ */ Symbol.for("react.module.reference");
52
+ function dA(e) {
53
+ return !!(typeof e == "string" || typeof e == "function" || e === c || e === E || ce || e === l || e === G || e === M || ae || e === BA || ie || oe || se || typeof e == "object" && e !== null && (e.$$typeof === F || e.$$typeof === z || e.$$typeof === m || e.$$typeof === O || e.$$typeof === S || // This needs to include all possible module reference object
54
54
  // types supported by any Flight configuration anywhere since
55
55
  // we don't know which Flight build this will end up being used
56
56
  // with.
57
- e.$$typeof === yA || e.getModuleId !== void 0));
57
+ e.$$typeof === JA || e.getModuleId !== void 0));
58
58
  }
59
- function qA(e, c, A) {
60
- var t = e.displayName;
61
- if (t)
62
- return t;
63
- var n = c.displayName || c.name || "";
64
- return n !== "" ? A + "(" + n + ")" : A;
59
+ function WA(e, g, Q) {
60
+ var v = e.displayName;
61
+ if (v)
62
+ return v;
63
+ var j = g.displayName || g.name || "";
64
+ return j !== "" ? Q + "(" + j + ")" : Q;
65
65
  }
66
- function SA(e) {
66
+ function LA(e) {
67
67
  return e.displayName || "Context";
68
68
  }
69
- function oA(e) {
69
+ function QA(e) {
70
70
  if (e == null)
71
71
  return null;
72
- if (typeof e.tag == "number" && S("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."), typeof e == "function")
72
+ if (typeof e.tag == "number" && AA("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."), typeof e == "function")
73
73
  return e.displayName || e.name || null;
74
74
  if (typeof e == "string")
75
75
  return e;
76
76
  switch (e) {
77
- case u:
77
+ case c:
78
78
  return "Fragment";
79
- case l:
79
+ case d:
80
80
  return "Portal";
81
- case I:
81
+ case E:
82
82
  return "Profiler";
83
- case f:
83
+ case l:
84
84
  return "StrictMode";
85
- case b:
85
+ case G:
86
86
  return "Suspense";
87
- case y:
87
+ case M:
88
88
  return "SuspenseList";
89
89
  }
90
90
  if (typeof e == "object")
91
91
  switch (e.$$typeof) {
92
- case v:
93
- var c = e;
94
- return SA(c) + ".Consumer";
95
- case h:
96
- var A = e;
97
- return SA(A._context) + ".Provider";
92
+ case O:
93
+ var g = e;
94
+ return LA(g) + ".Consumer";
98
95
  case m:
99
- return qA(e, e.render, "ForwardRef");
100
- case p:
101
- var t = e.displayName || null;
102
- return t !== null ? t : oA(e.type) || "Memo";
103
- case q: {
104
- var n = e, o = n._payload, r = n._init;
96
+ var Q = e;
97
+ return LA(Q._context) + ".Provider";
98
+ case S:
99
+ return WA(e, e.render, "ForwardRef");
100
+ case z:
101
+ var v = e.displayName || null;
102
+ return v !== null ? v : QA(e.type) || "Memo";
103
+ case F: {
104
+ var j = e, W = j._payload, k = j._init;
105
105
  try {
106
- return oA(r(o));
106
+ return QA(k(W));
107
107
  } catch {
108
108
  return null;
109
109
  }
@@ -111,18 +111,18 @@ function nt() {
111
111
  }
112
112
  return null;
113
113
  }
114
- var sA = Object.assign, eA = 0, UA, wA, w, x, R, P, H;
115
- function U() {
114
+ var pA = Object.assign, wA = 0, TA, we, VA, Ie, ZA, y, nA;
115
+ function rA() {
116
116
  }
117
- U.__reactDisabledLog = !0;
118
- function k() {
117
+ rA.__reactDisabledLog = !0;
118
+ function Z() {
119
119
  {
120
- if (eA === 0) {
121
- UA = console.log, wA = console.info, w = console.warn, x = console.error, R = console.group, P = console.groupCollapsed, H = console.groupEnd;
120
+ if (wA === 0) {
121
+ TA = console.log, we = console.info, VA = console.warn, Ie = console.error, ZA = console.group, y = console.groupCollapsed, nA = console.groupEnd;
122
122
  var e = {
123
123
  configurable: !0,
124
124
  enumerable: !0,
125
- value: U,
125
+ value: rA,
126
126
  writable: !0
127
127
  };
128
128
  Object.defineProperties(console, {
@@ -135,332 +135,332 @@ function nt() {
135
135
  groupEnd: e
136
136
  });
137
137
  }
138
- eA++;
138
+ wA++;
139
139
  }
140
140
  }
141
- function IA() {
141
+ function _() {
142
142
  {
143
- if (eA--, eA === 0) {
143
+ if (wA--, wA === 0) {
144
144
  var e = {
145
145
  configurable: !0,
146
146
  enumerable: !0,
147
147
  writable: !0
148
148
  };
149
149
  Object.defineProperties(console, {
150
- log: sA({}, e, {
151
- value: UA
150
+ log: pA({}, e, {
151
+ value: TA
152
152
  }),
153
- info: sA({}, e, {
154
- value: wA
153
+ info: pA({}, e, {
154
+ value: we
155
155
  }),
156
- warn: sA({}, e, {
157
- value: w
156
+ warn: pA({}, e, {
157
+ value: VA
158
158
  }),
159
- error: sA({}, e, {
160
- value: x
159
+ error: pA({}, e, {
160
+ value: Ie
161
161
  }),
162
- group: sA({}, e, {
163
- value: R
162
+ group: pA({}, e, {
163
+ value: ZA
164
164
  }),
165
- groupCollapsed: sA({}, e, {
166
- value: P
165
+ groupCollapsed: pA({}, e, {
166
+ value: y
167
167
  }),
168
- groupEnd: sA({}, e, {
169
- value: H
168
+ groupEnd: pA({}, e, {
169
+ value: nA
170
170
  })
171
171
  });
172
172
  }
173
- eA < 0 && S("disabledDepth fell below zero. This is a bug in React. Please file an issue.");
173
+ wA < 0 && AA("disabledDepth fell below zero. This is a bug in React. Please file an issue.");
174
174
  }
175
175
  }
176
- var dA = Z.ReactCurrentDispatcher, aA;
177
- function NA(e, c, A) {
176
+ var sA = kA.ReactCurrentDispatcher, gA;
177
+ function IA(e, g, Q) {
178
178
  {
179
- if (aA === void 0)
179
+ if (gA === void 0)
180
180
  try {
181
181
  throw Error();
182
- } catch (n) {
183
- var t = n.stack.trim().match(/\n( *(at )?)/);
184
- aA = t && t[1] || "";
182
+ } catch (j) {
183
+ var v = j.stack.trim().match(/\n( *(at )?)/);
184
+ gA = v && v[1] || "";
185
185
  }
186
186
  return `
187
- ` + aA + e;
187
+ ` + gA + e;
188
188
  }
189
189
  }
190
- var GA = !1, WA;
190
+ var GA = !1, UA;
191
191
  {
192
- var fA = typeof WeakMap == "function" ? WeakMap : Map;
193
- WA = new fA();
192
+ var _A = typeof WeakMap == "function" ? WeakMap : Map;
193
+ UA = new _A();
194
194
  }
195
- function V(e, c) {
195
+ function bA(e, g) {
196
196
  if (!e || GA)
197
197
  return "";
198
198
  {
199
- var A = WA.get(e);
200
- if (A !== void 0)
201
- return A;
199
+ var Q = UA.get(e);
200
+ if (Q !== void 0)
201
+ return Q;
202
202
  }
203
- var t;
203
+ var v;
204
204
  GA = !0;
205
- var n = Error.prepareStackTrace;
205
+ var j = Error.prepareStackTrace;
206
206
  Error.prepareStackTrace = void 0;
207
- var o;
208
- o = dA.current, dA.current = null, k();
207
+ var W;
208
+ W = sA.current, sA.current = null, Z();
209
209
  try {
210
- if (c) {
211
- var r = function() {
210
+ if (g) {
211
+ var k = function() {
212
212
  throw Error();
213
213
  };
214
- if (Object.defineProperty(r.prototype, "props", {
214
+ if (Object.defineProperty(k.prototype, "props", {
215
215
  set: function() {
216
216
  throw Error();
217
217
  }
218
218
  }), typeof Reflect == "object" && Reflect.construct) {
219
219
  try {
220
- Reflect.construct(r, []);
221
- } catch (D) {
222
- t = D;
220
+ Reflect.construct(k, []);
221
+ } catch (FA) {
222
+ v = FA;
223
223
  }
224
- Reflect.construct(e, [], r);
224
+ Reflect.construct(e, [], k);
225
225
  } else {
226
226
  try {
227
- r.call();
228
- } catch (D) {
229
- t = D;
227
+ k.call();
228
+ } catch (FA) {
229
+ v = FA;
230
230
  }
231
- e.call(r.prototype);
231
+ e.call(k.prototype);
232
232
  }
233
233
  } else {
234
234
  try {
235
235
  throw Error();
236
- } catch (D) {
237
- t = D;
236
+ } catch (FA) {
237
+ v = FA;
238
238
  }
239
239
  e();
240
240
  }
241
- } catch (D) {
242
- if (D && t && typeof D.stack == "string") {
243
- for (var i = D.stack.split(`
244
- `), a = t.stack.split(`
245
- `), B = i.length - 1, d = a.length - 1; B >= 1 && d >= 0 && i[B] !== a[d]; )
246
- d--;
247
- for (; B >= 1 && d >= 0; B--, d--)
248
- if (i[B] !== a[d]) {
249
- if (B !== 1 || d !== 1)
241
+ } catch (FA) {
242
+ if (FA && v && typeof FA.stack == "string") {
243
+ for (var P = FA.stack.split(`
244
+ `), fA = v.stack.split(`
245
+ `), X = P.length - 1, eA = fA.length - 1; X >= 1 && eA >= 0 && P[X] !== fA[eA]; )
246
+ eA--;
247
+ for (; X >= 1 && eA >= 0; X--, eA--)
248
+ if (P[X] !== fA[eA]) {
249
+ if (X !== 1 || eA !== 1)
250
250
  do
251
- if (B--, d--, d < 0 || i[B] !== a[d]) {
252
- var Q = `
253
- ` + i[B].replace(" at new ", " at ");
254
- return e.displayName && Q.includes("<anonymous>") && (Q = Q.replace("<anonymous>", e.displayName)), typeof e == "function" && WA.set(e, Q), Q;
251
+ if (X--, eA--, eA < 0 || P[X] !== fA[eA]) {
252
+ var OA = `
253
+ ` + P[X].replace(" at new ", " at ");
254
+ return e.displayName && OA.includes("<anonymous>") && (OA = OA.replace("<anonymous>", e.displayName)), typeof e == "function" && UA.set(e, OA), OA;
255
255
  }
256
- while (B >= 1 && d >= 0);
256
+ while (X >= 1 && eA >= 0);
257
257
  break;
258
258
  }
259
259
  }
260
260
  } finally {
261
- GA = !1, dA.current = o, IA(), Error.prepareStackTrace = n;
261
+ GA = !1, sA.current = W, _(), Error.prepareStackTrace = j;
262
262
  }
263
- var C = e ? e.displayName || e.name : "", F = C ? NA(C) : "";
264
- return typeof e == "function" && WA.set(e, F), F;
263
+ var ne = e ? e.displayName || e.name : "", XA = ne ? IA(ne) : "";
264
+ return typeof e == "function" && UA.set(e, XA), XA;
265
265
  }
266
- function tA(e, c, A) {
267
- return V(e, !1);
266
+ function De(e, g, Q) {
267
+ return bA(e, !1);
268
268
  }
269
- function YA(e) {
270
- var c = e.prototype;
271
- return !!(c && c.isReactComponent);
269
+ function $A(e) {
270
+ var g = e.prototype;
271
+ return !!(g && g.isReactComponent);
272
272
  }
273
- function TA(e, c, A) {
273
+ function he(e, g, Q) {
274
274
  if (e == null)
275
275
  return "";
276
276
  if (typeof e == "function")
277
- return V(e, YA(e));
277
+ return bA(e, $A(e));
278
278
  if (typeof e == "string")
279
- return NA(e);
279
+ return IA(e);
280
280
  switch (e) {
281
- case b:
282
- return NA("Suspense");
283
- case y:
284
- return NA("SuspenseList");
281
+ case G:
282
+ return IA("Suspense");
283
+ case M:
284
+ return IA("SuspenseList");
285
285
  }
286
286
  if (typeof e == "object")
287
287
  switch (e.$$typeof) {
288
- case m:
289
- return tA(e.render);
290
- case p:
291
- return TA(e.type, c, A);
292
- case q: {
293
- var t = e, n = t._payload, o = t._init;
288
+ case S:
289
+ return De(e.render);
290
+ case z:
291
+ return he(e.type, g, Q);
292
+ case F: {
293
+ var v = e, j = v._payload, W = v._init;
294
294
  try {
295
- return TA(o(n), c, A);
295
+ return he(W(j), g, Q);
296
296
  } catch {
297
297
  }
298
298
  }
299
299
  }
300
300
  return "";
301
301
  }
302
- var MA = Object.prototype.hasOwnProperty, _ = {}, X = Z.ReactDebugCurrentFrame;
303
- function PA(e) {
302
+ var PA = Object.prototype.hasOwnProperty, Oe = {}, CA = kA.ReactDebugCurrentFrame;
303
+ function xA(e) {
304
304
  if (e) {
305
- var c = e._owner, A = TA(e.type, e._source, c ? c.type : null);
306
- X.setExtraStackFrame(A);
305
+ var g = e._owner, Q = he(e.type, e._source, g ? g.type : null);
306
+ CA.setExtraStackFrame(Q);
307
307
  } else
308
- X.setExtraStackFrame(null);
308
+ CA.setExtraStackFrame(null);
309
309
  }
310
- function LA(e, c, A, t, n) {
310
+ function Pe(e, g, Q, v, j) {
311
311
  {
312
- var o = Function.call.bind(MA);
313
- for (var r in e)
314
- if (o(e, r)) {
315
- var i = void 0;
312
+ var W = Function.call.bind(PA);
313
+ for (var k in e)
314
+ if (W(e, k)) {
315
+ var P = void 0;
316
316
  try {
317
- if (typeof e[r] != "function") {
318
- var a = Error((t || "React class") + ": " + A + " type `" + r + "` is invalid; it must be a function, usually from the `prop-types` package, but received `" + typeof e[r] + "`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");
319
- throw a.name = "Invariant Violation", a;
317
+ if (typeof e[k] != "function") {
318
+ var fA = Error((v || "React class") + ": " + Q + " type `" + k + "` is invalid; it must be a function, usually from the `prop-types` package, but received `" + typeof e[k] + "`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");
319
+ throw fA.name = "Invariant Violation", fA;
320
320
  }
321
- i = e[r](c, r, t, A, null, "SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED");
322
- } catch (B) {
323
- i = B;
321
+ P = e[k](g, k, v, Q, null, "SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED");
322
+ } catch (X) {
323
+ P = X;
324
324
  }
325
- i && !(i instanceof Error) && (PA(n), S("%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).", t || "React class", A, r, typeof i), PA(null)), i instanceof Error && !(i.message in _) && (_[i.message] = !0, PA(n), S("Failed %s type: %s", A, i.message), PA(null));
325
+ P && !(P instanceof Error) && (xA(j), AA("%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).", v || "React class", Q, k, typeof P), xA(null)), P instanceof Error && !(P.message in Oe) && (Oe[P.message] = !0, xA(j), AA("Failed %s type: %s", Q, P.message), xA(null));
326
326
  }
327
327
  }
328
328
  }
329
- var HA = Array.isArray;
330
- function jA(e) {
331
- return HA(e);
329
+ var ge = Array.isArray;
330
+ function Ae(e) {
331
+ return ge(e);
332
332
  }
333
- function QA(e) {
333
+ function YA(e) {
334
334
  {
335
- var c = typeof Symbol == "function" && Symbol.toStringTag, A = c && e[Symbol.toStringTag] || e.constructor.name || "Object";
336
- return A;
335
+ var g = typeof Symbol == "function" && Symbol.toStringTag, Q = g && e[Symbol.toStringTag] || e.constructor.name || "Object";
336
+ return Q;
337
337
  }
338
338
  }
339
- function KA(e) {
339
+ function me(e) {
340
340
  try {
341
- return DA(e), !1;
341
+ return SA(e), !1;
342
342
  } catch {
343
343
  return !0;
344
344
  }
345
345
  }
346
- function DA(e) {
346
+ function SA(e) {
347
347
  return "" + e;
348
348
  }
349
- function oe(e) {
350
- if (KA(e))
351
- return S("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.", QA(e)), DA(e);
349
+ function be(e) {
350
+ if (me(e))
351
+ return AA("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.", YA(e)), SA(e);
352
352
  }
353
- var XA = Z.ReactCurrentOwner, zA = {
353
+ var Fe = kA.ReactCurrentOwner, qe = {
354
354
  key: !0,
355
355
  ref: !0,
356
356
  __self: !0,
357
357
  __source: !0
358
- }, ZA, _A;
359
- function se(e) {
360
- if (MA.call(e, "ref")) {
361
- var c = Object.getOwnPropertyDescriptor(e, "ref").get;
362
- if (c && c.isReactWarning)
358
+ }, vA, DA;
359
+ function HA(e) {
360
+ if (PA.call(e, "ref")) {
361
+ var g = Object.getOwnPropertyDescriptor(e, "ref").get;
362
+ if (g && g.isReactWarning)
363
363
  return !1;
364
364
  }
365
365
  return e.ref !== void 0;
366
366
  }
367
- function we(e) {
368
- if (MA.call(e, "key")) {
369
- var c = Object.getOwnPropertyDescriptor(e, "key").get;
370
- if (c && c.isReactWarning)
367
+ function Be(e) {
368
+ if (PA.call(e, "key")) {
369
+ var g = Object.getOwnPropertyDescriptor(e, "key").get;
370
+ if (g && g.isReactWarning)
371
371
  return !1;
372
372
  }
373
373
  return e.key !== void 0;
374
374
  }
375
- function Ie(e, c) {
376
- typeof e.ref == "string" && XA.current;
375
+ function xe(e, g) {
376
+ typeof e.ref == "string" && Fe.current;
377
377
  }
378
- function De(e, c) {
378
+ function Me(e, g) {
379
379
  {
380
- var A = function() {
381
- ZA || (ZA = !0, S("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", c));
380
+ var Q = function() {
381
+ vA || (vA = !0, AA("%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));
382
382
  };
383
- A.isReactWarning = !0, Object.defineProperty(e, "key", {
384
- get: A,
383
+ Q.isReactWarning = !0, Object.defineProperty(e, "key", {
384
+ get: Q,
385
385
  configurable: !0
386
386
  });
387
387
  }
388
388
  }
389
- function kA(e, c) {
389
+ function RA(e, g) {
390
390
  {
391
- var A = function() {
392
- _A || (_A = !0, S("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", c));
391
+ var Q = function() {
392
+ DA || (DA = !0, AA("%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));
393
393
  };
394
- A.isReactWarning = !0, Object.defineProperty(e, "ref", {
395
- get: A,
394
+ Q.isReactWarning = !0, Object.defineProperty(e, "ref", {
395
+ get: Q,
396
396
  configurable: !0
397
397
  });
398
398
  }
399
399
  }
400
- var he = function(e, c, A, t, n, o, r) {
401
- var i = {
400
+ var $ = function(e, g, Q, v, j, W, k) {
401
+ var P = {
402
402
  // This tag allows us to uniquely identify this as a React Element
403
- $$typeof: s,
403
+ $$typeof: o,
404
404
  // Built-in properties that belong on the element
405
405
  type: e,
406
- key: c,
407
- ref: A,
408
- props: r,
406
+ key: g,
407
+ ref: Q,
408
+ props: k,
409
409
  // Record the component responsible for creating this element.
410
- _owner: o
410
+ _owner: W
411
411
  };
412
- return i._store = {}, Object.defineProperty(i._store, "validated", {
412
+ return P._store = {}, Object.defineProperty(P._store, "validated", {
413
413
  configurable: !1,
414
414
  enumerable: !1,
415
415
  writable: !0,
416
416
  value: !1
417
- }), Object.defineProperty(i, "_self", {
417
+ }), Object.defineProperty(P, "_self", {
418
418
  configurable: !1,
419
419
  enumerable: !1,
420
420
  writable: !1,
421
- value: t
422
- }), Object.defineProperty(i, "_source", {
421
+ value: v
422
+ }), Object.defineProperty(P, "_source", {
423
423
  configurable: !1,
424
424
  enumerable: !1,
425
425
  writable: !1,
426
- value: n
427
- }), Object.freeze && (Object.freeze(i.props), Object.freeze(i)), i;
426
+ value: j
427
+ }), Object.freeze && (Object.freeze(P.props), Object.freeze(P)), P;
428
428
  };
429
- function me(e, c, A, t, n) {
429
+ function hA(e, g, Q, v, j) {
430
430
  {
431
- var o, r = {}, i = null, a = null;
432
- A !== void 0 && (oe(A), i = "" + A), we(c) && (oe(c.key), i = "" + c.key), se(c) && (a = c.ref, Ie(c, n));
433
- for (o in c)
434
- MA.call(c, o) && !zA.hasOwnProperty(o) && (r[o] = c[o]);
431
+ var W, k = {}, P = null, fA = null;
432
+ Q !== void 0 && (be(Q), P = "" + Q), Be(g) && (be(g.key), P = "" + g.key), HA(g) && (fA = g.ref, xe(g, j));
433
+ for (W in g)
434
+ PA.call(g, W) && !qe.hasOwnProperty(W) && (k[W] = g[W]);
435
435
  if (e && e.defaultProps) {
436
- var B = e.defaultProps;
437
- for (o in B)
438
- r[o] === void 0 && (r[o] = B[o]);
436
+ var X = e.defaultProps;
437
+ for (W in X)
438
+ k[W] === void 0 && (k[W] = X[W]);
439
439
  }
440
- if (i || a) {
441
- var d = typeof e == "function" ? e.displayName || e.name || "Unknown" : e;
442
- i && De(r, d), a && kA(r, d);
440
+ if (P || fA) {
441
+ var eA = typeof e == "function" ? e.displayName || e.name || "Unknown" : e;
442
+ P && Me(k, eA), fA && RA(k, eA);
443
443
  }
444
- return he(e, i, a, n, t, XA.current, r);
444
+ return $(e, P, fA, j, v, Fe.current, k);
445
445
  }
446
446
  }
447
- var OA = Z.ReactCurrentOwner, ae = Z.ReactDebugCurrentFrame;
448
- function cA(e) {
447
+ var ue = kA.ReactCurrentOwner, ee = kA.ReactDebugCurrentFrame;
448
+ function yA(e) {
449
449
  if (e) {
450
- var c = e._owner, A = TA(e.type, e._source, c ? c.type : null);
451
- ae.setExtraStackFrame(A);
450
+ var g = e._owner, Q = he(e.type, e._source, g ? g.type : null);
451
+ ee.setExtraStackFrame(Q);
452
452
  } else
453
- ae.setExtraStackFrame(null);
453
+ ee.setExtraStackFrame(null);
454
454
  }
455
- var VA;
456
- VA = !1;
457
- function $A(e) {
458
- return typeof e == "object" && e !== null && e.$$typeof === s;
455
+ var te;
456
+ te = !1;
457
+ function MA(e) {
458
+ return typeof e == "object" && e !== null && e.$$typeof === o;
459
459
  }
460
- function ce() {
460
+ function mA() {
461
461
  {
462
- if (OA.current) {
463
- var e = oA(OA.current.type);
462
+ if (ue.current) {
463
+ var e = QA(ue.current.type);
464
464
  if (e)
465
465
  return `
466
466
 
@@ -469,225 +469,285 @@ Check the render method of \`` + e + "`.";
469
469
  return "";
470
470
  }
471
471
  }
472
- function ve(e) {
472
+ function KA(e) {
473
473
  return "";
474
474
  }
475
- var ge = {};
476
- function be(e) {
475
+ var ke = {};
476
+ function Ve(e) {
477
477
  {
478
- var c = ce();
479
- if (!c) {
480
- var A = typeof e == "string" ? e : e.displayName || e.name;
481
- A && (c = `
478
+ var g = mA();
479
+ if (!g) {
480
+ var Q = typeof e == "string" ? e : e.displayName || e.name;
481
+ Q && (g = `
482
482
 
483
- Check the top-level render call using <` + A + ">.");
483
+ Check the top-level render call using <` + Q + ">.");
484
484
  }
485
- return c;
485
+ return g;
486
486
  }
487
487
  }
488
- function ue(e, c) {
488
+ function le(e, g) {
489
489
  {
490
490
  if (!e._store || e._store.validated || e.key != null)
491
491
  return;
492
492
  e._store.validated = !0;
493
- var A = be(c);
494
- if (ge[A])
493
+ var Q = Ve(g);
494
+ if (ke[Q])
495
495
  return;
496
- ge[A] = !0;
497
- var t = "";
498
- e && e._owner && e._owner !== OA.current && (t = " It was passed a child from " + oA(e._owner.type) + "."), cA(e), S('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.', A, t), cA(null);
496
+ ke[Q] = !0;
497
+ var v = "";
498
+ e && e._owner && e._owner !== ue.current && (v = " It was passed a child from " + QA(e._owner.type) + "."), yA(e), AA('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.', Q, v), yA(null);
499
499
  }
500
500
  }
501
- function Be(e, c) {
501
+ function de(e, g) {
502
502
  {
503
503
  if (typeof e != "object")
504
504
  return;
505
- if (jA(e))
506
- for (var A = 0; A < e.length; A++) {
507
- var t = e[A];
508
- $A(t) && ue(t, c);
505
+ if (Ae(e))
506
+ for (var Q = 0; Q < e.length; Q++) {
507
+ var v = e[Q];
508
+ MA(v) && le(v, g);
509
509
  }
510
- else if ($A(e))
510
+ else if (MA(e))
511
511
  e._store && (e._store.validated = !0);
512
512
  else if (e) {
513
- var n = L(e);
514
- if (typeof n == "function" && n !== e.entries)
515
- for (var o = n.call(e), r; !(r = o.next()).done; )
516
- $A(r.value) && ue(r.value, c);
513
+ var j = oA(e);
514
+ if (typeof j == "function" && j !== e.entries)
515
+ for (var W = j.call(e), k; !(k = W.next()).done; )
516
+ MA(k.value) && le(k.value, g);
517
517
  }
518
518
  }
519
519
  }
520
- function pe(e) {
520
+ function Je(e) {
521
521
  {
522
- var c = e.type;
523
- if (c == null || typeof c == "string")
522
+ var g = e.type;
523
+ if (g == null || typeof g == "string")
524
524
  return;
525
- var A;
526
- if (typeof c == "function")
527
- A = c.propTypes;
528
- else if (typeof c == "object" && (c.$$typeof === m || // Note: Memo only checks outer props here.
525
+ var Q;
526
+ if (typeof g == "function")
527
+ Q = g.propTypes;
528
+ else if (typeof g == "object" && (g.$$typeof === S || // Note: Memo only checks outer props here.
529
529
  // Inner props are checked in the reconciler.
530
- c.$$typeof === p))
531
- A = c.propTypes;
530
+ g.$$typeof === z))
531
+ Q = g.propTypes;
532
532
  else
533
533
  return;
534
- if (A) {
535
- var t = oA(c);
536
- LA(A, e.props, "prop", t, e);
537
- } else if (c.PropTypes !== void 0 && !VA) {
538
- VA = !0;
539
- var n = oA(c);
540
- S("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?", n || "Unknown");
534
+ if (Q) {
535
+ var v = QA(g);
536
+ Pe(Q, e.props, "prop", v, e);
537
+ } else if (g.PropTypes !== void 0 && !te) {
538
+ te = !0;
539
+ var j = QA(g);
540
+ AA("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?", j || "Unknown");
541
541
  }
542
- typeof c.getDefaultProps == "function" && !c.getDefaultProps.isReactClassApproved && S("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.");
542
+ typeof g.getDefaultProps == "function" && !g.getDefaultProps.isReactClassApproved && AA("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.");
543
543
  }
544
544
  }
545
- function Fe(e) {
545
+ function Le(e) {
546
546
  {
547
- for (var c = Object.keys(e.props), A = 0; A < c.length; A++) {
548
- var t = c[A];
549
- if (t !== "children" && t !== "key") {
550
- cA(e), S("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.", t), cA(null);
547
+ for (var g = Object.keys(e.props), Q = 0; Q < g.length; Q++) {
548
+ var v = g[Q];
549
+ if (v !== "children" && v !== "key") {
550
+ yA(e), AA("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.", v), yA(null);
551
551
  break;
552
552
  }
553
553
  }
554
- e.ref !== null && (cA(e), S("Invalid attribute `ref` supplied to `React.Fragment`."), cA(null));
554
+ e.ref !== null && (yA(e), AA("Invalid attribute `ref` supplied to `React.Fragment`."), yA(null));
555
555
  }
556
556
  }
557
- var le = {};
558
- function de(e, c, A, t, n, o) {
557
+ var Se = {};
558
+ function Ge(e, g, Q, v, j, W) {
559
559
  {
560
- var r = JA(e);
561
- if (!r) {
562
- var i = "";
563
- (e === void 0 || typeof e == "object" && e !== null && Object.keys(e).length === 0) && (i += " You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.");
564
- var a = ve();
565
- a ? i += a : i += ce();
566
- var B;
567
- e === null ? B = "null" : jA(e) ? B = "array" : e !== void 0 && e.$$typeof === s ? (B = "<" + (oA(e.type) || "Unknown") + " />", i = " Did you accidentally export a JSX literal instead of a component?") : B = typeof e, S("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s", B, i);
560
+ var k = dA(e);
561
+ if (!k) {
562
+ var P = "";
563
+ (e === void 0 || typeof e == "object" && e !== null && Object.keys(e).length === 0) && (P += " You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.");
564
+ var fA = KA();
565
+ fA ? P += fA : P += mA();
566
+ var X;
567
+ e === null ? X = "null" : Ae(e) ? X = "array" : e !== void 0 && e.$$typeof === o ? (X = "<" + (QA(e.type) || "Unknown") + " />", P = " Did you accidentally export a JSX literal instead of a component?") : X = typeof e, AA("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s", X, P);
568
568
  }
569
- var d = me(e, c, A, n, o);
570
- if (d == null)
571
- return d;
572
- if (r) {
573
- var Q = c.children;
574
- if (Q !== void 0)
575
- if (t)
576
- if (jA(Q)) {
577
- for (var C = 0; C < Q.length; C++)
578
- Be(Q[C], e);
579
- Object.freeze && Object.freeze(Q);
569
+ var eA = hA(e, g, Q, j, W);
570
+ if (eA == null)
571
+ return eA;
572
+ if (k) {
573
+ var OA = g.children;
574
+ if (OA !== void 0)
575
+ if (v)
576
+ if (Ae(OA)) {
577
+ for (var ne = 0; ne < OA.length; ne++)
578
+ de(OA[ne], e);
579
+ Object.freeze && Object.freeze(OA);
580
580
  } else
581
- S("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");
581
+ AA("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");
582
582
  else
583
- Be(Q, e);
583
+ de(OA, e);
584
584
  }
585
- if (MA.call(c, "key")) {
586
- var F = oA(e), D = Object.keys(c).filter(function(M) {
587
- return M !== "key";
588
- }), N = D.length > 0 ? "{key: someKey, " + D.join(": ..., ") + ": ...}" : "{key: someKey}";
589
- if (!le[F + N]) {
590
- var O = D.length > 0 ? "{" + D.join(": ..., ") + ": ...}" : "{}";
591
- S(`A props object containing a "key" prop is being spread into JSX:
585
+ if (PA.call(g, "key")) {
586
+ var XA = QA(e), FA = Object.keys(g).filter(function(At) {
587
+ return At !== "key";
588
+ }), He = FA.length > 0 ? "{key: someKey, " + FA.join(": ..., ") + ": ...}" : "{key: someKey}";
589
+ if (!Se[XA + He]) {
590
+ var $e = FA.length > 0 ? "{" + FA.join(": ..., ") + ": ...}" : "{}";
591
+ AA(`A props object containing a "key" prop is being spread into JSX:
592
592
  let props = %s;
593
593
  <%s {...props} />
594
594
  React keys must be passed directly to JSX without using spread:
595
595
  let props = %s;
596
- <%s key={someKey} {...props} />`, N, F, O, F), le[F + N] = !0;
596
+ <%s key={someKey} {...props} />`, He, XA, $e, XA), Se[XA + He] = !0;
597
597
  }
598
598
  }
599
- return e === u ? Fe(d) : pe(d), d;
599
+ return e === c ? Le(eA) : Je(eA), eA;
600
600
  }
601
601
  }
602
- function ye(e, c, A) {
603
- return de(e, c, A, !0);
602
+ function Ze(e, g, Q) {
603
+ return Ge(e, g, Q, !0);
604
604
  }
605
- function Ne(e, c, A) {
606
- return de(e, c, A, !1);
605
+ function _e(e, g, Q) {
606
+ return Ge(e, g, Q, !1);
607
607
  }
608
- var hA = Ne, Me = ye;
609
- ee.Fragment = u, ee.jsx = hA, ee.jsxs = Me;
610
- })()), ee;
608
+ var fe = _e, Ye = Ze;
609
+ Ue.Fragment = c, Ue.jsx = fe, Ue.jsxs = Ye;
610
+ })()), Ue;
611
611
  }
612
- var Ue;
613
- function rt() {
614
- return Ue || (Ue = 1, process.env.NODE_ENV === "production" ? fe.exports = tt() : fe.exports = nt()), fe.exports;
612
+ var st;
613
+ function Yt() {
614
+ return st || (st = 1, process.env.NODE_ENV === "production" ? Xe.exports = Lt() : Xe.exports = Gt()), Xe.exports;
615
615
  }
616
- var E = rt();
617
- const it = ({ action: g, row: s }) => /* @__PURE__ */ E.jsx("div", { className: "effect0", "data-action-id": g.id, "data-row-id": s.id, children: /* @__PURE__ */ E.jsx("div", { className: "effect0-text", children: `Audio: ${g.data.name}` }) }), ot = ({ action: g, row: s }) => /* @__PURE__ */ E.jsx("div", { className: "effect1", "data-action-id": g.id, "data-row-id": s.id, children: /* @__PURE__ */ E.jsx("div", { className: "effect1-text", children: `Video: ${g.data.name}` }) }), st = ({ action: g, row: s }) => /* @__PURE__ */ E.jsx("div", { className: "effect2", "data-action-id": g.id, "data-row-id": s.id, children: /* @__PURE__ */ E.jsx("div", { className: "effect2-text", children: `Video audio: ${g.data.name}` }) }), at = (g) => {
618
- const s = g.toLowerCase();
619
- 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";
616
+ var w = Yt();
617
+ const Kt = ({ action: B, row: o }) => /* @__PURE__ */ w.jsx("div", { className: "effect0", "data-action-id": B.id, "data-row-id": o.id, children: /* @__PURE__ */ w.jsx("div", { className: "effect0-text", children: `Audio: ${B.data.name}` }) }), jt = ({ action: B, row: o }) => /* @__PURE__ */ w.jsx("div", { className: "effect1", "data-action-id": B.id, "data-row-id": o.id, children: /* @__PURE__ */ w.jsx("div", { className: "effect1-text", children: `Video: ${B.data.name}` }) }), Tt = ({ action: B, row: o }) => /* @__PURE__ */ w.jsx("div", { className: "effect2", "data-action-id": B.id, "data-row-id": o.id, children: /* @__PURE__ */ w.jsx("div", { className: "effect2-text", children: `Video audio: ${B.data.name}` }) }), at = (B) => {
618
+ const o = B.toLowerCase();
619
+ return o.endsWith(".mp4") || o.endsWith(".webm") || o.endsWith(".mov") || o.endsWith(".m4v") ? "video" : o.endsWith(".mp3") || o.endsWith(".wav") || o.endsWith(".ogg") || o.endsWith(".m4a") || o.endsWith(".aac") ? "audio" : "other";
620
620
  };
621
- class ct {
621
+ class Wt {
622
622
  blobUrlBySrc = /* @__PURE__ */ new Map();
623
623
  pendingBySrc = /* @__PURE__ */ new Map();
624
+ metaBySrc = /* @__PURE__ */ new Map();
625
+ registerSrcMeta(o, d) {
626
+ const c = String(o ?? "");
627
+ if (!c) return;
628
+ const l = {
629
+ name: d?.name ? String(d.name) : void 0,
630
+ mimeType: d?.mimeType ? String(d.mimeType) : void 0
631
+ }, E = this.metaBySrc.get(c);
632
+ this.metaBySrc.set(c, {
633
+ name: E?.name ?? l.name,
634
+ mimeType: E?.mimeType ?? l.mimeType
635
+ });
636
+ }
637
+ getSrcMeta(o) {
638
+ const d = String(o ?? "");
639
+ if (d)
640
+ return this.metaBySrc.get(d);
641
+ }
624
642
  /**
625
643
  * Preloads a URL into memory and returns a blob: URL.
626
644
  * Useful to avoid runtime buffering/stalls when seeking frequently.
627
645
  */
628
- async preloadToBlobUrl(s) {
629
- if (!s) return s;
630
- const l = this.blobUrlBySrc.get(s);
631
- if (l) return l;
632
- const u = this.pendingBySrc.get(s);
633
- if (u) return u;
634
- const f = (async () => {
635
- const I = await fetch(s, { cache: "force-cache" });
636
- if (!I.ok) throw new Error(`Failed to fetch ${s}: ${I.status}`);
637
- const h = await I.blob(), v = URL.createObjectURL(h);
638
- return this.blobUrlBySrc.set(s, v), v;
639
- })().catch((I) => (console.warn("[mediaCache] preload failed:", s, I), s)).finally(() => {
640
- this.pendingBySrc.delete(s);
646
+ async preloadToBlobUrl(o) {
647
+ if (!o || o.startsWith("blob:") || o.startsWith("data:")) return o;
648
+ const d = this.blobUrlBySrc.get(o);
649
+ if (d) return d;
650
+ const c = this.pendingBySrc.get(o);
651
+ if (c) return c;
652
+ const l = (async () => {
653
+ const E = await fetch(o, { cache: "force-cache" });
654
+ if (!E.ok) throw new Error(`Failed to fetch ${o}: ${E.status}`);
655
+ const m = await E.blob(), O = URL.createObjectURL(m);
656
+ return this.blobUrlBySrc.set(o, O), O;
657
+ })().catch((E) => (console.warn("[mediaCache] preload failed:", o, E), o)).finally(() => {
658
+ this.pendingBySrc.delete(o);
641
659
  });
642
- return this.pendingBySrc.set(s, f), f;
660
+ return this.pendingBySrc.set(o, l), l;
643
661
  }
644
662
  /** Returns a blob URL if available, otherwise the original `src`. */
645
- resolve(s) {
646
- return this.blobUrlBySrc.get(s) ?? s;
663
+ resolve(o) {
664
+ return this.blobUrlBySrc.get(o) ?? o;
647
665
  }
648
666
  /** Starts preload in background (non-blocking). */
649
- warm(s) {
650
- this.preloadToBlobUrl(s);
667
+ warm(o) {
668
+ o && (o.startsWith("blob:") || o.startsWith("data:") || this.preloadToBlobUrl(o));
669
+ }
670
+ /**
671
+ * Preload a list of srcs with bounded concurrency.
672
+ *
673
+ * This is useful when you know ahead of time which assets will be scrubbed/seeked,
674
+ * so we can eliminate network stalls during interaction.
675
+ */
676
+ async warmAll(o, d) {
677
+ const c = [], l = /* @__PURE__ */ new Set();
678
+ for (const G of o) {
679
+ const M = String(G ?? "");
680
+ if (!M || l.has(M)) continue;
681
+ l.add(M);
682
+ const z = at(M);
683
+ z !== "video" && z !== "audio" || c.push(M);
684
+ }
685
+ if (c.length === 0) return;
686
+ const E = Math.max(1, Math.floor(d?.concurrency ?? 3)), m = d?.yieldBetween !== !1;
687
+ let O = 0;
688
+ const S = Array.from({ length: Math.min(E, c.length) }, async () => {
689
+ for (; O < c.length; ) {
690
+ const G = c[O++];
691
+ await this.preloadToBlobUrl(G), m && await new Promise((M) => setTimeout(M, 0));
692
+ }
693
+ });
694
+ await Promise.all(S);
651
695
  }
652
696
  /** Convenience: preload all unique action.data.src from editor data. */
653
- warmFromEditorData(s) {
654
- const l = /* @__PURE__ */ new Set(), u = Array.isArray(s) ? s : [];
655
- for (const f of u) {
656
- const I = f?.actions;
657
- if (Array.isArray(I))
658
- for (const h of I) {
659
- const v = h?.data?.src;
660
- typeof v == "string" && v && l.add(v);
697
+ warmFromEditorData(o) {
698
+ const d = /* @__PURE__ */ new Set(), c = Array.isArray(o) ? o : [];
699
+ for (const l of c) {
700
+ const E = l?.actions;
701
+ if (Array.isArray(E))
702
+ for (const m of E) {
703
+ const O = m?.data?.src, S = m?.data?.previewSrc;
704
+ typeof O == "string" && O && d.add(O), typeof S == "string" && S && d.add(S);
661
705
  }
662
706
  }
663
- for (const f of l) {
664
- const I = at(f);
665
- (I === "video" || I === "audio") && this.warm(f);
707
+ for (const l of d) {
708
+ const E = at(l);
709
+ (E === "video" || E === "audio") && this.warm(l);
666
710
  }
667
711
  }
668
712
  }
669
- const re = new ct(), gt = (g) => {
670
- if (!g) return;
671
- const l = g.split("#")[0].split("?")[0].toLowerCase(), u = l.lastIndexOf(".");
672
- if (u < 0) return;
673
- const f = l.slice(u + 1);
674
- if (f)
675
- return f === "m4a" || f === "m4v" ? "mp4" : f;
713
+ const qA = new Wt(), ct = (B) => {
714
+ if (!B) return;
715
+ const d = B.split("#")[0].split("?")[0].toLowerCase(), c = d.lastIndexOf(".");
716
+ if (c < 0) return;
717
+ const l = d.slice(c + 1);
718
+ if (l)
719
+ return l === "m4a" || l === "m4v" ? "mp4" : l;
720
+ }, Xt = (B) => {
721
+ const o = String(B ?? "").toLowerCase();
722
+ if (o) {
723
+ if (o === "audio/mpeg" || o === "audio/mp3") return "mp3";
724
+ if (o === "audio/wav" || o === "audio/x-wav") return "wav";
725
+ if (o === "audio/ogg") return "ogg";
726
+ if (o === "audio/aac") return "aac";
727
+ if (o === "audio/mp4" || o === "video/mp4") return "mp4";
728
+ }
729
+ }, gt = (B) => {
730
+ const o = ct(B);
731
+ if (o) return o;
732
+ const d = qA.getSrcMeta(B), c = d?.name ? ct(d.name) : void 0;
733
+ if (c) return c;
734
+ const l = d?.mimeType ? Xt(d.mimeType) : void 0;
735
+ if (l) return l;
676
736
  };
677
- class ut {
737
+ class zt {
678
738
  howlBySrc = {};
679
739
  activeByActionId = {};
680
- getHowl(s) {
681
- const l = re.resolve(s), u = l.startsWith("blob:") ? s : l, f = u;
682
- if (this.howlBySrc[f]) return this.howlBySrc[f];
683
- const I = gt(s), h = new Je({
684
- src: [u],
685
- format: I ? [I] : void 0,
740
+ getHowl(o) {
741
+ const d = qA.resolve(o), c = d, l = c;
742
+ if (this.howlBySrc[l]) return this.howlBySrc[l];
743
+ const E = gt(o) ?? gt(d), m = new bt({
744
+ src: [c],
745
+ format: E ? [E] : void 0,
686
746
  loop: !0,
687
747
  autoplay: !1,
688
748
  preload: !0
689
749
  });
690
- return this.howlBySrc[f] = h, h;
750
+ return this.howlBySrc[l] = m, m;
691
751
  }
692
752
  /**
693
753
  * Ensure the underlying WebAudio context is resumed.
@@ -698,141 +758,192 @@ class ut {
698
758
  */
699
759
  unlock() {
700
760
  try {
701
- const s = qe.ctx;
702
- s && s.state === "suspended" && s.resume();
761
+ const o = St.ctx;
762
+ o && o.state === "suspended" && o.resume();
703
763
  } catch {
704
764
  }
705
765
  }
706
- warm(s) {
707
- s && (re.warm(s), this.getHowl(s));
766
+ warm(o) {
767
+ o && (qA.warm(o), this.getHowl(o));
708
768
  }
709
- seekForEngineTime(s, l, u, f, I) {
710
- const h = Number(I), v = Number.isFinite(h) ? h : 0, m = s.duration();
711
- if (!Number.isFinite(m) || m <= 0) {
712
- s.seek(Math.max(0, f - u + v), l);
769
+ seekForEngineTime(o, d, c, l, E) {
770
+ const m = Number(E), O = Number.isFinite(m) ? m : 0, S = o.duration();
771
+ if (!Number.isFinite(S) || S <= 0) {
772
+ o.seek(Math.max(0, l - c + O), d);
713
773
  return;
714
774
  }
715
- const b = (f - u + v) % m, y = b < 0 ? b + m : b;
716
- s.seek(y, l);
775
+ const G = (l - c + O) % S, M = G < 0 ? G + S : G;
776
+ o.seek(M, d);
717
777
  }
718
- start(s) {
719
- const { actionId: l, src: u, startTime: f, time: I, engine: h } = s, v = Number(s.offset ?? 0), m = Number.isFinite(v) ? v : 0, b = this.activeByActionId[l];
720
- if (b) {
721
- const K = this.getHowl(b.src);
722
- K.rate(h.getPlayRate(), b.soundId);
778
+ start(o) {
779
+ const { actionId: d, src: c, startTime: l, time: E, engine: m } = o, O = Number(o.offset ?? 0), S = Number.isFinite(O) ? O : 0, G = this.activeByActionId[d];
780
+ if (G) {
781
+ const lA = this.getHowl(G.src);
782
+ lA.rate(m.getPlayRate(), G.soundId);
723
783
  try {
724
- K.playing(b.soundId) || K.play(b.soundId);
784
+ lA.playing(G.soundId) || lA.play(G.soundId);
725
785
  } catch {
726
786
  }
727
- h.isPlaying || this.seekForEngineTime(K, b.soundId, b.startTime, I, b.offset);
787
+ m.isPlaying || this.seekForEngineTime(lA, G.soundId, G.startTime, E, G.offset);
728
788
  return;
729
789
  }
730
- const y = this.getHowl(u), p = y.play();
731
- y.rate(h.getPlayRate(), p), this.seekForEngineTime(y, p, f, I, m);
732
- let q = performance.now();
733
- const W = ({ time: K }) => {
734
- if (!h.isPlaying) {
735
- this.seekForEngineTime(y, p, f, K, m);
790
+ const M = this.getHowl(c), z = M.play();
791
+ M.rate(m.getPlayRate(), z), this.seekForEngineTime(M, z, l, E, S);
792
+ let F = performance.now();
793
+ const BA = ({ time: lA }) => {
794
+ const oA = performance.now();
795
+ if (!m.isPlaying) {
796
+ this.seekForEngineTime(M, z, l, lA, S);
736
797
  return;
737
798
  }
738
- const L = performance.now();
739
- if (!(L - q < 500)) {
740
- q = L;
741
- try {
742
- const Z = Math.max(0, K - f + m), S = Number(y.seek(p));
743
- Number.isFinite(S) && Math.abs(S - Z) > 0.25 && this.seekForEngineTime(y, p, f, K, m);
744
- } catch {
745
- }
746
- }
747
- }, uA = ({ rate: K }) => {
748
- y.rate(K, p);
799
+ oA - F < 120 || (F = oA, this.seekForEngineTime(M, z, l, lA, S));
800
+ }, iA = ({ rate: lA }) => {
801
+ M.rate(lA, z);
749
802
  };
750
- h.on("afterSetTime", W), h.on("afterSetPlayRate", uA), this.activeByActionId[l] = {
751
- src: u,
752
- startTime: f,
753
- offset: m,
754
- soundId: p,
755
- engine: h,
756
- lastResyncAtMs: q,
757
- time: W,
758
- rate: uA
803
+ m.on("afterSetTime", BA), m.on("afterSetPlayRate", iA), this.activeByActionId[d] = {
804
+ src: c,
805
+ startTime: l,
806
+ offset: S,
807
+ soundId: z,
808
+ engine: m,
809
+ lastResyncAtMs: F,
810
+ time: BA,
811
+ rate: iA
759
812
  };
760
813
  }
761
- stop(s) {
762
- const { actionId: l } = s, u = this.activeByActionId[l];
763
- if (!u) return;
764
- const f = this.getHowl(u.src);
814
+ stop(o) {
815
+ const { actionId: d } = o, c = this.activeByActionId[d];
816
+ if (!c) return;
817
+ const l = this.getHowl(c.src);
765
818
  try {
766
- f.stop(u.soundId);
819
+ l.stop(c.soundId);
767
820
  } catch {
768
821
  }
769
- u.time && u.engine.off("afterSetTime", u.time), u.rate && u.engine.off("afterSetPlayRate", u.rate), delete this.activeByActionId[l];
822
+ c.time && c.engine.off("afterSetTime", c.time), c.rate && c.engine.off("afterSetPlayRate", c.rate), delete this.activeByActionId[d];
770
823
  }
771
824
  }
772
- const rA = new ut();
773
- class Bt {
825
+ const NA = new zt();
826
+ class qt {
774
827
  videoEl = null;
775
828
  currentSrc = null;
776
829
  lastSeekAtMs = 0;
777
830
  lastRate = null;
831
+ videoClaims = {};
832
+ activeVideoActionId = null;
833
+ lastEngineTime = 0;
778
834
  boundEngine = null;
779
835
  boundActionStart = 0;
780
836
  vfcHandle = null;
781
837
  rafHandle = null;
782
- attach(s) {
783
- this.videoEl = s, this.currentSrc = s?.currentSrc || s?.getAttribute("src") || null, this.lastSeekAtMs = 0, this.lastRate = null, this.unbindEngine(), this.setActive(!1);
838
+ attach(o) {
839
+ this.videoEl = o, this.currentSrc = o?.currentSrc || o?.getAttribute("src") || null, this.lastSeekAtMs = 0, this.lastRate = null, this.unbindEngine(), this.videoClaims = {}, this.activeVideoActionId = null, this.lastEngineTime = 0, this.setActive(!1);
840
+ }
841
+ setActive(o) {
842
+ this.videoEl && (this.videoEl.style.opacity = o ? "1" : "0");
784
843
  }
785
- setActive(s) {
786
- this.videoEl && (this.videoEl.style.opacity = s ? "1" : "0");
844
+ claimVideo(o) {
845
+ const d = String(o.actionId), c = Number.isFinite(Number(o.layer)) ? Number(o.layer) : 0, l = String(o.src ?? ""), E = Number(o.actionStart), m = Number(o.time), O = o.engine, S = !!o.isPlaying, G = Number(o.offset ?? 0), M = Number.isFinite(G) ? G : 0;
846
+ if (!l || !Number.isFinite(E) || !Number.isFinite(m)) return;
847
+ const z = performance.now();
848
+ this.lastEngineTime = m, this.videoClaims[d] = {
849
+ actionId: d,
850
+ layer: c,
851
+ src: l,
852
+ actionStart: E,
853
+ offset: M,
854
+ engine: O,
855
+ isPlaying: S,
856
+ time: m,
857
+ claimedAtMs: z
858
+ };
859
+ let F = null;
860
+ for (const iA of Object.values(this.videoClaims)) {
861
+ if (!F) {
862
+ F = iA;
863
+ continue;
864
+ }
865
+ if (iA.layer > F.layer) {
866
+ F = iA;
867
+ continue;
868
+ }
869
+ iA.layer === F.layer && iA.claimedAtMs > F.claimedAtMs && (F = iA);
870
+ }
871
+ if (!F) return;
872
+ this.activeVideoActionId = F.actionId, this.setActive(!0), this.setRate(F.engine.getPlayRate()), this.setSource(F.src);
873
+ const BA = Math.max(0, F.time - F.actionStart + F.offset);
874
+ this.seek(BA, { force: !F.isPlaying }), F.isPlaying ? this.play() : this.pause();
875
+ }
876
+ releaseVideo(o) {
877
+ const d = String(o);
878
+ if (delete this.videoClaims[d], this.activeVideoActionId && this.activeVideoActionId !== d) return;
879
+ let c = null;
880
+ for (const E of Object.values(this.videoClaims)) {
881
+ if (!c) {
882
+ c = E;
883
+ continue;
884
+ }
885
+ if (E.layer > c.layer) {
886
+ c = E;
887
+ continue;
888
+ }
889
+ E.layer === c.layer && E.claimedAtMs > c.claimedAtMs && (c = E);
890
+ }
891
+ if (!c) {
892
+ this.activeVideoActionId = null, this.pause(), this.unbindEngine(), this.setActive(!1);
893
+ return;
894
+ }
895
+ this.activeVideoActionId = c.actionId, this.setActive(!0), this.setRate(c.engine.getPlayRate()), this.setSource(c.src);
896
+ const l = Math.max(0, this.lastEngineTime - c.actionStart + c.offset);
897
+ this.seek(l, { force: !c.isPlaying }), c.isPlaying ? this.play() : this.pause();
787
898
  }
788
- bindEngine(s, l) {
789
- this.unbindEngine(), this.boundEngine = s, this.boundActionStart = l, this.tickFromVideo();
899
+ bindEngine(o, d) {
900
+ this.unbindEngine(), this.boundEngine = o, this.boundActionStart = d, this.tickFromVideo();
790
901
  }
791
902
  unbindEngine() {
792
- const s = this.videoEl;
793
- if (this.vfcHandle != null && s?.cancelVideoFrameCallback)
903
+ const o = this.videoEl;
904
+ if (this.vfcHandle != null && o?.cancelVideoFrameCallback)
794
905
  try {
795
- s.cancelVideoFrameCallback(this.vfcHandle);
906
+ o.cancelVideoFrameCallback(this.vfcHandle);
796
907
  } catch {
797
908
  }
798
909
  this.rafHandle != null && cancelAnimationFrame(this.rafHandle), this.vfcHandle = null, this.rafHandle = null, this.boundEngine = null;
799
910
  }
800
911
  tickFromVideo = () => {
801
912
  if (!this.videoEl || !this.boundEngine || this.videoEl.paused) return;
802
- const s = this.boundActionStart + this.videoEl.currentTime;
803
- Math.abs(this.boundEngine.getTime() - s) > 0.03 && this.boundEngine.setTime(s, !0);
804
- const l = this.videoEl;
805
- l?.requestVideoFrameCallback ? this.vfcHandle = l.requestVideoFrameCallback(() => this.tickFromVideo()) : this.rafHandle = requestAnimationFrame(() => this.tickFromVideo());
913
+ const o = this.boundActionStart + this.videoEl.currentTime;
914
+ Math.abs(this.boundEngine.getTime() - o) > 0.03 && this.boundEngine.setTime(o, !0);
915
+ const d = this.videoEl;
916
+ d?.requestVideoFrameCallback ? this.vfcHandle = d.requestVideoFrameCallback(() => this.tickFromVideo()) : this.rafHandle = requestAnimationFrame(() => this.tickFromVideo());
806
917
  };
807
- setSource(s) {
808
- if (!this.videoEl || !s) return;
809
- const l = re.resolve(s);
810
- if (!((this.videoEl.currentSrc || this.videoEl.getAttribute("src") || "") === l || this.currentSrc === l)) {
811
- this.currentSrc = l, this.videoEl.preload = "auto", this.videoEl.src = l;
918
+ setSource(o) {
919
+ if (!this.videoEl || !o) return;
920
+ const d = qA.resolve(o);
921
+ if (!((this.videoEl.currentSrc || this.videoEl.getAttribute("src") || "") === d || this.currentSrc === d)) {
922
+ this.currentSrc = d, this.videoEl.preload = "auto", this.videoEl.src = d;
812
923
  try {
813
924
  this.videoEl.load();
814
925
  } catch {
815
926
  }
816
927
  }
817
928
  }
818
- warm(s) {
819
- s && re.warm(s);
929
+ warm(o) {
930
+ o && qA.warm(o);
820
931
  }
821
- setRate(s) {
822
- this.videoEl && this.lastRate !== s && (this.lastRate = s, this.videoEl.playbackRate = s);
932
+ setRate(o) {
933
+ this.videoEl && this.lastRate !== o && (this.lastRate = o, this.videoEl.playbackRate = o);
823
934
  }
824
935
  /**
825
936
  * Sync the video to a desired timeline time.
826
937
  * To avoid buffering/stutters, we only seek when drift is large or when paused/scrubbing.
827
938
  */
828
- seek(s, l) {
939
+ seek(o, d) {
829
940
  if (this.videoEl)
830
941
  try {
831
- const u = performance.now(), f = l?.force === !0, I = this.videoEl.currentTime;
832
- if (!f && !this.videoEl.paused && (Math.abs(I - s) < 0.12 || u - this.lastSeekAtMs < 150))
942
+ const c = performance.now(), l = d?.force === !0, E = this.videoEl.currentTime;
943
+ if (!l && !this.videoEl.paused && (Math.abs(E - o) < 0.12 || c - this.lastSeekAtMs < 150))
833
944
  return;
834
- const h = this.videoEl.duration;
835
- Number.isFinite(h) && h > 0 ? this.videoEl.currentTime = Math.min(s, Math.max(0, h - 0.05)) : this.videoEl.currentTime = Math.max(0, s), this.lastSeekAtMs = u;
945
+ const m = this.videoEl.duration;
946
+ Number.isFinite(m) && m > 0 ? this.videoEl.currentTime = Math.min(o, Math.max(0, m - 0.05)) : this.videoEl.currentTime = Math.max(0, o), this.lastSeekAtMs = c;
836
947
  } catch {
837
948
  }
838
949
  }
@@ -847,28 +958,28 @@ class Bt {
847
958
  this.videoEl && this.videoEl.pause();
848
959
  }
849
960
  }
850
- const G = new Bt(), te = 160, ne = 5, Ee = 20, lt = {
961
+ const jA = new qt(), Vt = 160, Zt = 5, _t = {
851
962
  effect0: {
852
963
  id: "effect0",
853
964
  name: "Play audio",
854
965
  source: {
855
- start: ({ action: g, engine: s, isPlaying: l, time: u }) => {
856
- if (l) {
857
- const { src: f, offset: I } = g.data;
858
- rA.warm(f), rA.start({ actionId: g.id, src: f, startTime: g.start, engine: s, time: u, offset: I });
966
+ start: ({ action: B, engine: o, isPlaying: d, time: c }) => {
967
+ if (d) {
968
+ const { src: l, offset: E } = B.data;
969
+ NA.warm(l), NA.start({ actionId: B.id, src: l, startTime: B.start, engine: o, time: c, offset: E });
859
970
  }
860
971
  },
861
- enter: ({ action: g, engine: s, isPlaying: l, time: u }) => {
862
- if (l) {
863
- const { src: f, offset: I } = g.data;
864
- rA.warm(f), rA.start({ actionId: g.id, src: f, startTime: g.start, engine: s, time: u, offset: I });
972
+ enter: ({ action: B, engine: o, isPlaying: d, time: c }) => {
973
+ if (d) {
974
+ const { src: l, offset: E } = B.data;
975
+ NA.warm(l), NA.start({ actionId: B.id, src: l, startTime: B.start, engine: o, time: c, offset: E });
865
976
  }
866
977
  },
867
- leave: ({ action: g }) => {
868
- rA.stop({ actionId: g.id });
978
+ leave: ({ action: B }) => {
979
+ NA.stop({ actionId: B.id });
869
980
  },
870
- stop: ({ action: g }) => {
871
- rA.stop({ actionId: g.id });
981
+ stop: ({ action: B }) => {
982
+ NA.stop({ actionId: B.id });
872
983
  }
873
984
  }
874
985
  },
@@ -876,23 +987,23 @@ const G = new Bt(), te = 160, ne = 5, Ee = 20, lt = {
876
987
  id: "effect2",
877
988
  name: "Play video audio",
878
989
  source: {
879
- start: ({ action: g, engine: s, isPlaying: l, time: u }) => {
880
- if (l) {
881
- const { src: f, offset: I } = g.data;
882
- rA.warm(f), rA.start({ actionId: g.id, src: f, startTime: g.start, engine: s, time: u, offset: I });
990
+ start: ({ action: B, engine: o, isPlaying: d, time: c }) => {
991
+ if (d) {
992
+ const { src: l, offset: E } = B.data;
993
+ NA.warm(l), NA.start({ actionId: B.id, src: l, startTime: B.start, engine: o, time: c, offset: E });
883
994
  }
884
995
  },
885
- enter: ({ action: g, engine: s, isPlaying: l, time: u }) => {
886
- if (l) {
887
- const { src: f, offset: I } = g.data;
888
- rA.warm(f), rA.start({ actionId: g.id, src: f, startTime: g.start, engine: s, time: u, offset: I });
996
+ enter: ({ action: B, engine: o, isPlaying: d, time: c }) => {
997
+ if (d) {
998
+ const { src: l, offset: E } = B.data;
999
+ NA.warm(l), NA.start({ actionId: B.id, src: l, startTime: B.start, engine: o, time: c, offset: E });
889
1000
  }
890
1001
  },
891
- leave: ({ action: g }) => {
892
- rA.stop({ actionId: g.id });
1002
+ leave: ({ action: B }) => {
1003
+ NA.stop({ actionId: B.id });
893
1004
  },
894
- stop: ({ action: g }) => {
895
- rA.stop({ actionId: g.id });
1005
+ stop: ({ action: B }) => {
1006
+ NA.stop({ actionId: B.id });
896
1007
  }
897
1008
  }
898
1009
  },
@@ -900,808 +1011,1109 @@ const G = new Bt(), te = 160, ne = 5, Ee = 20, lt = {
900
1011
  id: "effect1",
901
1012
  name: "Play video",
902
1013
  source: {
903
- start: ({ action: g, engine: s, isPlaying: l, time: u }) => {
904
- const { src: f, previewSrc: I, offset: h } = g.data ?? {}, v = I || f;
905
- v && (G.warm(v), G.setSource(v)), G.setActive(!0), G.setRate(s.getPlayRate());
906
- const m = Number(h ?? 0);
907
- G.seek(Math.max(0, u - g.start + (Number.isFinite(m) ? m : 0)), { force: !0 }), l && G.play();
1014
+ start: ({ action: B, engine: o, isPlaying: d, time: c }) => {
1015
+ const { src: l, previewSrc: E, offset: m, videoLayer: O } = B.data ?? {}, S = E || l;
1016
+ S && jA.warm(S), jA.claimVideo({
1017
+ actionId: String(B.id),
1018
+ layer: Number.isFinite(Number(O)) ? Number(O) : 0,
1019
+ src: S,
1020
+ engine: o,
1021
+ isPlaying: d,
1022
+ time: c,
1023
+ actionStart: Number(B.start),
1024
+ offset: m
1025
+ });
908
1026
  },
909
- enter: ({ action: g, engine: s, isPlaying: l, time: u }) => {
910
- const { src: f, previewSrc: I, offset: h } = g.data ?? {}, v = I || f;
911
- v && (G.warm(v), G.setSource(v)), G.setActive(!0), G.setRate(s.getPlayRate());
912
- const m = Number(h ?? 0);
913
- G.seek(Math.max(0, u - g.start + (Number.isFinite(m) ? m : 0)), { force: !0 }), l && G.play();
1027
+ enter: ({ action: B, engine: o, isPlaying: d, time: c }) => {
1028
+ const { src: l, previewSrc: E, offset: m, videoLayer: O } = B.data ?? {}, S = E || l;
1029
+ S && jA.warm(S), jA.claimVideo({
1030
+ actionId: String(B.id),
1031
+ layer: Number.isFinite(Number(O)) ? Number(O) : 0,
1032
+ src: S,
1033
+ engine: o,
1034
+ isPlaying: d,
1035
+ time: c,
1036
+ actionStart: Number(B.start),
1037
+ offset: m
1038
+ });
914
1039
  },
915
- update: ({ action: g, engine: s, time: l, isPlaying: u }) => {
916
- const { src: f, previewSrc: I, offset: h } = g.data ?? {}, v = I || f;
917
- if (v && G.setSource(v), G.setActive(!0), G.setRate(s.getPlayRate()), !u) {
918
- const m = Number(h ?? 0);
919
- G.seek(Math.max(0, l - g.start + (Number.isFinite(m) ? m : 0)), { force: !0 });
920
- }
1040
+ update: ({ action: B, engine: o, time: d, isPlaying: c }) => {
1041
+ const { src: l, previewSrc: E, offset: m, videoLayer: O } = B.data ?? {}, S = E || l;
1042
+ jA.claimVideo({
1043
+ actionId: String(B.id),
1044
+ layer: Number.isFinite(Number(O)) ? Number(O) : 0,
1045
+ src: S,
1046
+ engine: o,
1047
+ isPlaying: c,
1048
+ time: d,
1049
+ actionStart: Number(B.start),
1050
+ offset: m
1051
+ });
921
1052
  },
922
- leave: () => {
923
- G.pause(), G.unbindEngine(), G.setActive(!1);
1053
+ leave: ({ action: B }) => {
1054
+ jA.releaseVideo(String(B.id));
924
1055
  },
925
- stop: () => {
926
- G.pause(), G.unbindEngine(), G.setActive(!1);
1056
+ stop: ({ action: B }) => {
1057
+ jA.releaseVideo(String(B.id));
927
1058
  }
928
1059
  }
929
1060
  }
930
- }, dt = [
931
- {
932
- id: "0",
933
- actions: [
934
- {
935
- id: "action0",
936
- start: 0,
937
- end: 10,
938
- effectId: "effect1",
939
- data: {
940
- src: "/footage/Big_Buck_Bunny_720_10s_5MB.mp4",
941
- name: "Big Buck Bunny (10s)"
942
- }
943
- }
944
- ]
945
- },
946
- {
947
- id: "1",
948
- actions: []
949
- },
950
- {
951
- id: "2",
952
- actions: [
953
- {
954
- id: "action1",
955
- start: 0,
956
- end: 10,
957
- effectId: "effect0",
958
- data: {
959
- src: "/footage/file_example_MP3_700KB.mp3",
960
- name: "Example MP3 (looped)"
961
- }
962
- }
963
- ]
964
- },
965
- {
966
- id: "3",
967
- actions: []
968
- }
969
- ], ft = "", Qt = "", Et = "", Ct = "", wt = "", It = "", { Option: Dt } = Ye, ht = [0.2, 0.5, 1, 1.5, 2], mt = ({
970
- timelineState: g,
971
- autoScrollWhenPlay: s,
972
- editorData: l,
973
- selectedActionId: u,
974
- onDeleteSelectedClip: f,
975
- onSplitSelectedClip: I,
976
- canUndo: h,
977
- canRedo: v,
978
- onUndo: m,
979
- onRedo: b
1061
+ }, $t = "", An = "", en = "", tn = "", nn = "", rn = "", { Option: on } = dt, sn = [0.2, 0.5, 1, 1.5, 2], an = ({
1062
+ timelineState: B,
1063
+ autoScrollWhenPlay: o,
1064
+ scale: d,
1065
+ scaleWidth: c,
1066
+ startLeft: l,
1067
+ editorData: E,
1068
+ selectedActionId: m,
1069
+ onDeleteSelectedClip: O,
1070
+ onSplitSelectedClip: S,
1071
+ canUndo: G,
1072
+ canRedo: M,
1073
+ onUndo: z,
1074
+ onRedo: F
980
1075
  }) => {
981
- const [y, p] = z(!1), [q, W] = z(0), [uA, K] = z(!1), L = j(0), Z = j(0), S = j(0), BA = j(0), CA = j(0), iA = j(0), lA = !!u, FA = (() => {
982
- if (!u) return null;
983
- const w = Array.isArray(l) ? l : [];
984
- for (const x of w) {
985
- const R = x?.actions;
986
- if (Array.isArray(R))
987
- for (const P of R) {
988
- if (String(P?.id) !== u) continue;
989
- const H = Number(P?.start), U = Number(P?.end);
990
- return !Number.isFinite(H) || !Number.isFinite(U) ? null : { start: H, end: U };
1076
+ const [BA, iA] = cA(!1), [lA, oA] = cA(0), [kA, AA] = cA(!1), Qe = tA(0), ie = tA(0), oe = tA(0), se = tA(0), ae = tA(0), ce = tA(0), JA = !!m, WA = (() => {
1077
+ if (!m) return null;
1078
+ const y = Array.isArray(E) ? E : [];
1079
+ for (const nA of y) {
1080
+ const rA = nA?.actions;
1081
+ if (Array.isArray(rA))
1082
+ for (const Z of rA) {
1083
+ if (String(Z?.id) !== m) continue;
1084
+ const _ = Number(Z?.start), sA = Number(Z?.end);
1085
+ return !Number.isFinite(_) || !Number.isFinite(sA) ? null : { start: _, end: sA };
991
1086
  }
992
1087
  }
993
1088
  return null;
994
- })(), yA = !!(FA && q > FA.start && q < FA.end), JA = (w) => {
995
- const x = Array.isArray(l) ? l : [];
996
- for (const R of x) {
997
- const P = R?.actions;
998
- if (Array.isArray(P))
999
- for (const H of P) {
1000
- if (H?.effectId !== "effect1") continue;
1001
- const U = Number(H?.start), k = Number(H?.end);
1002
- if (!(!Number.isFinite(U) || !Number.isFinite(k)) && w >= U && w < k)
1089
+ })(), LA = !!(WA && lA > WA.start && lA < WA.end), QA = (y) => {
1090
+ const nA = Array.isArray(E) ? E : [];
1091
+ for (const rA of nA) {
1092
+ const Z = rA?.actions;
1093
+ if (Array.isArray(Z))
1094
+ for (const _ of Z) {
1095
+ if (_?.effectId !== "effect1") continue;
1096
+ const sA = Number(_?.start), gA = Number(_?.end);
1097
+ if (!(!Number.isFinite(sA) || !Number.isFinite(gA)) && y >= sA && y < gA)
1003
1098
  return !0;
1004
1099
  }
1005
1100
  }
1006
1101
  return !1;
1007
- }, qA = (w) => {
1008
- JA(w) || (G.pause(), G.unbindEngine(), G.setActive(!1));
1102
+ }, pA = (y) => {
1103
+ QA(y) || (jA.pause(), jA.unbindEngine(), jA.setActive(!1));
1009
1104
  };
1010
- Ce(() => {
1011
- if (!g.current) return;
1012
- const w = g.current, x = () => p(!0), R = () => p(!1), P = ({ time: U }) => {
1013
- W(U), qA(U);
1014
- }, H = ({ time: U }) => {
1015
- const k = performance.now();
1016
- if (!(k - L.current < 33) && (L.current = k, W(U), qA(U), s.current)) {
1017
- const dA = U * (te / ne) + Ee - 500, aA = g.current;
1018
- aA && aA.setScrollLeft(dA);
1105
+ Ee(() => {
1106
+ if (!B.current) return;
1107
+ const y = B.current, nA = () => iA(!0), rA = () => iA(!1), Z = ({ time: sA }) => {
1108
+ oA(sA), pA(sA);
1109
+ }, _ = ({ time: sA }) => {
1110
+ const gA = performance.now();
1111
+ if (!(gA - Qe.current < 33) && (Qe.current = gA, oA(sA), pA(sA), o.current)) {
1112
+ const GA = sA * (c / d) + l - 500, UA = B.current;
1113
+ UA && UA.setScrollLeft(GA);
1019
1114
  }
1020
1115
  };
1021
- return w.listener.on("play", x), w.listener.on("paused", R), w.listener.on("afterSetTime", P), w.listener.on("setTimeByTick", H), () => {
1022
- w.listener.off("play", x), w.listener.off("paused", R), w.listener.off("afterSetTime", P), w.listener.off("setTimeByTick", H);
1116
+ return y.listener.on("play", nA), y.listener.on("paused", rA), y.listener.on("afterSetTime", Z), y.listener.on("setTimeByTick", _), () => {
1117
+ y.listener.off("play", nA), y.listener.off("paused", rA), y.listener.off("afterSetTime", Z), y.listener.off("setTimeByTick", _);
1023
1118
  };
1024
- }, [l]);
1025
- const SA = () => {
1026
- g.current && (g.current.isPlaying ? g.current.pause() : (rA.unlock(), g.current.play({ autoEnd: !0 })));
1027
- }, oA = (w) => {
1028
- g.current && g.current.setPlayRate(w);
1029
- }, sA = (w) => {
1030
- const x = (parseInt(w % 1 * 100 + "") + "").padStart(2, "0"), R = (parseInt(w / 60 + "") + "").padStart(2, "0"), P = (parseInt(w % 60 + "") + "").padStart(2, "0");
1031
- return /* @__PURE__ */ E.jsx(E.Fragment, { children: `${R}:${P}.${x.replace("0.", "")}` });
1032
- }, eA = () => {
1033
- const w = [], x = /* @__PURE__ */ new Set(), R = Array.isArray(l) ? l : [];
1034
- for (const P of R) {
1035
- const H = P?.actions;
1036
- if (Array.isArray(H))
1037
- for (const U of H) {
1038
- const k = U?.data?.src;
1039
- if (!k) continue;
1040
- const IA = String(k);
1041
- x.has(IA) || (x.add(IA), w.push(IA));
1119
+ }, [E]);
1120
+ const wA = () => {
1121
+ B.current && (B.current.isPlaying ? B.current.pause() : (NA.unlock(), B.current.play({ autoEnd: !0 })));
1122
+ }, TA = (y) => {
1123
+ B.current && B.current.setPlayRate(y);
1124
+ }, we = (y) => {
1125
+ const nA = (parseInt(y % 1 * 100 + "") + "").padStart(2, "0"), rA = (parseInt(y / 60 + "") + "").padStart(2, "0"), Z = (parseInt(y % 60 + "") + "").padStart(2, "0");
1126
+ return /* @__PURE__ */ w.jsx(w.Fragment, { children: `${rA}:${Z}.${nA.replace("0.", "")}` });
1127
+ }, VA = () => {
1128
+ const y = [], nA = /* @__PURE__ */ new Set(), rA = Array.isArray(E) ? E : [];
1129
+ for (const Z of rA) {
1130
+ const _ = Z?.actions;
1131
+ if (Array.isArray(_))
1132
+ for (const sA of _) {
1133
+ const gA = sA?.data?.src;
1134
+ if (!gA) continue;
1135
+ const IA = String(gA);
1136
+ nA.has(IA) || (nA.add(IA), y.push(IA));
1042
1137
  }
1043
1138
  }
1044
- return w;
1045
- }, UA = (w, x) => {
1046
- const R = URL.createObjectURL(w), P = document.createElement("a");
1047
- P.href = R, P.download = x, document.body.appendChild(P), P.click(), P.remove(), setTimeout(() => URL.revokeObjectURL(R), 3e3);
1048
- }, wA = async () => {
1049
- if (!uA) {
1050
- K(!0);
1139
+ return y;
1140
+ }, Ie = (y, nA) => {
1141
+ const rA = URL.createObjectURL(y), Z = document.createElement("a");
1142
+ Z.href = rA, Z.download = nA, document.body.appendChild(Z), Z.click(), Z.remove(), setTimeout(() => URL.revokeObjectURL(rA), 3e3);
1143
+ }, ZA = async () => {
1144
+ if (!kA) {
1145
+ AA(!0);
1051
1146
  try {
1052
- const w = eA(), x = new FormData();
1053
- x.append("timeline", JSON.stringify({ editorData: l }));
1054
- for (const H of w) {
1055
- const U = await fetch(H);
1056
- if (!U.ok) throw new Error(`Failed to fetch asset: ${H} (${U.status})`);
1057
- const k = await U.blob();
1058
- x.append("assets", k, encodeURIComponent(H));
1147
+ const y = VA(), nA = new FormData();
1148
+ nA.append("timeline", JSON.stringify({ editorData: E }));
1149
+ for (const _ of y) {
1150
+ const sA = qA.resolve(_), gA = await fetch(sA);
1151
+ if (!gA.ok) throw new Error(`Failed to fetch asset: ${_} (${gA.status})`);
1152
+ const IA = await gA.blob();
1153
+ nA.append("assets", IA, encodeURIComponent(_));
1059
1154
  }
1060
- const R = await fetch("/export", {
1155
+ const rA = await fetch("/export", {
1061
1156
  method: "POST",
1062
- body: x
1157
+ body: nA
1063
1158
  });
1064
- if (!R.ok) {
1065
- const H = await R.text().catch(() => "");
1066
- throw new Error(H || `Export failed (${R.status})`);
1159
+ if (!rA.ok) {
1160
+ const _ = await rA.text().catch(() => "");
1161
+ throw new Error(_ || `Export failed (${rA.status})`);
1067
1162
  }
1068
- const P = await R.blob();
1069
- UA(P, "export.mp4");
1163
+ const Z = await rA.blob();
1164
+ Ie(Z, "export.mp4");
1070
1165
  } finally {
1071
- K(!1);
1166
+ AA(!1);
1072
1167
  }
1073
1168
  }
1074
1169
  };
1075
- return /* @__PURE__ */ E.jsxs("div", { className: "timeline-player", children: [
1076
- /* @__PURE__ */ E.jsx(
1170
+ return /* @__PURE__ */ w.jsxs("div", { className: "timeline-player", children: [
1171
+ /* @__PURE__ */ w.jsx(
1077
1172
  "div",
1078
1173
  {
1079
1174
  className: "play-control",
1080
1175
  role: "button",
1081
1176
  tabIndex: 0,
1082
- "aria-label": y ? "Pause" : "Play",
1177
+ "aria-label": BA ? "Pause" : "Play",
1083
1178
  onClick: () => {
1084
- Date.now() - Z.current < 450 || SA();
1179
+ Date.now() - ie.current < 450 || wA();
1085
1180
  },
1086
- onPointerUp: (w) => {
1087
- w.pointerType !== "mouse" && (Z.current = Date.now(), SA());
1181
+ onPointerUp: (y) => {
1182
+ y.pointerType !== "mouse" && (ie.current = Date.now(), wA());
1088
1183
  },
1089
- children: /* @__PURE__ */ E.jsx(
1184
+ children: /* @__PURE__ */ w.jsx(
1090
1185
  "img",
1091
1186
  {
1092
- src: y ? Qt : ft,
1187
+ src: BA ? An : $t,
1093
1188
  alt: "",
1094
1189
  draggable: !1
1095
1190
  }
1096
1191
  )
1097
1192
  }
1098
1193
  ),
1099
- /* @__PURE__ */ E.jsx("div", { className: "time", children: sA(q) }),
1100
- /* @__PURE__ */ E.jsxs("div", { className: "history-tools", children: [
1101
- /* @__PURE__ */ E.jsx(
1194
+ /* @__PURE__ */ w.jsx("div", { className: "time", children: we(lA) }),
1195
+ /* @__PURE__ */ w.jsxs("div", { className: "history-tools", children: [
1196
+ /* @__PURE__ */ w.jsx(
1102
1197
  "button",
1103
1198
  {
1104
1199
  type: "button",
1105
1200
  className: "history-tool",
1106
- disabled: !h,
1201
+ disabled: !G,
1107
1202
  "aria-label": "Undo",
1108
1203
  onClick: () => {
1109
- Date.now() - CA.current < 450 || h && m();
1204
+ Date.now() - ae.current < 450 || G && z();
1110
1205
  },
1111
- onPointerUp: (w) => {
1112
- w.pointerType !== "mouse" && (CA.current = Date.now(), h && m());
1206
+ onPointerUp: (y) => {
1207
+ y.pointerType !== "mouse" && (ae.current = Date.now(), G && z());
1113
1208
  },
1114
- children: /* @__PURE__ */ E.jsx("img", { src: Et, alt: "", draggable: !1 })
1209
+ children: /* @__PURE__ */ w.jsx("img", { src: en, alt: "", draggable: !1 })
1115
1210
  }
1116
1211
  ),
1117
- /* @__PURE__ */ E.jsx(
1212
+ /* @__PURE__ */ w.jsx(
1118
1213
  "button",
1119
1214
  {
1120
1215
  type: "button",
1121
1216
  className: "history-tool",
1122
- disabled: !v,
1217
+ disabled: !M,
1123
1218
  "aria-label": "Redo",
1124
1219
  onClick: () => {
1125
- Date.now() - iA.current < 450 || v && b();
1220
+ Date.now() - ce.current < 450 || M && F();
1126
1221
  },
1127
- onPointerUp: (w) => {
1128
- w.pointerType !== "mouse" && (iA.current = Date.now(), v && b());
1222
+ onPointerUp: (y) => {
1223
+ y.pointerType !== "mouse" && (ce.current = Date.now(), M && F());
1129
1224
  },
1130
- children: /* @__PURE__ */ E.jsx("img", { src: Ct, alt: "", draggable: !1 })
1225
+ children: /* @__PURE__ */ w.jsx("img", { src: tn, alt: "", draggable: !1 })
1131
1226
  }
1132
1227
  )
1133
1228
  ] }),
1134
- /* @__PURE__ */ E.jsx("div", { className: "rate-control", children: /* @__PURE__ */ E.jsx(Ye, { size: "small", defaultValue: 1, style: { width: 120 }, onChange: oA, children: ht.map((w) => /* @__PURE__ */ E.jsx(Dt, { value: w, children: `${w.toFixed(1)}x` }, w)) }) }),
1135
- /* @__PURE__ */ E.jsxs("div", { className: "clip-tools", children: [
1136
- /* @__PURE__ */ E.jsx(
1229
+ /* @__PURE__ */ w.jsx("div", { className: "rate-control", children: /* @__PURE__ */ w.jsx(dt, { size: "small", defaultValue: 1, style: { width: 120 }, onChange: TA, children: sn.map((y) => /* @__PURE__ */ w.jsx(on, { value: y, children: `${y.toFixed(1)}x` }, y)) }) }),
1230
+ /* @__PURE__ */ w.jsxs("div", { className: "clip-tools", children: [
1231
+ /* @__PURE__ */ w.jsx(
1137
1232
  "button",
1138
1233
  {
1139
1234
  type: "button",
1140
1235
  className: "clip-tool clip-tool-delete",
1141
- disabled: !lA,
1236
+ disabled: !JA,
1142
1237
  "aria-label": "Delete selected clip",
1143
1238
  onClick: () => {
1144
- Date.now() - S.current < 450 || lA && f();
1239
+ Date.now() - oe.current < 450 || JA && O();
1145
1240
  },
1146
- onPointerUp: (w) => {
1147
- w.pointerType !== "mouse" && (S.current = Date.now(), lA && f());
1241
+ onPointerUp: (y) => {
1242
+ y.pointerType !== "mouse" && (oe.current = Date.now(), JA && O());
1148
1243
  },
1149
- children: /* @__PURE__ */ E.jsx("img", { src: wt, alt: "", draggable: !1 })
1244
+ children: /* @__PURE__ */ w.jsx("img", { src: nn, alt: "", draggable: !1 })
1150
1245
  }
1151
1246
  ),
1152
- /* @__PURE__ */ E.jsx(
1247
+ /* @__PURE__ */ w.jsx(
1153
1248
  "button",
1154
1249
  {
1155
1250
  type: "button",
1156
1251
  className: "clip-tool clip-tool-split",
1157
- disabled: !yA,
1252
+ disabled: !LA,
1158
1253
  "aria-label": "Split selected clip at cursor",
1159
1254
  onClick: () => {
1160
- Date.now() - BA.current < 450 || yA && I();
1255
+ Date.now() - se.current < 450 || LA && S();
1161
1256
  },
1162
- onPointerUp: (w) => {
1163
- w.pointerType !== "mouse" && (BA.current = Date.now(), yA && I());
1257
+ onPointerUp: (y) => {
1258
+ y.pointerType !== "mouse" && (se.current = Date.now(), LA && S());
1164
1259
  },
1165
- children: /* @__PURE__ */ E.jsx("img", { src: It, alt: "", draggable: !1 })
1260
+ children: /* @__PURE__ */ w.jsx("img", { src: rn, alt: "", draggable: !1 })
1166
1261
  }
1167
1262
  )
1168
1263
  ] }),
1169
- /* @__PURE__ */ E.jsx("div", { className: "export-control", children: /* @__PURE__ */ E.jsx(We, { size: "small", type: "primary", loading: uA, onClick: wA, children: "Export" }) })
1264
+ /* @__PURE__ */ w.jsx("div", { className: "export-control", children: /* @__PURE__ */ w.jsx(Ht, { size: "small", type: "primary", loading: kA, onClick: ZA, children: "Export" }) })
1170
1265
  ] });
1171
1266
  };
1172
- function vt() {
1173
- const g = () => typeof window > "u" ? !1 : typeof navigator < "u" && // maxTouchPoints is the most reliable cross-browser hint.
1174
- (navigator.maxTouchPoints ?? 0) > 0, [s, l] = z(g);
1175
- return Ce(() => {
1267
+ function cn() {
1268
+ const B = () => typeof window > "u" ? !1 : typeof navigator < "u" && // maxTouchPoints is the most reliable cross-browser hint.
1269
+ (navigator.maxTouchPoints ?? 0) > 0, [o, d] = cA(B);
1270
+ return Ee(() => {
1176
1271
  if (typeof window > "u" || typeof window.matchMedia != "function") return;
1177
- const u = window.matchMedia("(pointer: coarse)"), f = () => l(!!u.matches || g());
1178
- return f(), typeof u.addEventListener == "function" ? (u.addEventListener("change", f), () => u.removeEventListener("change", f)) : (u.addListener(f), () => u.removeListener(f));
1179
- }, []), s;
1272
+ const c = window.matchMedia("(pointer: coarse)"), l = () => d(!!c.matches || B());
1273
+ return l(), typeof c.addEventListener == "function" ? (c.addEventListener("change", l), () => c.removeEventListener("change", l)) : (c.addListener(l), () => c.removeListener(l));
1274
+ }, []), o;
1180
1275
  }
1181
- const bt = structuredClone(dt), Qe = 5, Te = ({ item: g, hint: s, isDragging: l }) => /* @__PURE__ */ E.jsxs("div", { className: `footage-card${l ? " is-dragging" : ""}`, children: [
1182
- /* @__PURE__ */ E.jsx("div", { className: "footage-name", children: g.name }),
1183
- g.kind === "video" ? /* @__PURE__ */ E.jsx(
1276
+ const gn = "", Bn = "", un = "", Bt = () => [
1277
+ { id: "0", actions: [] },
1278
+ { id: "1", actions: [] },
1279
+ { id: "2", actions: [] },
1280
+ { id: "3", actions: [] }
1281
+ ], ze = 5, ft = ({ item: B, hint: o, isDragging: d }) => /* @__PURE__ */ w.jsxs("div", { className: `footage-card${d ? " is-dragging" : ""}`, children: [
1282
+ /* @__PURE__ */ w.jsx("div", { className: "footage-name", children: B.name }),
1283
+ B.kind === "video" ? /* @__PURE__ */ w.jsx(
1184
1284
  "video",
1185
1285
  {
1186
1286
  className: "footage-preview",
1187
- src: g.src,
1287
+ src: B.src,
1188
1288
  muted: !0,
1189
1289
  preload: "metadata",
1190
1290
  draggable: !1,
1191
- onDragStart: (u) => u.preventDefault(),
1291
+ onDragStart: (c) => c.preventDefault(),
1192
1292
  playsInline: !0
1193
1293
  }
1194
- ) : /* @__PURE__ */ E.jsx(
1294
+ ) : /* @__PURE__ */ w.jsx(
1195
1295
  "audio",
1196
1296
  {
1197
1297
  className: "footage-audio",
1198
- src: g.src,
1298
+ src: B.src,
1199
1299
  controls: !0,
1200
1300
  preload: "metadata",
1201
1301
  draggable: !1,
1202
- onDragStart: (u) => u.preventDefault()
1302
+ onDragStart: (c) => c.preventDefault()
1203
1303
  }
1204
1304
  ),
1205
- /* @__PURE__ */ E.jsx("div", { className: "footage-kind", children: s })
1206
- ] }), pt = ({ item: g, hint: s }) => {
1207
- const { attributes: l, listeners: u, setNodeRef: f, transform: I, isDragging: h } = et({
1208
- id: `footage-${g.id}`,
1209
- data: { item: g }
1210
- }), v = I ? {
1211
- transform: `translate3d(${I.x}px, ${I.y}px, 0)`
1305
+ /* @__PURE__ */ w.jsx("div", { className: "footage-kind", children: o })
1306
+ ] }), ln = ({ item: B, hint: o }) => {
1307
+ const { attributes: d, listeners: c, setNodeRef: l, transform: E, isDragging: m } = Jt({
1308
+ id: `footage-${B.id}`,
1309
+ data: { item: B }
1310
+ }), O = E ? {
1311
+ transform: `translate3d(${E.x}px, ${E.y}px, 0)`
1212
1312
  } : void 0;
1213
- return /* @__PURE__ */ E.jsx("div", { ref: f, style: v, ...u, ...l, children: /* @__PURE__ */ E.jsx(Te, { item: g, hint: s, isDragging: h }) });
1214
- }, Ft = (g) => String(g ?? "").toLowerCase().match(/\.(mp3|wav|m4a|aac|ogg)(\?|#|$)/) ? "audio" : "video", yt = (g, s) => {
1313
+ return /* @__PURE__ */ w.jsx("div", { ref: l, style: O, ...c, ...d, children: /* @__PURE__ */ w.jsx(ft, { item: B, hint: o, isDragging: m }) });
1314
+ }, Ct = (B) => String(B ?? "").toLowerCase().match(/\.(mp3|wav|m4a|aac|ogg)(\?|#|$)/) ? "audio" : "video", dn = (B, o) => {
1215
1315
  try {
1216
- const l = String(g ?? "").split("/").pop() || "";
1217
- return decodeURIComponent(l.split("?")[0].split("#")[0]) || `Footage ${s + 1}`;
1316
+ const d = String(B ?? "").split("/").pop() || "";
1317
+ return decodeURIComponent(d.split("?")[0].split("#")[0]) || `Footage ${o + 1}`;
1218
1318
  } catch {
1219
- return `Footage ${s + 1}`;
1319
+ return `Footage ${o + 1}`;
1220
1320
  }
1221
- }, xt = ({ footageUrls: g }) => {
1222
- const [s, l] = z(bt), [u, f] = z(null), [I, h] = z([]), [v, m] = z([]), b = j(s), y = vt(), p = j(null), q = j(null), W = j(null), uA = j(!0), K = Oe(() => {
1223
- const A = Array.isArray(g) ? g.filter(Boolean) : [];
1224
- return A.length ? A.map((t, n) => ({
1225
- id: `url-${n}`,
1226
- kind: Ft(t),
1227
- name: yt(t, n),
1228
- src: t,
1321
+ }, ut = (B) => {
1322
+ const o = String(B?.type ?? "").toLowerCase();
1323
+ return o.startsWith("audio/") ? "audio" : o.startsWith("video/") ? "video" : Ct(B?.name ?? "");
1324
+ }, In = ({
1325
+ footageUrls: B,
1326
+ footageFiles: o,
1327
+ footageFileHandles: d,
1328
+ autoPlaceFootage: c = !1
1329
+ }) => {
1330
+ const [l, E] = cA(() => Bt()), [m, O] = cA(null), [S, G] = cA([]), [M, z] = cA([]), F = tA(l), BA = cn(), [iA, lA] = cA(!1), oA = tA(null), kA = tA(null), AA = tA(null), Qe = tA(!0), ie = We(() => {
1331
+ const A = Array.isArray(B) ? B.filter(Boolean) : [];
1332
+ return A.length ? A.map((n, t) => ({
1333
+ id: `url-${t}`,
1334
+ kind: Ct(n),
1335
+ name: dn(n, t),
1336
+ src: n,
1229
1337
  defaultDuration: 10
1230
1338
  })) : [];
1231
- }, [g]), [L, Z] = z(null), [S, BA] = z(null), [CA, iA] = z(null), [lA, ie] = z(0), [FA, yA] = z(0), [JA, qA] = z(0), [SA, oA] = z(0), [sA, eA] = z(!1), [UA, wA] = z(null), w = j(null), x = j(null), R = j(null), P = j(null), H = y ? 48 : 32, U = [0, 1], k = [2, 3], IA = ["V1", "V2", "A1", "A2"], dA = (A, t) => {
1232
- if (t.length === 0) return null;
1233
- if (A == null) return t[0];
1234
- let n = t[0], o = Math.abs(A - n);
1235
- for (const r of t) {
1236
- const i = Math.abs(A - r);
1237
- i < o && (n = r, o = i);
1238
- }
1239
- return n;
1240
- }, aA = (A, t) => A ? A.kind === "video" ? dA(t, U) : dA(t, k) : null, NA = (A) => A === U[1] ? k[1] : k[0];
1241
- Ce(() => {
1242
- re.warmFromEditorData(s);
1243
- }, [s]), Ce(() => {
1244
- b.current = s;
1245
- }, [s]), Xe(() => {
1246
- const A = W.current;
1339
+ }, [B]), [oe, se] = cA([]), [ae, ce] = cA([]);
1340
+ Ee(() => {
1341
+ const A = Array.isArray(o) ? o.filter(Boolean) : [];
1342
+ if (A.length === 0) {
1343
+ se([]);
1344
+ return;
1345
+ }
1346
+ const n = [], t = A.map((r, s) => {
1347
+ const i = URL.createObjectURL(r);
1348
+ return n.push(i), qA.registerSrcMeta(i, { name: r.name, mimeType: r.type }), {
1349
+ id: `file-${s}`,
1350
+ kind: ut(r),
1351
+ name: r.name || `Footage ${s + 1}`,
1352
+ src: i,
1353
+ defaultDuration: 10
1354
+ };
1355
+ });
1356
+ return se(t), () => {
1357
+ for (const r of n)
1358
+ try {
1359
+ URL.revokeObjectURL(r);
1360
+ } catch {
1361
+ }
1362
+ };
1363
+ }, [o]), Ee(() => {
1364
+ const A = Array.isArray(d) ? d.filter(Boolean) : [];
1365
+ if (A.length === 0) {
1366
+ ce([]);
1367
+ return;
1368
+ }
1369
+ let n = !1;
1370
+ const t = [];
1371
+ return (async () => {
1372
+ const s = [];
1373
+ for (let i = 0; i < A.length; i++) {
1374
+ const a = A[i];
1375
+ try {
1376
+ const u = await a.getFile();
1377
+ if (n) return;
1378
+ const C = URL.createObjectURL(u);
1379
+ t.push(C), qA.registerSrcMeta(C, { name: u.name || a?.name, mimeType: u.type }), s.push({
1380
+ id: `handle-${i}`,
1381
+ kind: ut(u),
1382
+ name: u.name || a?.name || `Footage ${i + 1}`,
1383
+ src: C,
1384
+ defaultDuration: 10
1385
+ });
1386
+ } catch (u) {
1387
+ console.warn("[MeliesVideoEditor] Failed to load file handle", u);
1388
+ }
1389
+ }
1390
+ n || ce(s);
1391
+ })(), () => {
1392
+ n = !0;
1393
+ for (const s of t)
1394
+ try {
1395
+ URL.revokeObjectURL(s);
1396
+ } catch {
1397
+ }
1398
+ };
1399
+ }, [d]);
1400
+ const JA = We(() => [...ie, ...oe, ...ae], [ie, oe, ae]), [dA, WA] = cA(null), [LA, QA] = cA(null), [pA, wA] = cA(null), [TA, we] = cA(0), [VA, Ie] = cA(0), [ZA, y] = cA(0), [nA, rA] = cA(0), [Z, _] = cA(!1), [sA, gA] = cA(null), IA = tA(null), GA = tA(null), UA = tA(null), _A = tA(null), bA = BA ? 48 : 32, De = 30, [$A, he] = cA(() => Vt), PA = Zt, Oe = (A) => {
1401
+ he((n) => {
1402
+ const t = Math.round(n * A);
1403
+ return Math.min(600, Math.max(60, t));
1404
+ });
1405
+ }, CA = [1, 0], xA = [3, 2], Pe = ["V2", "V1", "A2", "A1"], ge = (A, n) => {
1406
+ if (n.length === 0) return null;
1407
+ if (A == null) return n[0];
1408
+ let t = n[0], r = Math.abs(A - t);
1409
+ for (const s of n) {
1410
+ const i = Math.abs(A - s);
1411
+ i < r && (t = s, r = i);
1412
+ }
1413
+ return t;
1414
+ }, Ae = (A, n) => A ? A.kind === "video" ? ge(n, CA) : ge(n, xA) : null, YA = (A) => A === CA[1] ? xA[1] : xA[0], me = (A) => A === xA[1] ? CA[1] : CA[0], SA = (A, n) => {
1415
+ const t = n === "video" ? CA : xA;
1416
+ return ge(A, t) ?? t[0];
1417
+ }, be = tA(!1);
1418
+ Ee(() => {
1419
+ if (!c || be.current || JA.length === 0 || F.current.some((a) => Array.isArray(a?.actions) && a.actions.length > 0)) return;
1420
+ const t = CA[0], r = YA(t), s = Bt();
1421
+ let i = 0;
1422
+ for (const a of JA) {
1423
+ const u = Math.max(0.01, Number(a.defaultDuration ?? 10)), C = i, I = i + u;
1424
+ if (i = I, a.kind === "video") {
1425
+ const D = `link-${vA()}`, N = CA.findIndex((b) => b === t);
1426
+ s[t].actions.push({
1427
+ id: `video-${vA()}`,
1428
+ start: C,
1429
+ end: I,
1430
+ effectId: "effect1",
1431
+ data: {
1432
+ src: a.src,
1433
+ previewSrc: a.previewSrc,
1434
+ name: a.name,
1435
+ linkId: D,
1436
+ videoLayer: N
1437
+ }
1438
+ }), s[r].actions.push({
1439
+ id: `video-audio-${vA()}`,
1440
+ start: C,
1441
+ end: I,
1442
+ effectId: "effect2",
1443
+ data: {
1444
+ src: a.src,
1445
+ name: a.name,
1446
+ linkId: D
1447
+ }
1448
+ });
1449
+ } else
1450
+ s[r].actions.push({
1451
+ id: `audio-${vA()}`,
1452
+ start: C,
1453
+ end: I,
1454
+ effectId: "effect0",
1455
+ data: {
1456
+ src: a.src,
1457
+ name: a.name
1458
+ }
1459
+ });
1460
+ }
1461
+ O(null), G([]), z([]), E(() => (F.current = s, s)), be.current = !0;
1462
+ }, [c, JA]), Ee(() => {
1463
+ qA.warmFromEditorData(l);
1464
+ }, [l]), Ee(() => {
1465
+ F.current = l;
1466
+ }, [l]), Rt(() => {
1467
+ const A = AA.current;
1247
1468
  if (!A) return;
1248
- const t = () => {
1249
- const o = A.getBoundingClientRect(), r = A.querySelector(".timeline-editor-edit-area");
1250
- if (!r) return;
1251
- const i = r.getBoundingClientRect();
1252
- qA(i.top - o.top), oA(i.left - o.left);
1253
- }, n = requestAnimationFrame(t);
1254
- return window.addEventListener("resize", t), () => {
1255
- cancelAnimationFrame(n), window.removeEventListener("resize", t);
1469
+ const n = () => {
1470
+ const r = A.getBoundingClientRect(), s = A.querySelector(".timeline-editor-edit-area");
1471
+ if (!s) return;
1472
+ const i = s.getBoundingClientRect();
1473
+ y(i.top - r.top), rA(i.left - r.left);
1474
+ }, t = requestAnimationFrame(n);
1475
+ return window.addEventListener("resize", n), () => {
1476
+ cancelAnimationFrame(t), window.removeEventListener("resize", n);
1256
1477
  };
1257
- }, [y, s.length]);
1258
- const GA = (A) => {
1259
- const t = W.current;
1260
- if (!t || !A) return !1;
1261
- const n = t.getBoundingClientRect();
1262
- return A.x >= n.left && A.x <= n.right && A.y >= n.top && A.y <= n.bottom;
1263
- }, WA = j(0), fA = () => globalThis.crypto?.randomUUID ? globalThis.crypto.randomUUID() : `uid-${++WA.current}`, V = j(null), tA = j(null), YA = j(null), TA = 0.9, MA = 1.05, _ = j({ actionId: null, edge: null }), X = j({
1478
+ }, [BA, l.length]);
1479
+ const Fe = (A) => {
1480
+ const n = AA.current;
1481
+ if (!n || !A) return !1;
1482
+ const t = n.getBoundingClientRect();
1483
+ return A.x >= t.left && A.x <= t.right && A.y >= t.top && A.y <= t.bottom;
1484
+ }, qe = tA(0), vA = () => globalThis.crypto?.randomUUID ? globalThis.crypto.randomUUID() : `uid-${++qe.current}`, DA = tA(null), HA = tA(null), Be = tA(null), xe = 0.9, Me = 1.05, RA = tA({ actionId: null, edge: null }), $ = tA({
1264
1485
  actionId: null,
1265
1486
  mode: null,
1266
1487
  dir: null,
1267
1488
  basePointerTime: null,
1268
1489
  lastPointerTime: null,
1490
+ basePointerClientY: null,
1491
+ lastPointerClientY: null,
1492
+ initialRowIndex: 0,
1493
+ committedRowIndex: 0,
1494
+ laneCandidateRowIndex: null,
1495
+ laneCandidateSinceMs: 0,
1496
+ laneIntentRowIndex: null,
1269
1497
  initialStart: 0,
1270
1498
  initialEnd: 0,
1271
1499
  takeover: !1
1272
- }), PA = j(!1), LA = (A) => A.map((t) => {
1273
- const n = (t.actions ?? []).map((o) => `${String(o.id)}@${Number(o.start)}-${Number(o.end)}`).join("|");
1274
- return `${String(t.id)}:${n}`;
1275
- }).join("||"), HA = (A) => {
1276
- const t = structuredClone(A);
1277
- h((n) => {
1278
- const o = [...n, t];
1279
- return o.length > Qe && o.splice(0, o.length - Qe), o;
1280
- }), m([]);
1281
- }, jA = (A, t, n, o) => A < o && t > n, QA = (A, t, n, o) => {
1282
- const r = Array.isArray(A?.actions) ? A.actions : [];
1283
- for (const i of r)
1284
- if (!(!i || i.id === t) && jA(n, o, Number(i.start), Number(i.end)))
1500
+ }), hA = tA({
1501
+ actionId: null,
1502
+ partnerId: null,
1503
+ dir: null,
1504
+ baseStart: 0,
1505
+ baseOffset: 0,
1506
+ partnerBaseOffset: 0
1507
+ }), ue = tA(!1), ee = (A) => A.map((n) => {
1508
+ const t = (n.actions ?? []).map((r) => `${String(r.id)}@${Number(r.start)}-${Number(r.end)}`).join("|");
1509
+ return `${String(n.id)}:${t}`;
1510
+ }).join("||"), yA = (A) => {
1511
+ const n = structuredClone(A);
1512
+ G((t) => {
1513
+ const r = [...t, n];
1514
+ return r.length > ze && r.splice(0, r.length - ze), r;
1515
+ }), z([]);
1516
+ }, te = (A, n, t, r) => A < r && n > t, MA = (A, n, t, r) => {
1517
+ const s = Array.isArray(A?.actions) ? A.actions : [];
1518
+ for (const i of s)
1519
+ if (!(!i || i.id === n) && te(t, r, Number(i.start), Number(i.end)))
1285
1520
  return !0;
1286
1521
  return !1;
1287
- }, KA = (A, t) => {
1288
- for (let n = 0; n < A.length; n++) {
1289
- const o = A[n], r = Array.isArray(o?.actions) ? o.actions : [];
1290
- for (let i = 0; i < r.length; i++) {
1291
- const a = r[i];
1292
- if (String(a?.id) === t)
1293
- return { rowIndex: n, actionIndex: i, action: a };
1522
+ }, mA = (A, n) => {
1523
+ for (let t = 0; t < A.length; t++) {
1524
+ const r = A[t], s = Array.isArray(r?.actions) ? r.actions : [];
1525
+ for (let i = 0; i < s.length; i++) {
1526
+ const a = s[i];
1527
+ if (String(a?.id) === n)
1528
+ return { rowIndex: t, actionIndex: i, action: a };
1294
1529
  }
1295
1530
  }
1296
1531
  return null;
1297
- }, DA = (A, t) => {
1298
- const n = KA(A, t), o = n?.action?.data?.linkId;
1299
- if (!n || !o) return null;
1300
- for (let r = 0; r < A.length; r++) {
1301
- const i = A[r], a = Array.isArray(i?.actions) ? i.actions : [];
1302
- for (let B = 0; B < a.length; B++) {
1303
- const d = a[B];
1304
- if (d?.data?.linkId && String(d.data.linkId) === String(o) && String(d.id) !== String(t))
1305
- return { rowIndex: r, actionIndex: B, action: d };
1532
+ }, KA = (A, n) => {
1533
+ const t = mA(A, n), r = t?.action?.data?.linkId;
1534
+ if (!t || !r) return null;
1535
+ for (let s = 0; s < A.length; s++) {
1536
+ const i = A[s], a = Array.isArray(i?.actions) ? i.actions : [];
1537
+ for (let u = 0; u < a.length; u++) {
1538
+ const C = a[u];
1539
+ if (C?.data?.linkId && String(C.data.linkId) === String(r) && String(C.id) !== String(n))
1540
+ return { rowIndex: s, actionIndex: u, action: C };
1306
1541
  }
1307
1542
  }
1308
1543
  return null;
1309
- }, oe = (A, t) => {
1310
- const n = KA(A, t);
1311
- if (!n) return A;
1312
- const o = DA(A, t);
1313
- if (!o) return A;
1314
- const r = Number(n.action.start), i = Number(n.action.end);
1315
- if (!Number.isFinite(r) || !Number.isFinite(i) || i <= r || Number(o.action.start) === r && Number(o.action.end) === i) return A;
1316
- const a = structuredClone(A), B = a[o.rowIndex], d = Array.isArray(B.actions) ? [...B.actions] : [], Q = { ...d[o.actionIndex], start: r, end: i };
1317
- return d.splice(o.actionIndex, 1, Q), B.actions = d, a;
1318
- }, XA = (A, t, n, o) => {
1319
- if (!Number.isFinite(n) || !Number.isFinite(o) || o <= n) return A;
1320
- const r = KA(A, t);
1544
+ }, ke = (A, n) => {
1545
+ const t = mA(A, n);
1546
+ if (!t) return A;
1547
+ const r = KA(A, n);
1321
1548
  if (!r) return A;
1322
- const i = DA(A, t);
1549
+ const s = Number(t.action.start), i = Number(t.action.end);
1550
+ if (!Number.isFinite(s) || !Number.isFinite(i) || i <= s || Number(r.action.start) === s && Number(r.action.end) === i) return A;
1551
+ const a = structuredClone(A), u = a[r.rowIndex], C = Array.isArray(u.actions) ? [...u.actions] : [], I = { ...C[r.actionIndex], start: s, end: i };
1552
+ return C.splice(r.actionIndex, 1, I), u.actions = C, a;
1553
+ }, Ve = (A, n) => {
1554
+ const t = structuredClone(A);
1555
+ for (; t.length < 4; ) t.push({ id: `${t.length}`, actions: [] });
1556
+ const r = (f) => f && typeof f == "object" ? f : {}, s = (f, R) => {
1557
+ if (!(!f || typeof f != "object"))
1558
+ return f[R];
1559
+ }, i = (f) => String(s(f, "id") ?? ""), a = (f) => String(s(f, "effectId") ?? ""), u = (f) => Number(s(f, "start")), C = (f) => Number(s(f, "end")), I = (f) => s(f, "data"), D = (f) => {
1560
+ if (!f || typeof f != "object") return 0;
1561
+ const R = Number(f.start);
1562
+ return Number.isFinite(R) ? R : 0;
1563
+ }, N = /* @__PURE__ */ new Map(), b = /* @__PURE__ */ new Map();
1564
+ for (let f = 0; f < t.length; f++) {
1565
+ const R = t[f], H = Array.isArray(R?.actions) ? R.actions : [];
1566
+ for (let h = 0; h < H.length; h++) {
1567
+ const U = H[h], L = i(U);
1568
+ if (!L) continue;
1569
+ N.set(L, { rowIndex: f, actionIndex: h, action: U });
1570
+ const T = I(U), q = s(T, "linkId"), aA = q != null ? String(q) : "";
1571
+ if (!aA) continue;
1572
+ const J = b.get(aA) ?? {}, K = a(U);
1573
+ K === "effect1" ? J.video = { rowIndex: f, actionIndex: h, action: U } : K === "effect2" && (J.audio = { rowIndex: f, actionIndex: h, action: U }), b.set(aA, J);
1574
+ }
1575
+ }
1576
+ const p = /* @__PURE__ */ new Map();
1577
+ for (const f of b.values()) {
1578
+ if (!f.video || !f.audio) continue;
1579
+ const R = i(f.video.action), H = i(f.audio.action), h = n && String(n) === H ? "audio" : "video", U = h === "audio" ? me(SA(f.audio.rowIndex, "audio")) : SA(f.video.rowIndex, "video"), L = YA(U), T = h === "audio" ? f.audio.action : f.video.action, q = u(T), aA = C(T), J = Number.isFinite(q) && Number.isFinite(aA) && aA > q, K = Math.max(0, CA.findIndex((V) => V === U));
1580
+ p.set(R, {
1581
+ targetRowIndex: U,
1582
+ patchStartEnd: J ? { start: q, end: aA } : void 0,
1583
+ patchVideoLayer: K
1584
+ }), p.set(H, {
1585
+ targetRowIndex: L,
1586
+ patchStartEnd: J ? { start: q, end: aA } : void 0
1587
+ });
1588
+ }
1589
+ for (const [f, R] of N.entries()) {
1590
+ if (p.has(f)) continue;
1591
+ const H = a(R.action);
1592
+ if (H === "effect1") {
1593
+ const h = SA(R.rowIndex, "video"), U = Math.max(0, CA.findIndex((L) => L === h));
1594
+ p.set(f, { targetRowIndex: h, patchVideoLayer: U });
1595
+ } else if (H === "effect0" || H === "effect2") {
1596
+ const h = SA(R.rowIndex, "audio");
1597
+ p.set(f, { targetRowIndex: h });
1598
+ }
1599
+ }
1600
+ const Y = t.map((f) => ({ ...f, actions: [] }));
1601
+ let x = !1;
1602
+ for (let f = 0; f < t.length; f++) {
1603
+ const R = t[f], H = Array.isArray(R?.actions) ? R.actions : [];
1604
+ for (const h of H) {
1605
+ const U = h, L = i(U);
1606
+ if (!L) continue;
1607
+ const T = p.get(L), q = T ? T.targetRowIndex : f, aA = Y[q] ?? Y[f];
1608
+ let J = U;
1609
+ if (T?.patchStartEnd) {
1610
+ const K = T.patchStartEnd.start, V = T.patchStartEnd.end;
1611
+ (u(J) !== K || C(J) !== V) && (J = { ...r(J), start: K, end: V }, x = !0);
1612
+ }
1613
+ if (T?.patchVideoLayer != null && a(J) === "effect1") {
1614
+ const K = Number(s(I(J), "videoLayer"));
1615
+ if (!Number.isFinite(K) || K !== T.patchVideoLayer) {
1616
+ const V = { ...r(I(J)), videoLayer: T.patchVideoLayer };
1617
+ J = { ...r(J), data: V }, x = !0;
1618
+ }
1619
+ }
1620
+ q !== f && (x = !0), aA.actions.push(J);
1621
+ }
1622
+ }
1623
+ for (const f of Y) {
1624
+ const R = Array.isArray(f.actions) ? [...f.actions] : [];
1625
+ R.sort((H, h) => D(H) - D(h)), f.actions = R;
1626
+ }
1627
+ return x ? Y : A;
1628
+ }, le = (A, n, t, r) => {
1629
+ if (!Number.isFinite(t) || !Number.isFinite(r) || r <= t) return A;
1630
+ const s = mA(A, n);
1631
+ if (!s) return A;
1632
+ const i = KA(A, n);
1323
1633
  if (!i) return A;
1324
- const a = structuredClone(A), B = a[r.rowIndex], d = Array.isArray(B.actions) ? [...B.actions] : [], Q = { ...d[r.actionIndex], start: n, end: o };
1325
- d.splice(r.actionIndex, 1, Q), B.actions = d;
1326
- const C = a[i.rowIndex], F = Array.isArray(C.actions) ? [...C.actions] : [], D = { ...F[i.actionIndex], start: n, end: o };
1327
- return F.splice(i.actionIndex, 1, D), C.actions = F, a;
1328
- }, zA = (A, t, n, o) => {
1329
- if (!Number.isFinite(n) || !Number.isFinite(o) || o <= n) return A;
1330
- const r = KA(A, t);
1331
- if (!r) return A;
1332
- const i = Number(r.action.start), a = Number(r.action.end);
1333
- if (i === n && a === o) return A;
1334
- const B = structuredClone(A), d = B[r.rowIndex], Q = Array.isArray(d.actions) ? [...d.actions] : [], C = { ...Q[r.actionIndex], start: n, end: o };
1335
- return Q.splice(r.actionIndex, 1, C), d.actions = Q, B;
1336
- }, ZA = () => {
1337
- const A = p.current?.getTime ? Number(p.current.getTime()) : 0;
1634
+ const a = structuredClone(A), u = a[s.rowIndex], C = Array.isArray(u.actions) ? [...u.actions] : [], I = { ...C[s.actionIndex], start: t, end: r };
1635
+ C.splice(s.actionIndex, 1, I), u.actions = C;
1636
+ const D = a[i.rowIndex], N = Array.isArray(D.actions) ? [...D.actions] : [], b = { ...N[i.actionIndex], start: t, end: r };
1637
+ return N.splice(i.actionIndex, 1, b), D.actions = N, a;
1638
+ }, de = (A, n, t, r) => {
1639
+ if (!Number.isFinite(t) || !Number.isFinite(r) || r <= t) return A;
1640
+ const s = mA(A, n);
1641
+ if (!s) return A;
1642
+ const i = Number(s.action.start), a = Number(s.action.end);
1643
+ if (i === t && a === r) return A;
1644
+ const u = structuredClone(A), C = u[s.rowIndex], I = Array.isArray(C.actions) ? [...C.actions] : [], D = { ...I[s.actionIndex], start: t, end: r };
1645
+ return I.splice(s.actionIndex, 1, D), C.actions = I, u;
1646
+ }, Je = () => {
1647
+ const A = oA.current?.getTime ? Number(oA.current.getTime()) : 0;
1338
1648
  return Number.isFinite(A) ? Math.max(0, A) : 0;
1339
- }, _A = (A, t, n) => {
1340
- const o = ZA(), r = n - t;
1341
- if (!Number.isFinite(r) || r <= 0)
1342
- return { start: t, end: n, snapped: !1, edge: null };
1343
- const i = Math.abs(t - o), a = Math.abs(n - o), B = i <= a ? "start" : "end", d = Math.min(i, a), Q = _.current;
1344
- if (Q.actionId === A && Q.edge != null) {
1345
- if ((Q.edge === "start" ? i : a) > MA)
1346
- return _.current = { actionId: A, edge: null }, { start: t, end: n, snapped: !1, edge: null };
1649
+ }, Le = (A, n, t) => {
1650
+ const r = Je(), s = t - n;
1651
+ if (!Number.isFinite(s) || s <= 0)
1652
+ return { start: n, end: t, snapped: !1, edge: null };
1653
+ const i = Math.abs(n - r), a = Math.abs(t - r), u = i <= a ? "start" : "end", C = Math.min(i, a), I = RA.current;
1654
+ if (I.actionId === A && I.edge != null) {
1655
+ if ((I.edge === "start" ? i : a) > Me)
1656
+ return RA.current = { actionId: A, edge: null }, { start: n, end: t, snapped: !1, edge: null };
1347
1657
  } else {
1348
- if (d > TA)
1349
- return { start: t, end: n, snapped: !1, edge: null };
1350
- _.current = { actionId: A, edge: B };
1351
- }
1352
- const D = _.current.edge;
1353
- if (D === "start") {
1354
- const M = o, Y = M + r;
1355
- return { start: Math.max(0, M), end: Math.max(Math.max(0, M), Y), snapped: !0, edge: D };
1356
- }
1357
- const N = o, O = N - r;
1358
- return { start: Math.max(0, O), end: Math.max(0, N), snapped: !0, edge: D };
1359
- }, se = (A, t, n, o) => {
1360
- const r = ZA(), i = o === "left" ? "start" : "end", a = Math.abs(i === "start" ? t - r : n - r), B = _.current;
1361
- if (B.actionId === A && B.edge === i) {
1362
- if (a > MA)
1363
- return _.current = { actionId: A, edge: null }, { start: t, end: n, snapped: !1 };
1658
+ if (C > xe)
1659
+ return { start: n, end: t, snapped: !1, edge: null };
1660
+ RA.current = { actionId: A, edge: u };
1661
+ }
1662
+ const b = RA.current.edge;
1663
+ if (b === "start") {
1664
+ const x = r, f = x + s;
1665
+ return { start: Math.max(0, x), end: Math.max(Math.max(0, x), f), snapped: !0, edge: b };
1666
+ }
1667
+ const p = r, Y = p - s;
1668
+ return { start: Math.max(0, Y), end: Math.max(0, p), snapped: !0, edge: b };
1669
+ }, Se = (A, n, t, r) => {
1670
+ const s = Je(), i = r === "left" ? "start" : "end", a = Math.abs(i === "start" ? n - s : t - s), u = RA.current;
1671
+ if (u.actionId === A && u.edge === i) {
1672
+ if (a > Me)
1673
+ return RA.current = { actionId: A, edge: null }, { start: n, end: t, snapped: !1 };
1364
1674
  } else {
1365
- if (a > TA)
1366
- return { start: t, end: n, snapped: !1 };
1367
- _.current = { actionId: A, edge: i };
1675
+ if (a > xe)
1676
+ return { start: n, end: t, snapped: !1 };
1677
+ RA.current = { actionId: A, edge: i };
1368
1678
  }
1369
1679
  if (i === "start") {
1370
- const D = Math.max(0, r), N = Math.max(D + 0.01, n);
1371
- return { start: D, end: N, snapped: !0 };
1372
- }
1373
- const C = Math.max(0, r), F = Math.min(t, C - 0.01);
1374
- return { start: Math.max(0, F), end: C, snapped: !0 };
1375
- }, we = (A, t, n) => {
1376
- const o = A.defaultDuration ?? 10;
1377
- let r = Math.max(0, t), i = r + o;
1378
- const a = p.current;
1379
- a?.isPlaying && a.pause(), l((B) => {
1380
- HA(B);
1381
- const d = structuredClone(B);
1382
- for (; d.length < 4; ) d.push({ id: `${d.length}`, actions: [] });
1383
- const Q = Number.isFinite(Number(n)) ? Number(n) : null, C = dA(Q, U) ?? U[0], F = dA(Q, k) ?? k[0], D = (N) => {
1384
- const O = [];
1385
- for (const M of N) {
1386
- const Y = Array.isArray(d[M]?.actions) ? d[M].actions : [];
1387
- for (const $ of Y) {
1388
- const EA = Number($?.start), mA = Number($?.end);
1389
- !Number.isFinite(EA) || !Number.isFinite(mA) || O.push({ start: EA, end: mA });
1680
+ const b = Math.max(0, s), p = Math.max(b + 0.01, t);
1681
+ return { start: b, end: p, snapped: !0 };
1682
+ }
1683
+ const D = Math.max(0, s), N = Math.min(n, D - 0.01);
1684
+ return { start: Math.max(0, N), end: D, snapped: !0 };
1685
+ }, Ge = (A, n, t) => {
1686
+ const r = A.defaultDuration ?? 10;
1687
+ let s = Math.max(0, n), i = s + r;
1688
+ const a = oA.current;
1689
+ a?.isPlaying && a.pause(), E((u) => {
1690
+ yA(u);
1691
+ const C = structuredClone(u);
1692
+ for (; C.length < 4; ) C.push({ id: `${C.length}`, actions: [] });
1693
+ const I = Number.isFinite(Number(t)) ? Number(t) : null, D = ge(I, CA) ?? CA[0], N = ge(I, xA) ?? xA[0], b = (p) => {
1694
+ const Y = [];
1695
+ for (const x of p) {
1696
+ const f = Array.isArray(C[x]?.actions) ? C[x].actions : [];
1697
+ for (const R of f) {
1698
+ const H = Number(R?.start), h = Number(R?.end);
1699
+ !Number.isFinite(H) || !Number.isFinite(h) || Y.push({ start: H, end: h });
1390
1700
  }
1391
1701
  }
1392
- O.sort((M, Y) => M.start - Y.start);
1393
- for (const M of O)
1394
- jA(r, i, M.start, M.end) && (r = M.end, i = r + o);
1702
+ Y.sort((x, f) => x.start - f.start);
1703
+ for (const x of Y)
1704
+ te(s, i, x.start, x.end) && (s = x.end, i = s + r);
1395
1705
  };
1396
1706
  if (A.kind === "video") {
1397
- const N = C, O = NA(N);
1398
- D([N, O]);
1399
- const M = `link-${fA()}`, Y = `video-${fA()}`, $ = `video-audio-${fA()}`;
1400
- d[N].actions = [
1401
- ...d[N].actions ?? [],
1707
+ const p = D, Y = YA(p);
1708
+ b([p, Y]);
1709
+ const x = `link-${vA()}`, f = `video-${vA()}`, R = `video-audio-${vA()}`, H = CA.findIndex((h) => h === p);
1710
+ C[p].actions = [
1711
+ ...C[p].actions ?? [],
1402
1712
  {
1403
- id: Y,
1404
- start: r,
1713
+ id: f,
1714
+ start: s,
1405
1715
  end: i,
1406
1716
  effectId: "effect1",
1407
- data: { src: A.src, previewSrc: A.previewSrc, name: A.name, linkId: M }
1717
+ data: { src: A.src, previewSrc: A.previewSrc, name: A.name, linkId: x, videoLayer: H }
1408
1718
  }
1409
- ], d[O].actions = [
1410
- ...d[O].actions ?? [],
1719
+ ], C[Y].actions = [
1720
+ ...C[Y].actions ?? [],
1411
1721
  {
1412
- id: $,
1413
- start: r,
1722
+ id: R,
1723
+ start: s,
1414
1724
  end: i,
1415
1725
  effectId: "effect2",
1416
- data: { src: A.src, name: A.name, linkId: M }
1726
+ data: { src: A.src, name: A.name, linkId: x }
1417
1727
  }
1418
1728
  ];
1419
1729
  } else {
1420
- const N = F;
1421
- D([N]), d[N].actions = [
1422
- ...d[N].actions ?? [],
1730
+ const p = N;
1731
+ b([p]), C[p].actions = [
1732
+ ...C[p].actions ?? [],
1423
1733
  {
1424
- id: `audio-${fA()}`,
1425
- start: r,
1734
+ id: `audio-${vA()}`,
1735
+ start: s,
1426
1736
  end: i,
1427
1737
  effectId: "effect0",
1428
1738
  data: { src: A.src, name: A.name }
1429
1739
  }
1430
1740
  ];
1431
1741
  }
1432
- return d;
1742
+ return C;
1433
1743
  });
1434
- }, Ie = () => {
1435
- const A = W.current;
1744
+ }, Ze = () => {
1745
+ const A = AA.current;
1436
1746
  return A ? A.querySelector(".timeline-editor-edit-area .ReactVirtualized__Grid")?.scrollLeft ?? 0 : 0;
1437
- }, De = () => lA, kA = (A) => {
1438
- const t = W.current;
1439
- if (!t) return 0;
1440
- const o = (t.querySelector(".timeline-editor-edit-area") ?? t).getBoundingClientRect(), a = (A - o.x + Ie() - Ee) * ne / te;
1747
+ }, _e = () => TA, fe = (A) => {
1748
+ const n = AA.current;
1749
+ if (!n) return 0;
1750
+ const r = (n.querySelector(".timeline-editor-edit-area") ?? n).getBoundingClientRect(), a = (A - r.x + Ze() - De) * PA / $A;
1441
1751
  return Math.max(0, a);
1442
- }, he = (A) => {
1443
- const t = Number(A);
1444
- return Number.isFinite(t) ? Ee + t * te / ne : 0;
1445
- }, me = (A, t, n, o) => {
1446
- const r = A.defaultDuration ?? 10;
1447
- let i = Math.max(0, t), a = i + r;
1448
- const B = [];
1752
+ }, Ye = (A) => {
1753
+ const n = Number(A);
1754
+ return Number.isFinite(n) ? De + n * $A / PA : 0;
1755
+ }, e = (A, n, t, r) => {
1756
+ const s = A.defaultDuration ?? 10;
1757
+ let i = Math.max(0, n), a = i + s;
1758
+ const u = [];
1449
1759
  if (A.kind === "video") {
1450
- const Q = n, C = NA(Q);
1451
- B.push(Q, C);
1760
+ const I = t, D = YA(I);
1761
+ u.push(I, D);
1452
1762
  } else
1453
- B.push(n);
1454
- const d = [];
1455
- for (const Q of B) {
1456
- const C = Array.isArray(o[Q]?.actions) ? o[Q].actions : [];
1457
- for (const F of C) {
1458
- const D = Number(F?.start), N = Number(F?.end);
1459
- !Number.isFinite(D) || !Number.isFinite(N) || d.push({ start: D, end: N });
1763
+ u.push(t);
1764
+ const C = [];
1765
+ for (const I of u) {
1766
+ const D = Array.isArray(r[I]?.actions) ? r[I].actions : [];
1767
+ for (const N of D) {
1768
+ const b = Number(N?.start), p = Number(N?.end);
1769
+ !Number.isFinite(b) || !Number.isFinite(p) || C.push({ start: b, end: p });
1460
1770
  }
1461
1771
  }
1462
- d.sort((Q, C) => Q.start - C.start);
1463
- for (const Q of d)
1464
- jA(i, a, Q.start, Q.end) && (i = Q.end, a = i + r);
1772
+ C.sort((I, D) => I.start - D.start);
1773
+ for (const I of C)
1774
+ te(i, a, I.start, I.end) && (i = I.end, a = i + s);
1465
1775
  return Math.max(0, i);
1466
- }, OA = (A) => {
1467
- const t = W.current;
1468
- if (!t) return null;
1469
- const n = t.querySelector(".timeline-editor-edit-area");
1776
+ }, g = (A) => {
1777
+ const n = AA.current;
1470
1778
  if (!n) return null;
1471
- const o = n.getBoundingClientRect(), r = A - o.y;
1472
- if (r < 0 || r > o.height) return null;
1473
- const i = r + De(), a = Math.floor(i / H);
1779
+ const t = n.querySelector(".timeline-editor-edit-area");
1780
+ if (!t) return null;
1781
+ const r = t.getBoundingClientRect(), s = A - r.y;
1782
+ if (s < 0 || s > r.height) return null;
1783
+ const i = s + _e(), a = Math.floor(i / bA);
1474
1784
  if (!Number.isFinite(a)) return null;
1475
- const B = Math.max(0, b.current.length - 1);
1476
- return Math.min(Math.max(0, a), B);
1477
- }, ae = (A) => {
1785
+ const u = Math.max(0, F.current.length - 1);
1786
+ return Math.min(Math.max(0, a), u);
1787
+ }, Q = (A) => {
1478
1788
  if (!A) return null;
1479
1789
  if ("clientX" in A && "clientY" in A) {
1480
- const r = Number(A.clientX), i = Number(A.clientY);
1481
- if (Number.isFinite(r) && Number.isFinite(i)) return { x: r, y: i };
1790
+ const s = Number(A.clientX), i = Number(A.clientY);
1791
+ if (Number.isFinite(s) && Number.isFinite(i)) return { x: s, y: i };
1482
1792
  }
1483
- const t = A.touches, n = A.changedTouches, o = (t && t.length ? t[0] : null) || (n && n.length ? n[0] : null);
1484
- if (o) {
1485
- const r = Number(o.clientX), i = Number(o.clientY);
1486
- if (Number.isFinite(r) && Number.isFinite(i)) return { x: r, y: i };
1793
+ const n = A.touches, t = A.changedTouches, r = (n && n.length ? n[0] : null) || (t && t.length ? t[0] : null);
1794
+ if (r) {
1795
+ const s = Number(r.clientX), i = Number(r.clientY);
1796
+ if (Number.isFinite(s) && Number.isFinite(i)) return { x: s, y: i };
1487
1797
  }
1488
1798
  return null;
1489
- }, cA = () => {
1490
- if (PA.current) return;
1491
- PA.current = !0;
1492
- const A = (n) => {
1493
- const o = X.current;
1494
- if (!o.actionId || !o.mode || n.isPrimary === !1) return;
1495
- const r = kA(n.clientX);
1496
- o.basePointerTime == null && (o.basePointerTime = r), o.lastPointerTime = r;
1497
- }, t = () => {
1498
- X.current = {
1499
- actionId: null,
1500
- mode: null,
1501
- dir: null,
1502
- basePointerTime: null,
1503
- lastPointerTime: null,
1504
- initialStart: 0,
1505
- initialEnd: 0,
1506
- takeover: !1
1507
- }, _.current = { actionId: null, edge: null };
1799
+ }, v = () => {
1800
+ if (ue.current) return;
1801
+ ue.current = !0;
1802
+ const A = (t) => {
1803
+ const r = $.current;
1804
+ if (!r.actionId || !r.mode || t.isPrimary === !1) return;
1805
+ const s = fe(t.clientX);
1806
+ r.basePointerTime == null && (r.basePointerTime = s), r.lastPointerTime = s, r.basePointerClientY == null && (r.basePointerClientY = t.clientY), r.lastPointerClientY = t.clientY;
1807
+ }, n = () => {
1808
+ const t = {
1809
+ actionId: $.current.actionId,
1810
+ mode: $.current.mode
1811
+ };
1812
+ requestAnimationFrame(() => {
1813
+ $.current.actionId === t.actionId && $.current.mode === t.mode && ($.current = {
1814
+ actionId: null,
1815
+ mode: null,
1816
+ dir: null,
1817
+ basePointerTime: null,
1818
+ lastPointerTime: null,
1819
+ basePointerClientY: null,
1820
+ lastPointerClientY: null,
1821
+ initialRowIndex: 0,
1822
+ committedRowIndex: 0,
1823
+ laneCandidateRowIndex: null,
1824
+ laneCandidateSinceMs: 0,
1825
+ laneIntentRowIndex: null,
1826
+ initialStart: 0,
1827
+ initialEnd: 0,
1828
+ takeover: !1
1829
+ }, RA.current = { actionId: null, edge: null });
1830
+ });
1508
1831
  };
1509
- window.addEventListener("pointermove", A, { capture: !0 }), window.addEventListener("pointerup", t, { capture: !0 }), window.addEventListener("pointercancel", t, { capture: !0 }), X.current._removePointerListeners = () => {
1510
- window.removeEventListener("pointermove", A, { capture: !0 }), window.removeEventListener("pointerup", t, { capture: !0 }), window.removeEventListener("pointercancel", t, { capture: !0 }), PA.current = !1;
1832
+ window.addEventListener("pointermove", A, { capture: !0 }), window.addEventListener("pointerup", n, { capture: !0 }), window.addEventListener("pointercancel", n, { capture: !0 }), $.current._removePointerListeners = () => {
1833
+ window.removeEventListener("pointermove", A, { capture: !0 }), window.removeEventListener("pointerup", n, { capture: !0 }), window.removeEventListener("pointercancel", n, { capture: !0 }), ue.current = !1;
1511
1834
  };
1512
- }, VA = () => {
1513
- const A = X.current?._removePointerListeners;
1514
- A?.(), delete X.current._removePointerListeners;
1515
- }, $A = (A) => A.map((t) => ({
1516
- ...t,
1835
+ }, j = () => {
1836
+ const A = $.current?._removePointerListeners;
1837
+ A?.(), delete $.current._removePointerListeners;
1838
+ }, W = tA(!1), k = (A) => {
1839
+ const n = Number(A?.data?.offset ?? 0);
1840
+ return Number.isFinite(n) ? n : 0;
1841
+ }, P = (A, n, t) => {
1842
+ const r = mA(A, n);
1843
+ if (!r) return A;
1844
+ const s = Math.max(0, Number.isFinite(t) ? t : 0);
1845
+ if (k(r.action) === s) return A;
1846
+ const a = structuredClone(A), u = a[r.rowIndex], C = Array.isArray(u.actions) ? [...u.actions] : [], I = {
1847
+ ...C[r.actionIndex],
1848
+ data: { ...C[r.actionIndex]?.data ?? {}, offset: s }
1849
+ };
1850
+ return C.splice(r.actionIndex, 1, I), u.actions = C, a;
1851
+ }, fA = (A, n, t, r) => {
1852
+ const s = mA(A, n);
1853
+ if (!s) return A;
1854
+ const i = KA(A, n);
1855
+ if (!i) return P(A, n, t);
1856
+ const a = Math.max(0, Number.isFinite(t) ? t : 0), u = Math.max(0, Number.isFinite(Number(r)) ? Number(r) : a), C = structuredClone(A), I = C[s.rowIndex], D = Array.isArray(I.actions) ? [...I.actions] : [], N = {
1857
+ ...D[s.actionIndex],
1858
+ data: { ...D[s.actionIndex]?.data ?? {}, offset: a }
1859
+ };
1860
+ D.splice(s.actionIndex, 1, N), I.actions = D;
1861
+ const b = C[i.rowIndex], p = Array.isArray(b.actions) ? [...b.actions] : [], Y = {
1862
+ ...p[i.actionIndex],
1863
+ data: { ...p[i.actionIndex]?.data ?? {}, offset: u }
1864
+ };
1865
+ return p.splice(i.actionIndex, 1, Y), b.actions = p, C;
1866
+ }, [X, eA] = cA(null), OA = (A, n, t) => {
1867
+ const r = mA(A, n);
1868
+ if (!r) return A;
1869
+ const i = String(r.action?.effectId ?? "") === "effect1" ? "video" : "audio", a = SA(t, i), u = KA(A, n), C = !!u, I = /* @__PURE__ */ new Set([String(n)]);
1870
+ u && I.add(String(u.action.id));
1871
+ const D = Number(r.action?.start), N = Number(r.action?.end);
1872
+ if (!Number.isFinite(D) || !Number.isFinite(N) || N <= D) return A;
1873
+ const b = (h, U, L) => {
1874
+ const T = Array.isArray(h?.actions) ? h.actions : [];
1875
+ for (const q of T) {
1876
+ const aA = String(q?.id ?? "");
1877
+ if (!(aA && I.has(aA)) && te(U, L, Number(q?.start), Number(q?.end)))
1878
+ return !1;
1879
+ }
1880
+ return !0;
1881
+ };
1882
+ let p = null, Y = null;
1883
+ if (C && (i === "video" ? (p = a, Y = YA(p)) : (Y = a, p = me(Y))), i === "video") {
1884
+ if (!b(A[a], D, N)) return A;
1885
+ } else if (!b(A[a], D, N)) return A;
1886
+ if (p != null && !b(A[p], D, N) || Y != null && !b(A[Y], D, N) || !C && r.rowIndex === a) return A;
1887
+ if (C && i === "video" && r.rowIndex === p) {
1888
+ const h = u ? mA(A, String(u.action.id)) : null;
1889
+ if (h && h.rowIndex === Y) return A;
1890
+ }
1891
+ if (C && i === "audio" && r.rowIndex === Y) {
1892
+ const h = u ? mA(A, String(u.action.id)) : null;
1893
+ if (h && h.rowIndex === p) return A;
1894
+ }
1895
+ const x = structuredClone(A);
1896
+ for (; x.length < 4; ) x.push({ id: `${x.length}`, actions: [] });
1897
+ const f = (h, U) => {
1898
+ const L = Array.isArray(h.actions) ? h.actions : [];
1899
+ h.actions = L.filter((T) => String(T?.id ?? "") !== U);
1900
+ }, R = (h, U) => {
1901
+ const L = x[h];
1902
+ L.actions = [...L.actions ?? [], U], L.actions.sort((T, q) => Number(T.start) - Number(q.start));
1903
+ };
1904
+ f(x[r.rowIndex], String(n));
1905
+ let H = r.action;
1906
+ if (i === "video") {
1907
+ const h = Math.max(0, CA.findIndex((U) => U === a));
1908
+ H = {
1909
+ ...H,
1910
+ data: { ...H.data ?? {}, videoLayer: h }
1911
+ };
1912
+ }
1913
+ if (R(a, H), u && p != null && Y != null) {
1914
+ const h = mA(A, String(u.action.id));
1915
+ if (h) {
1916
+ f(x[h.rowIndex], String(u.action.id));
1917
+ const U = i === "video" ? Y : p;
1918
+ let L = h.action;
1919
+ if (String(L?.effectId ?? "") === "effect1") {
1920
+ const q = Math.max(0, CA.findIndex((aA) => aA === U));
1921
+ L = { ...L, data: { ...L.data ?? {}, videoLayer: q } };
1922
+ }
1923
+ R(U, L);
1924
+ }
1925
+ }
1926
+ return x;
1927
+ }, ne = (A) => A.map((n) => ({
1928
+ ...n,
1517
1929
  selected: void 0,
1518
- actions: (t.actions ?? []).map((n) => ({ ...n, selected: void 0 }))
1519
- })), ce = Oe(() => s.map((A, t) => {
1520
- const n = u ? (A.actions ?? []).some((a) => String(a.id) === u) : !1, o = L != null && CA != null && t === CA, r = Array.isArray(A.classNames) ? A.classNames : [], i = o ? [...r, "dnd-drop-hover"] : r;
1930
+ actions: (n.actions ?? []).map((t) => ({ ...t, selected: void 0 }))
1931
+ })), XA = We(() => l.map((A, n) => {
1932
+ const t = m ? (A.actions ?? []).some((a) => String(a.id) === m) : !1, r = dA != null && pA != null && n === pA, s = Array.isArray(A.classNames) ? A.classNames : [], i = r ? [...s, "dnd-drop-hover"] : s;
1521
1933
  return {
1522
1934
  ...A,
1523
1935
  classNames: i,
1524
- selected: n,
1936
+ selected: t,
1525
1937
  actions: (A.actions ?? []).map((a) => ({
1526
1938
  ...a,
1527
- selected: u ? String(a.id) === u : !1
1939
+ selected: m ? String(a.id) === m : !1
1528
1940
  }))
1529
1941
  };
1530
- }), [s, u, L, CA]), ve = () => {
1531
- if (!u) return;
1532
- const A = p.current;
1533
- A?.isPlaying && A.pause(), l((t) => {
1534
- HA(t);
1535
- let n = null;
1536
- for (const r of t) {
1537
- const i = Array.isArray(r?.actions) ? r.actions : [];
1942
+ }), [l, m, dA, pA]), FA = () => {
1943
+ if (!m) return;
1944
+ const A = oA.current;
1945
+ A?.isPlaying && A.pause(), E((n) => {
1946
+ yA(n);
1947
+ let t = null;
1948
+ for (const s of n) {
1949
+ const i = Array.isArray(s?.actions) ? s.actions : [];
1538
1950
  for (const a of i) {
1539
- if (String(a?.id) !== u) continue;
1540
- const B = a?.data?.linkId;
1541
- B != null && (n = String(B));
1951
+ if (String(a?.id) !== m) continue;
1952
+ const u = a?.data?.linkId;
1953
+ u != null && (t = String(u));
1542
1954
  break;
1543
1955
  }
1544
- if (n != null) break;
1956
+ if (t != null) break;
1545
1957
  }
1546
- return t.map((r) => ({
1547
- ...r,
1548
- actions: (r.actions ?? []).filter((i) => !(String(i?.id) === u || n && String(i?.data?.linkId ?? "") === n))
1958
+ return n.map((s) => ({
1959
+ ...s,
1960
+ actions: (s.actions ?? []).filter((i) => !(String(i?.id) === m || t && String(i?.data?.linkId ?? "") === t))
1549
1961
  }));
1550
- }), f(null);
1551
- }, ge = () => {
1552
- if (!u) return;
1553
- const A = p.current, t = A?.getTime ? A.getTime() : null;
1554
- if (t == null) return;
1555
- const n = Number(t);
1556
- Number.isFinite(n) && (A?.isPlaying && A.pause(), V.current = null, tA.current = null, l((o) => {
1557
- let r = -1, i = -1, a = null;
1558
- for (let T = 0; T < o.length; T++) {
1559
- const J = o[T], nA = Array.isArray(J?.actions) ? J.actions : [];
1560
- for (let AA = 0; AA < nA.length; AA++) {
1561
- const RA = nA[AA];
1562
- if (String(RA?.id) === u) {
1563
- r = T, i = AA, a = RA;
1962
+ }), O(null);
1963
+ }, He = () => {
1964
+ if (!m) return;
1965
+ const A = oA.current, n = A?.getTime ? A.getTime() : null;
1966
+ if (n == null) return;
1967
+ const t = Number(n);
1968
+ Number.isFinite(t) && (A?.isPlaying && A.pause(), DA.current = null, HA.current = null, E((r) => {
1969
+ let s = -1, i = -1, a = null;
1970
+ for (let J = 0; J < r.length; J++) {
1971
+ const K = r[J], V = Array.isArray(K?.actions) ? K.actions : [];
1972
+ for (let uA = 0; uA < V.length; uA++) {
1973
+ const EA = V[uA];
1974
+ if (String(EA?.id) === m) {
1975
+ s = J, i = uA, a = EA;
1564
1976
  break;
1565
1977
  }
1566
1978
  }
1567
1979
  if (a) break;
1568
1980
  }
1569
- if (!a) return o;
1570
- const B = a?.data?.linkId ? String(a.data.linkId) : null;
1571
- let d = -1, Q = -1, C = null;
1572
- if (B)
1573
- for (let T = 0; T < o.length; T++) {
1574
- const J = o[T], nA = Array.isArray(J?.actions) ? J.actions : [];
1575
- for (let AA = 0; AA < nA.length; AA++) {
1576
- const RA = nA[AA];
1577
- if (String(RA?.id) !== u && String(RA?.data?.linkId ?? "") === B) {
1578
- d = T, Q = AA, C = RA;
1981
+ if (!a) return r;
1982
+ const u = a?.data?.linkId ? String(a.data.linkId) : null;
1983
+ let C = -1, I = -1, D = null;
1984
+ if (u)
1985
+ for (let J = 0; J < r.length; J++) {
1986
+ const K = r[J], V = Array.isArray(K?.actions) ? K.actions : [];
1987
+ for (let uA = 0; uA < V.length; uA++) {
1988
+ const EA = V[uA];
1989
+ if (String(EA?.id) !== m && String(EA?.data?.linkId ?? "") === u) {
1990
+ C = J, I = uA, D = EA;
1579
1991
  break;
1580
1992
  }
1581
1993
  }
1582
- if (C) break;
1994
+ if (D) break;
1583
1995
  }
1584
- const F = Number(a.start), D = Number(a.end);
1585
- if (!Number.isFinite(F) || !Number.isFinite(D) || !(F < n && n < D)) return o;
1586
- HA(o);
1587
- const N = B && C ? `link-${fA()}` : B, O = B && C ? `link-${fA()}` : B, M = `${String(a.id)}-r-${fA()}`, Y = Number(a?.data?.offset ?? 0), $ = Number.isFinite(Y) ? Y : 0, EA = n - F, mA = $ + (Number.isFinite(EA) ? EA : 0), xA = {
1996
+ const N = Number(a.start), b = Number(a.end);
1997
+ if (!Number.isFinite(N) || !Number.isFinite(b) || !(N < t && t < b)) return r;
1998
+ yA(r);
1999
+ const p = u && D ? `link-${vA()}` : u, Y = u && D ? `link-${vA()}` : u, x = `${String(a.id)}-r-${vA()}`, f = Number(a?.data?.offset ?? 0), R = Number.isFinite(f) ? f : 0, H = t - N, h = R + (Number.isFinite(H) ? H : 0), U = {
1588
2000
  ...a,
1589
- start: F,
1590
- end: n,
2001
+ start: N,
2002
+ end: t,
1591
2003
  id: a.id,
1592
- data: { ...a.data, offset: $, linkId: N ?? void 0 }
1593
- }, vA = {
2004
+ data: { ...a.data, offset: R, linkId: p ?? void 0 }
2005
+ }, L = {
1594
2006
  ...a,
1595
- start: n,
1596
- end: D,
1597
- id: M,
1598
- data: { ...a.data, offset: mA, linkId: O ?? void 0 }
1599
- }, bA = structuredClone(o), gA = bA[r], pA = Array.isArray(gA.actions) ? [...gA.actions] : [];
1600
- if (pA.splice(i, 1, xA, vA), pA.sort((T, J) => Number(T.start) - Number(J.start)), gA.actions = pA, C && d >= 0 && Q >= 0) {
1601
- const T = Number(C.start), J = Number(C.end);
1602
- if (Number.isFinite(T) && Number.isFinite(J) && T === F && J === D) {
1603
- const nA = `${String(C.id)}-r-${fA()}`, AA = {
1604
- ...C,
1605
- start: F,
1606
- end: n,
1607
- id: C.id,
1608
- data: { ...C.data, linkId: N ?? void 0 }
1609
- }, RA = {
1610
- ...C,
1611
- start: n,
1612
- end: D,
1613
- id: nA,
1614
- data: { ...C.data, linkId: O ?? void 0 }
1615
- }, Pe = bA[d], He = Array.isArray(Pe.actions) ? [...Pe.actions] : [];
1616
- He.splice(Q, 1, AA, RA), He.sort((Le, je) => Number(Le.start) - Number(je.start)), Pe.actions = He;
2007
+ start: t,
2008
+ end: b,
2009
+ id: x,
2010
+ data: { ...a.data, offset: h, linkId: Y ?? void 0 }
2011
+ }, T = structuredClone(r), q = T[s], aA = Array.isArray(q.actions) ? [...q.actions] : [];
2012
+ if (aA.splice(i, 1, U, L), aA.sort((J, K) => Number(J.start) - Number(K.start)), q.actions = aA, D && C >= 0 && I >= 0) {
2013
+ const J = Number(D.start), K = Number(D.end);
2014
+ if (Number.isFinite(J) && Number.isFinite(K) && J === N && K === b) {
2015
+ const V = Number(D?.data?.offset), uA = Number.isFinite(V) ? V : R, EA = uA + (Number.isFinite(H) ? H : 0), zA = `${String(D.id)}-r-${vA()}`, pe = {
2016
+ ...D,
2017
+ start: N,
2018
+ end: t,
2019
+ id: D.id,
2020
+ data: { ...D.data, offset: uA, linkId: p ?? void 0 }
2021
+ }, re = {
2022
+ ...D,
2023
+ start: t,
2024
+ end: b,
2025
+ id: zA,
2026
+ data: { ...D.data, offset: EA, linkId: Y ?? void 0 }
2027
+ }, ve = T[C], Re = Array.isArray(ve.actions) ? [...ve.actions] : [];
2028
+ Re.splice(I, 1, pe, re), Re.sort((Ke, je) => Number(Ke.start) - Number(je.start)), ve.actions = Re;
1617
2029
  }
1618
2030
  }
1619
- return bA;
2031
+ return T;
1620
2032
  }));
1621
- }, be = () => {
1622
- const A = p.current, t = A?.getTime ? A.getTime() : null;
1623
- A?.isPlaying && A.pause(), V.current = null, tA.current = null, f(null), h((n) => {
1624
- if (n.length === 0) return n;
1625
- const o = n[n.length - 1], r = structuredClone(b.current);
1626
- return m((i) => [...i, r]), l(structuredClone(o)), n.slice(0, -1);
1627
- }), t != null && requestAnimationFrame(() => {
1628
- const n = p.current;
1629
- n?.setTime && n.setTime(t);
2033
+ }, $e = () => {
2034
+ const A = oA.current, n = A?.getTime ? A.getTime() : null;
2035
+ A?.isPlaying && A.pause(), DA.current = null, HA.current = null, O(null), G((t) => {
2036
+ if (t.length === 0) return t;
2037
+ const r = t[t.length - 1], s = structuredClone(F.current);
2038
+ return z((i) => [...i, s]), E(structuredClone(r)), t.slice(0, -1);
2039
+ }), n != null && requestAnimationFrame(() => {
2040
+ const t = oA.current;
2041
+ t?.setTime && t.setTime(n);
1630
2042
  });
1631
- }, ue = () => {
1632
- const A = p.current, t = A?.getTime ? A.getTime() : null;
1633
- A?.isPlaying && A.pause(), V.current = null, tA.current = null, f(null), m((n) => {
1634
- if (n.length === 0) return n;
1635
- const o = n[n.length - 1], r = structuredClone(b.current);
1636
- return h((i) => {
1637
- const a = [...i, r];
1638
- return a.length > Qe && a.splice(0, a.length - Qe), a;
1639
- }), l(structuredClone(o)), n.slice(0, -1);
1640
- }), t != null && requestAnimationFrame(() => {
1641
- const n = p.current;
1642
- n?.setTime && n.setTime(t);
2043
+ }, At = () => {
2044
+ const A = oA.current, n = A?.getTime ? A.getTime() : null;
2045
+ A?.isPlaying && A.pause(), DA.current = null, HA.current = null, O(null), z((t) => {
2046
+ if (t.length === 0) return t;
2047
+ const r = t[t.length - 1], s = structuredClone(F.current);
2048
+ return G((i) => {
2049
+ const a = [...i, s];
2050
+ return a.length > ze && a.splice(0, a.length - ze), a;
2051
+ }), E(structuredClone(r)), t.slice(0, -1);
2052
+ }), n != null && requestAnimationFrame(() => {
2053
+ const t = oA.current;
2054
+ t?.setTime && t.setTime(n);
1643
2055
  });
1644
- }, Be = Ke(
1645
- xe(ze, { activationConstraint: { distance: 6 } }),
2056
+ }, Et = yt(
2057
+ rt(Nt, { activationConstraint: { distance: 6 } }),
1646
2058
  // On touch, require a short press-hold before starting drag, so scroll is still possible.
1647
- xe(Ve, { activationConstraint: { delay: 180, tolerance: 6 } })
1648
- ), { setNodeRef: pe, isOver: Fe } = Ze({ id: "timeline-drop" }), le = (A) => {
1649
- const t = A.active.data.current?.item;
1650
- Z(t ?? null);
1651
- const n = ae(A.activatorEvent);
1652
- if (w.current = n, x.current = n, wA(n), n) {
1653
- const r = GA(n);
1654
- eA(r);
1655
- const i = OA(n.y);
1656
- iA(r ? aA(t ?? null, i) : null);
2059
+ rt(Ut, { activationConstraint: { delay: 180, tolerance: 6 } })
2060
+ ), { setNodeRef: Qt, isOver: wt } = Pt({ id: "timeline-drop" }), It = (A) => {
2061
+ const n = A.active.data.current?.item;
2062
+ WA(n ?? null);
2063
+ const t = Q(A.activatorEvent);
2064
+ if (IA.current = t, GA.current = t, gA(t), t) {
2065
+ const s = Fe(t);
2066
+ _(s);
2067
+ const i = g(t.y);
2068
+ wA(s ? Ae(n ?? null, i) : null);
1657
2069
  } else
1658
- iA(null), eA(!1);
1659
- const o = A.active.rect.current.initial;
1660
- BA(o ? { width: o.width, height: o.height } : null);
1661
- }, de = (A) => {
1662
- const t = A.active.rect.current.initial;
1663
- !S && t && BA({ width: t.width, height: t.height });
1664
- const n = x.current;
1665
- if (!n) {
1666
- iA(null);
2070
+ wA(null), _(!1);
2071
+ const r = A.active.rect.current.initial;
2072
+ QA(r ? { width: r.width, height: r.height } : null);
2073
+ }, Dt = (A) => {
2074
+ const n = A.active.rect.current.initial;
2075
+ !LA && n && QA({ width: n.width, height: n.height });
2076
+ const t = GA.current;
2077
+ if (!t) {
2078
+ wA(null);
1667
2079
  return;
1668
2080
  }
1669
- const o = Number(A?.delta?.x ?? 0), r = Number(A?.delta?.y ?? 0), i = { x: n.x + (Number.isFinite(o) ? o : 0), y: n.y + (Number.isFinite(r) ? r : 0) };
1670
- w.current = i, wA(i);
1671
- const a = GA(i);
1672
- eA(a);
1673
- const B = OA(i.y);
1674
- iA(a ? aA(L, B) : null);
1675
- }, ye = (A) => {
1676
- const t = A.active.data.current?.item, n = x.current, o = Number(A?.delta?.x ?? 0), r = Number(A?.delta?.y ?? 0), i = n ? { x: n.x + (Number.isFinite(o) ? o : 0), y: n.y + (Number.isFinite(r) ? r : 0) } : w.current;
1677
- w.current = i;
1678
- const B = String(A.over?.id ?? "") === "timeline-drop" || GA(i);
1679
- if (t && B && i) {
1680
- const d = kA(i.x), Q = OA(i.y), C = aA(t, Q);
1681
- iA(C), we(t, Math.max(0, d), C);
1682
- }
1683
- Z(null), BA(null), iA(null), eA(!1), wA(null), x.current = null;
1684
- }, Ne = () => {
1685
- Z(null), BA(null), iA(null), eA(!1), wA(null), x.current = null;
1686
- }, hA = Oe(() => {
1687
- if (!L || !sA) return null;
1688
- const A = UA;
2081
+ const r = Number(A?.delta?.x ?? 0), s = Number(A?.delta?.y ?? 0), i = { x: t.x + (Number.isFinite(r) ? r : 0), y: t.y + (Number.isFinite(s) ? s : 0) };
2082
+ IA.current = i, gA(i);
2083
+ const a = Fe(i);
2084
+ _(a);
2085
+ const u = g(i.y);
2086
+ wA(a ? Ae(dA, u) : null);
2087
+ }, ht = (A) => {
2088
+ const n = A.active.data.current?.item, t = GA.current, r = Number(A?.delta?.x ?? 0), s = Number(A?.delta?.y ?? 0), i = t ? { x: t.x + (Number.isFinite(r) ? r : 0), y: t.y + (Number.isFinite(s) ? s : 0) } : IA.current;
2089
+ IA.current = i;
2090
+ const u = String(A.over?.id ?? "") === "timeline-drop" || Fe(i);
2091
+ if (n && u && i) {
2092
+ const C = fe(i.x), I = g(i.y), D = Ae(n, I);
2093
+ wA(D), Ge(n, Math.max(0, C), D);
2094
+ }
2095
+ WA(null), QA(null), wA(null), _(!1), gA(null), GA.current = null;
2096
+ }, mt = () => {
2097
+ WA(null), QA(null), wA(null), _(!1), gA(null), GA.current = null;
2098
+ }, Ce = We(() => {
2099
+ if (!dA || !Z) return null;
2100
+ const A = sA;
1689
2101
  if (!A) return null;
1690
- const t = OA(A.y), n = aA(L, t);
1691
- if (n == null) return null;
1692
- const o = kA(A.x), r = me(L, o, n, b.current), i = L.defaultDuration ?? 10;
2102
+ const n = g(A.y), t = Ae(dA, n);
2103
+ if (t == null) return null;
2104
+ const r = fe(A.x), s = e(dA, r, t, F.current), i = dA.defaultDuration ?? 10;
1693
2105
  return {
1694
- laneRow: n,
1695
- desiredStart: o,
1696
- start: r,
1697
- end: r + i,
2106
+ laneRow: t,
2107
+ desiredStart: r,
2108
+ start: s,
2109
+ end: s + i,
1698
2110
  duration: i,
1699
- kind: L.kind
2111
+ kind: dA.kind
1700
2112
  };
1701
- }, [L, sA, UA, FA, lA, H]), Me = (A) => {
1702
- if (!y || A.pointerType === "mouse" || L) return;
2113
+ }, [dA, Z, sA, VA, TA, bA]), Ft = (A) => {
2114
+ if (!BA || A.pointerType === "mouse" || dA) return;
1703
2115
  if (!!A.target?.closest?.(".timeline-editor-cursor-area, .timeline-editor-cursor")) {
1704
- P.current = { pointerId: A.pointerId }, R.current = null;
2116
+ _A.current = { pointerId: A.pointerId }, UA.current = null;
1705
2117
  try {
1706
2118
  A.currentTarget.setPointerCapture(A.pointerId);
1707
2119
  } catch {
@@ -1709,15 +2121,15 @@ const bt = structuredClone(dt), Qe = 5, Te = ({ item: g, hint: s, isDragging: l
1709
2121
  A.preventDefault();
1710
2122
  return;
1711
2123
  }
1712
- R.current = { x: A.clientX, y: A.clientY };
1713
- }, e = (A) => {
1714
- if (!y || A.pointerType === "mouse" || L || !P.current || P.current.pointerId !== A.pointerId) return;
1715
- const t = kA(A.clientX);
1716
- p.current && p.current.setTime(t), A.preventDefault();
1717
- }, c = (A) => {
1718
- if (!y || A.pointerType === "mouse" || L) return;
1719
- if (P.current && P.current.pointerId === A.pointerId) {
1720
- P.current = null;
2124
+ UA.current = { x: A.clientX, y: A.clientY };
2125
+ }, pt = (A) => {
2126
+ if (!BA || A.pointerType === "mouse" || dA || !_A.current || _A.current.pointerId !== A.pointerId) return;
2127
+ const n = fe(A.clientX);
2128
+ oA.current && oA.current.setTime(n), A.preventDefault();
2129
+ }, vt = (A) => {
2130
+ if (!BA || A.pointerType === "mouse" || dA) return;
2131
+ if (_A.current && _A.current.pointerId === A.pointerId) {
2132
+ _A.current = null;
1721
2133
  try {
1722
2134
  A.currentTarget.releasePointerCapture(A.pointerId);
1723
2135
  } catch {
@@ -1725,303 +2137,486 @@ const bt = structuredClone(dt), Qe = 5, Te = ({ item: g, hint: s, isDragging: l
1725
2137
  A.preventDefault();
1726
2138
  return;
1727
2139
  }
1728
- const t = R.current;
1729
- R.current = null;
1730
- const n = t ? Math.abs(A.clientX - t.x) : 0, o = t ? Math.abs(A.clientY - t.y) : 0;
1731
- if (n > 10 || o > 10) return;
1732
- const i = A.target?.closest?.("[data-action-id]"), a = i?.getAttribute("data-row-id"), B = i?.getAttribute("data-action-id");
1733
- if (a && B) {
1734
- f(B);
2140
+ const n = UA.current;
2141
+ UA.current = null;
2142
+ const t = n ? Math.abs(A.clientX - n.x) : 0, r = n ? Math.abs(A.clientY - n.y) : 0;
2143
+ if (t > 10 || r > 10) return;
2144
+ const i = A.target?.closest?.("[data-action-id]"), a = i?.getAttribute("data-row-id"), u = i?.getAttribute("data-action-id");
2145
+ if (a && u) {
2146
+ O(u);
1735
2147
  return;
1736
2148
  }
1737
- const d = kA(A.clientX);
1738
- f(null), p.current && p.current.setTime(d);
2149
+ const C = fe(A.clientX);
2150
+ O(null), oA.current && oA.current.setTime(C);
1739
2151
  };
1740
- return /* @__PURE__ */ E.jsx(
1741
- _e,
2152
+ return /* @__PURE__ */ w.jsx(
2153
+ xt,
1742
2154
  {
1743
- sensors: Be,
1744
- collisionDetection: $e,
1745
- onDragStart: le,
1746
- onDragMove: de,
1747
- onDragEnd: ye,
1748
- onDragCancel: Ne,
1749
- children: /* @__PURE__ */ E.jsxs("div", { className: "timeline-editor-engine", children: [
1750
- /* @__PURE__ */ E.jsx("div", { className: "player-config", children: /* @__PURE__ */ E.jsx("div", { className: "footage-bin", children: K.map((A) => /* @__PURE__ */ E.jsx(
1751
- pt,
1752
- {
1753
- item: A,
1754
- hint: y ? "Press-hold, then drag into timeline" : "Drag into timeline"
1755
- },
1756
- A.id
1757
- )) }) }),
1758
- /* @__PURE__ */ E.jsx("div", { className: "player-panel", ref: q, children: /* @__PURE__ */ E.jsx(
1759
- "video",
1760
- {
1761
- className: "player-video",
1762
- preload: "auto",
1763
- playsInline: !0,
1764
- muted: !0,
1765
- controls: !1,
1766
- disablePictureInPicture: !0,
1767
- disableRemotePlayback: !0,
1768
- controlsList: "nodownload noplaybackrate noremoteplayback",
1769
- tabIndex: -1,
1770
- onContextMenu: (A) => A.preventDefault(),
1771
- ref: (A) => G.attach(A)
1772
- }
1773
- ) }),
1774
- /* @__PURE__ */ E.jsx(
1775
- mt,
2155
+ sensors: Et,
2156
+ collisionDetection: Mt,
2157
+ onDragStart: It,
2158
+ onDragMove: Dt,
2159
+ onDragEnd: ht,
2160
+ onDragCancel: mt,
2161
+ children: /* @__PURE__ */ w.jsxs("div", { className: "timeline-editor-engine", children: [
2162
+ /* @__PURE__ */ w.jsxs("div", { className: "player-stack", children: [
2163
+ /* @__PURE__ */ w.jsx("div", { className: "footage-ribbon", role: "toolbar", "aria-label": "Footage", children: /* @__PURE__ */ w.jsxs("div", { className: "footage-ribbon-left", children: [
2164
+ /* @__PURE__ */ w.jsxs("div", { className: "footage-toggle-stack", children: [
2165
+ /* @__PURE__ */ w.jsx(
2166
+ "button",
2167
+ {
2168
+ type: "button",
2169
+ className: `footage-ribbon-toggle${iA ? " is-open" : ""}`,
2170
+ "aria-expanded": iA,
2171
+ "aria-controls": "footage-bin-panel",
2172
+ onClick: () => lA((A) => !A),
2173
+ children: /* @__PURE__ */ w.jsx("img", { src: gn, alt: "Footage", draggable: !1 })
2174
+ }
2175
+ ),
2176
+ /* @__PURE__ */ w.jsx(
2177
+ "button",
2178
+ {
2179
+ type: "button",
2180
+ className: `footage-edge-handle${iA ? " is-open" : ""}`,
2181
+ "aria-label": iA ? "Close footage bin" : "Open footage bin",
2182
+ "aria-expanded": iA,
2183
+ "aria-controls": "footage-bin-panel",
2184
+ onClick: () => lA((A) => !A),
2185
+ children: /* @__PURE__ */ w.jsx("span", { className: "footage-edge-chevron", "aria-hidden": "true" })
2186
+ }
2187
+ )
2188
+ ] }),
2189
+ /* @__PURE__ */ w.jsx("div", { className: "footage-ribbon-title", children: "Footage" })
2190
+ ] }) }),
2191
+ /* @__PURE__ */ w.jsx(
2192
+ "div",
2193
+ {
2194
+ id: "footage-bin-panel",
2195
+ className: `footage-bin-panel${iA ? " is-open" : ""}${dA ? " is-dragging" : ""}`,
2196
+ "aria-hidden": !iA,
2197
+ children: /* @__PURE__ */ w.jsx("div", { className: "footage-bin", children: JA.map((A) => /* @__PURE__ */ w.jsx(
2198
+ ln,
2199
+ {
2200
+ item: A,
2201
+ hint: BA ? "Press-hold, then drag into timeline" : "Drag into timeline"
2202
+ },
2203
+ A.id
2204
+ )) })
2205
+ }
2206
+ ),
2207
+ /* @__PURE__ */ w.jsx("div", { className: "player-panel", ref: kA, children: /* @__PURE__ */ w.jsx(
2208
+ "video",
2209
+ {
2210
+ className: "player-video",
2211
+ preload: "auto",
2212
+ playsInline: !0,
2213
+ muted: !0,
2214
+ controls: !1,
2215
+ disablePictureInPicture: !0,
2216
+ disableRemotePlayback: !0,
2217
+ controlsList: "nodownload noplaybackrate noremoteplayback",
2218
+ tabIndex: -1,
2219
+ onContextMenu: (A) => A.preventDefault(),
2220
+ ref: (A) => jA.attach(A)
2221
+ }
2222
+ ) })
2223
+ ] }),
2224
+ /* @__PURE__ */ w.jsx(
2225
+ an,
1776
2226
  {
1777
- timelineState: p,
1778
- autoScrollWhenPlay: uA,
1779
- editorData: s,
1780
- selectedActionId: u,
1781
- onDeleteSelectedClip: ve,
1782
- onSplitSelectedClip: ge,
1783
- canUndo: I.length > 0,
1784
- canRedo: v.length > 0,
1785
- onUndo: be,
1786
- onRedo: ue
2227
+ timelineState: oA,
2228
+ autoScrollWhenPlay: Qe,
2229
+ scale: PA,
2230
+ scaleWidth: $A,
2231
+ startLeft: De,
2232
+ editorData: l,
2233
+ selectedActionId: m,
2234
+ onDeleteSelectedClip: FA,
2235
+ onSplitSelectedClip: He,
2236
+ canUndo: S.length > 0,
2237
+ canRedo: M.length > 0,
2238
+ onUndo: $e,
2239
+ onRedo: At
1787
2240
  }
1788
2241
  ),
1789
- /* @__PURE__ */ E.jsxs(
2242
+ /* @__PURE__ */ w.jsxs(
1790
2243
  "div",
1791
2244
  {
1792
- className: `timeline-drop${Fe ? " is-over" : ""}`,
2245
+ className: `timeline-drop${wt ? " is-over" : ""}`,
1793
2246
  ref: (A) => {
1794
- W.current = A, pe(A);
2247
+ AA.current = A, Qt(A);
1795
2248
  },
1796
- onPointerDown: Me,
1797
- onPointerMove: e,
1798
- onPointerUp: c,
2249
+ onPointerDown: Ft,
2250
+ onPointerMove: pt,
2251
+ onPointerUp: vt,
1799
2252
  children: [
1800
- /* @__PURE__ */ E.jsx(
2253
+ /* @__PURE__ */ w.jsxs("div", { className: "timeline-zoom-controls", "aria-label": "Timeline zoom", children: [
2254
+ /* @__PURE__ */ w.jsx(
2255
+ "button",
2256
+ {
2257
+ type: "button",
2258
+ className: "timeline-zoom-control",
2259
+ onClick: () => Oe(1 / 1.25),
2260
+ "aria-label": "Zoom out",
2261
+ title: "Zoom out",
2262
+ children: /* @__PURE__ */ w.jsx("img", { src: un, alt: "", draggable: !1 })
2263
+ }
2264
+ ),
2265
+ /* @__PURE__ */ w.jsx(
2266
+ "button",
2267
+ {
2268
+ type: "button",
2269
+ className: "timeline-zoom-control",
2270
+ onClick: () => Oe(1.25),
2271
+ "aria-label": "Zoom in",
2272
+ title: "Zoom in",
2273
+ children: /* @__PURE__ */ w.jsx("img", { src: Bn, alt: "", draggable: !1 })
2274
+ }
2275
+ )
2276
+ ] }),
2277
+ /* @__PURE__ */ w.jsx(
1801
2278
  "div",
1802
2279
  {
1803
2280
  className: "timeline-lane-labels",
1804
2281
  style: {
1805
- top: JA,
1806
- transform: `translateY(${-lA}px)`,
1807
- height: H * IA.length
2282
+ top: ZA,
2283
+ transform: `translateY(${-TA}px)`,
2284
+ height: bA * Pe.length
1808
2285
  },
1809
- children: IA.map((A, t) => /* @__PURE__ */ E.jsx(
2286
+ children: Pe.map((A, n) => /* @__PURE__ */ w.jsx(
1810
2287
  "div",
1811
2288
  {
1812
- className: `timeline-lane-label${CA === t ? " is-hover" : ""}`,
1813
- style: { height: H },
2289
+ className: `timeline-lane-label${pA === n ? " is-hover" : ""}`,
2290
+ style: { height: bA },
1814
2291
  children: A
1815
2292
  },
1816
2293
  A
1817
2294
  ))
1818
2295
  }
1819
2296
  ),
1820
- hA ? /* @__PURE__ */ E.jsx("div", { className: "timeline-ghost-layer", style: { top: JA, left: SA }, children: (() => {
1821
- const A = te / ne, t = hA.duration * A, n = he(hA.start) - FA, o = [];
1822
- return hA.kind === "video" ? (o.push({ row: hA.laneRow, kind: "video" }), o.push({ row: NA(hA.laneRow), kind: "audio" })) : o.push({ row: hA.laneRow, kind: "audio" }), o.map((r) => /* @__PURE__ */ E.jsx(
2297
+ Ce ? /* @__PURE__ */ w.jsx("div", { className: "timeline-ghost-layer", style: { top: ZA, left: nA }, children: (() => {
2298
+ const A = $A / PA, n = Ce.duration * A, t = Ye(Ce.start) - VA, r = [];
2299
+ return Ce.kind === "video" ? (r.push({ row: Ce.laneRow, kind: "video" }), r.push({ row: YA(Ce.laneRow), kind: "audio" })) : r.push({ row: Ce.laneRow, kind: "audio" }), r.map((s) => /* @__PURE__ */ w.jsx(
2300
+ "div",
2301
+ {
2302
+ className: `timeline-ghost-clip${s.kind === "video" ? " is-video" : " is-audio"}`,
2303
+ style: {
2304
+ left: t,
2305
+ top: s.row * bA - TA,
2306
+ width: n,
2307
+ height: bA
2308
+ }
2309
+ },
2310
+ `${s.kind}-${s.row}`
2311
+ ));
2312
+ })() }) : null,
2313
+ X ? /* @__PURE__ */ w.jsx("div", { className: "timeline-ghost-layer", style: { top: ZA, left: nA }, children: (() => {
2314
+ const A = $A / PA, n = X.duration * A, t = Ye(X.start) - VA, r = [];
2315
+ return X.kind === "video" ? (r.push({ row: X.laneRow, kind: "video" }), r.push({ row: YA(X.laneRow), kind: "audio" })) : r.push({ row: X.laneRow, kind: "audio" }), r.map((s) => /* @__PURE__ */ w.jsx(
1823
2316
  "div",
1824
2317
  {
1825
- className: `timeline-ghost-clip${r.kind === "video" ? " is-video" : " is-audio"}`,
2318
+ className: `timeline-ghost-clip${s.kind === "video" ? " is-video" : " is-audio"}`,
1826
2319
  style: {
1827
- left: n,
1828
- top: r.row * H - lA,
1829
- width: t,
1830
- height: H
2320
+ left: t,
2321
+ top: s.row * bA - TA,
2322
+ width: n,
2323
+ height: bA
1831
2324
  }
1832
2325
  },
1833
- `${r.kind}-${r.row}`
2326
+ `${X.actionId}-${s.kind}-${s.row}`
1834
2327
  ));
1835
2328
  })() }) : null,
1836
- /* @__PURE__ */ E.jsx(
1837
- ke,
2329
+ /* @__PURE__ */ w.jsx(
2330
+ Ot,
1838
2331
  {
1839
- scale: ne,
1840
- scaleWidth: te,
1841
- startLeft: Ee,
1842
- rowHeight: H,
2332
+ scale: PA,
2333
+ scaleWidth: $A,
2334
+ startLeft: De,
2335
+ rowHeight: bA,
1843
2336
  autoScroll: !0,
1844
- ref: p,
1845
- editorData: ce,
1846
- effects: lt,
2337
+ ref: oA,
2338
+ editorData: XA,
2339
+ effects: _t,
1847
2340
  onScroll: (A) => {
1848
- const t = Number(A?.scrollTop ?? 0), n = Number(A?.scrollLeft ?? 0);
1849
- Number.isFinite(t) && ie(t), Number.isFinite(n) && yA(n);
2341
+ const n = Number(A?.scrollTop ?? 0), t = Number(A?.scrollLeft ?? 0);
2342
+ Number.isFinite(n) && we(n), Number.isFinite(t) && Ie(t);
1850
2343
  },
1851
- onClickTimeArea: (A, t) => {
1852
- f(null);
2344
+ onClickTimeArea: (A, n) => {
2345
+ O(null);
1853
2346
  },
1854
2347
  onClickRow: (A) => {
1855
- A.target?.closest?.(".timeline-editor-action") || f(null);
2348
+ A.target?.closest?.(".timeline-editor-action") || O(null);
1856
2349
  },
1857
- onClickActionOnly: (A, { action: t }) => {
1858
- const n = t;
1859
- n?.id && f(String(n.id));
2350
+ onClickActionOnly: (A, { action: n }) => {
2351
+ const t = n;
2352
+ t?.id && O(String(t.id));
1860
2353
  },
1861
2354
  onActionMoveStart: ({ action: A }) => {
1862
- YA.current = String(A?.id ?? ""), _.current = { actionId: String(A?.id ?? ""), edge: null };
1863
- const t = Number(A?.start), n = Number(A?.end);
1864
- X.current = {
1865
- actionId: String(A?.id ?? ""),
2355
+ Be.current = String(A?.id ?? ""), RA.current = { actionId: String(A?.id ?? ""), edge: null };
2356
+ const n = Number(A?.start), t = Number(A?.end), r = String(A?.id ?? ""), s = r ? mA(F.current, r) : null, i = s ? s.rowIndex : 0;
2357
+ $.current = {
2358
+ actionId: r,
1866
2359
  mode: "move",
1867
2360
  dir: null,
1868
2361
  basePointerTime: null,
1869
2362
  lastPointerTime: null,
1870
- initialStart: Number.isFinite(t) ? t : 0,
1871
- initialEnd: Number.isFinite(n) ? n : 0,
1872
- takeover: !1
1873
- }, cA(), !V.current && (V.current = structuredClone(s), tA.current = LA(s));
2363
+ basePointerClientY: null,
2364
+ lastPointerClientY: null,
2365
+ initialRowIndex: i,
2366
+ committedRowIndex: i,
2367
+ laneCandidateRowIndex: null,
2368
+ laneCandidateSinceMs: 0,
2369
+ laneIntentRowIndex: null,
2370
+ initialStart: Number.isFinite(n) ? n : 0,
2371
+ initialEnd: Number.isFinite(t) ? t : 0,
2372
+ takeover: !0
2373
+ }, v(), eA(null), !DA.current && (DA.current = structuredClone(l), HA.current = ee(l));
1874
2374
  },
1875
2375
  onActionMoveEnd: () => {
1876
- const A = V.current, t = tA.current;
1877
- A && t && LA(b.current) !== t && HA(A), V.current = null, tA.current = null, YA.current = null, _.current = { actionId: null, edge: null }, X.current = {
2376
+ const A = $.current, n = String(A.actionId ?? ""), t = A.laneIntentRowIndex;
2377
+ n && t != null && (W.current = !0, E((i) => {
2378
+ const a = OA(i, n, t);
2379
+ return F.current = a, a;
2380
+ })), eA(null);
2381
+ const r = DA.current, s = HA.current;
2382
+ r && s && ee(F.current) !== s && yA(r), DA.current = null, HA.current = null, Be.current = null, RA.current = { actionId: null, edge: null }, $.current = {
1878
2383
  actionId: null,
1879
2384
  mode: null,
1880
2385
  dir: null,
1881
2386
  basePointerTime: null,
1882
2387
  lastPointerTime: null,
2388
+ basePointerClientY: null,
2389
+ lastPointerClientY: null,
2390
+ initialRowIndex: 0,
2391
+ committedRowIndex: 0,
2392
+ laneCandidateRowIndex: null,
2393
+ laneCandidateSinceMs: 0,
2394
+ laneIntentRowIndex: null,
1883
2395
  initialStart: 0,
1884
2396
  initialEnd: 0,
1885
2397
  takeover: !1
1886
- }, VA();
2398
+ }, j();
1887
2399
  },
1888
2400
  onActionResizeStart: ({ action: A }) => {
1889
- YA.current = String(A?.id ?? ""), _.current = { actionId: String(A?.id ?? ""), edge: null };
1890
- const t = Number(A?.start), n = Number(A?.end);
1891
- X.current = {
1892
- actionId: String(A?.id ?? ""),
2401
+ Be.current = String(A?.id ?? ""), RA.current = { actionId: String(A?.id ?? ""), edge: null };
2402
+ const n = Number(A?.start), t = Number(A?.end), r = String(A?.id ?? ""), s = r ? mA(F.current, r) : null, i = s ? s.rowIndex : 0, a = k(s?.action ?? A), u = r ? KA(F.current, r) : null, C = u ? String(u.action.id) : null, I = u ? k(u.action) : a;
2403
+ hA.current = {
2404
+ actionId: r,
2405
+ partnerId: C,
2406
+ dir: null,
2407
+ baseStart: Number.isFinite(n) ? n : 0,
2408
+ baseOffset: a,
2409
+ partnerBaseOffset: I
2410
+ }, $.current = {
2411
+ actionId: r,
1893
2412
  mode: "resize",
1894
2413
  dir: null,
1895
2414
  basePointerTime: null,
1896
2415
  lastPointerTime: null,
1897
- initialStart: Number.isFinite(t) ? t : 0,
1898
- initialEnd: Number.isFinite(n) ? n : 0,
2416
+ basePointerClientY: null,
2417
+ lastPointerClientY: null,
2418
+ initialRowIndex: i,
2419
+ committedRowIndex: i,
2420
+ laneCandidateRowIndex: null,
2421
+ laneCandidateSinceMs: 0,
2422
+ laneIntentRowIndex: null,
2423
+ initialStart: Number.isFinite(n) ? n : 0,
2424
+ initialEnd: Number.isFinite(t) ? t : 0,
1899
2425
  takeover: !1
1900
- }, cA(), !V.current && (V.current = structuredClone(s), tA.current = LA(s));
2426
+ }, v(), !DA.current && (DA.current = structuredClone(l), HA.current = ee(l));
1901
2427
  },
1902
2428
  onActionResizeEnd: () => {
1903
- const A = V.current, t = tA.current;
1904
- A && t && LA(b.current) !== t && HA(A), V.current = null, tA.current = null, YA.current = null, _.current = { actionId: null, edge: null }, X.current = {
2429
+ const A = DA.current, n = HA.current;
2430
+ A && n && ee(F.current) !== n && yA(A), DA.current = null, HA.current = null, Be.current = null, RA.current = { actionId: null, edge: null }, $.current = {
1905
2431
  actionId: null,
1906
2432
  mode: null,
1907
2433
  dir: null,
1908
2434
  basePointerTime: null,
1909
2435
  lastPointerTime: null,
2436
+ basePointerClientY: null,
2437
+ lastPointerClientY: null,
2438
+ initialRowIndex: 0,
2439
+ committedRowIndex: 0,
2440
+ laneCandidateRowIndex: null,
2441
+ laneCandidateSinceMs: 0,
2442
+ laneIntentRowIndex: null,
1910
2443
  initialStart: 0,
1911
2444
  initialEnd: 0,
1912
2445
  takeover: !1
1913
- }, VA();
2446
+ }, j(), hA.current = {
2447
+ actionId: null,
2448
+ partnerId: null,
2449
+ dir: null,
2450
+ baseStart: 0,
2451
+ baseOffset: 0,
2452
+ partnerBaseOffset: 0
2453
+ };
1914
2454
  },
1915
- onActionMoving: ({ action: A, row: t, start: n, end: o }) => {
1916
- const r = String(A?.id ?? ""), i = X.current;
1917
- if (i.takeover && i.mode === "move" && i.actionId === r) {
1918
- const O = i.basePointerTime, M = i.lastPointerTime, Y = O != null && M != null ? M - O : 0, $ = i.initialStart + Y, EA = i.initialEnd + Y, mA = _A(r, $, EA), xA = mA.start, vA = mA.end;
1919
- if (QA(t, String(A.id), xA, vA)) return !1;
1920
- const gA = b.current, pA = DA(gA, String(A.id));
1921
- if (pA) {
1922
- const T = gA[pA.rowIndex];
1923
- if (T && QA(T, String(pA.action.id), xA, vA)) return !1;
2455
+ onActionMoving: ({ action: A, row: n, start: t, end: r }) => {
2456
+ const s = String(A?.id ?? ""), i = $.current, a = (R, H) => {
2457
+ const h = Number(R), U = Number(H);
2458
+ if (!Number.isFinite(h) || !Number.isFinite(U)) return { start: R, end: H, clamped: !1 };
2459
+ if (U <= h) return { start: R, end: H, clamped: !1 };
2460
+ if (h >= 0) return { start: h, end: U, clamped: !1 };
2461
+ const L = -h;
2462
+ return { start: 0, end: U + L, clamped: !0 };
2463
+ }, u = (R) => {
2464
+ const H = String(R?.id ?? "");
2465
+ return H ? F.current.findIndex((h) => String(h?.id ?? "") === H) : -1;
2466
+ };
2467
+ if (i.takeover && i.mode === "move" && i.actionId === s) {
2468
+ const H = Math.max(10, bA * 0.45), h = i.basePointerTime, U = i.lastPointerTime, L = h != null && U != null ? U - h : 0, T = i.initialStart + L, q = i.initialEnd + L, aA = Le(s, T, q), J = a(aA.start, aA.end), K = J.start, V = J.end, EA = String(A?.effectId ?? "") === "effect1" ? "video" : "audio", zA = i.lastPointerClientY, pe = zA != null ? g(zA) : null, re = SA(
2469
+ pe ?? i.committedRowIndex,
2470
+ EA
2471
+ ), ve = i.basePointerClientY, Re = ve != null && zA != null ? Math.abs(zA - ve) : 0, Ke = typeof performance < "u" && performance.now ? performance.now() : Date.now();
2472
+ re !== i.committedRowIndex && Re >= H ? (i.laneCandidateRowIndex !== re && (i.laneCandidateRowIndex = re, i.laneCandidateSinceMs = Ke), Ke - i.laneCandidateSinceMs >= 160 && (i.laneIntentRowIndex = re)) : (i.laneCandidateRowIndex = null, i.laneCandidateSinceMs = 0, i.laneIntentRowIndex = null);
2473
+ const je = re !== i.committedRowIndex && Re >= H ? re : null;
2474
+ je != null ? eA({
2475
+ actionId: s,
2476
+ laneRow: je,
2477
+ start: K,
2478
+ end: V,
2479
+ duration: Math.max(0.01, V - K),
2480
+ kind: EA
2481
+ }) : eA(null);
2482
+ const et = F.current, nt = et[i.committedRowIndex];
2483
+ if (nt && MA(nt, String(A.id), K, V)) return !1;
2484
+ const tt = KA(et, String(A.id));
2485
+ if (tt) {
2486
+ const Te = EA === "video" ? YA(SA(i.committedRowIndex, "video")) : me(SA(i.committedRowIndex, "audio")), ye = et[Te];
2487
+ if (ye && MA(ye, String(tt.action.id), K, V)) return !1;
1924
2488
  }
1925
- return l((T) => {
1926
- const J = pA ? XA(T, String(A.id), xA, vA) : zA(T, String(A.id), xA, vA);
1927
- return b.current = J, J;
2489
+ return E((Te) => {
2490
+ const ye = tt ? le(Te, String(A.id), K, V) : de(Te, String(A.id), K, V);
2491
+ return F.current = ye, ye;
1928
2492
  }), !1;
1929
2493
  }
1930
- const a = Number(n), B = Number(o);
1931
- if (!Number.isFinite(a) || !Number.isFinite(B) || B <= a) return !1;
1932
- const d = _A(r, a, B), Q = d.start, C = d.end;
1933
- if (!Number.isFinite(Q) || !Number.isFinite(C) || C <= Q || QA(t, String(A.id), Q, C)) return !1;
1934
- const D = b.current, N = DA(D, String(A.id));
1935
- if (N) {
1936
- const O = D[N.rowIndex];
1937
- if (O && QA(O, String(N.action.id), Q, C)) return !1;
2494
+ const C = Number(t), I = Number(r);
2495
+ if (!Number.isFinite(C) || !Number.isFinite(I) || I <= C) return !1;
2496
+ const D = Le(s, C, I), N = a(D.start, D.end), b = N.start, p = N.end;
2497
+ if (!Number.isFinite(b) || !Number.isFinite(p) || p <= b) return !1;
2498
+ const Y = n;
2499
+ if (MA(Y, String(A.id), b, p)) return !1;
2500
+ const x = F.current, f = KA(x, String(A.id));
2501
+ if (f) {
2502
+ const R = String(A?.effectId ?? ""), H = u(Y);
2503
+ let h = f.rowIndex;
2504
+ if (H >= 0)
2505
+ if (R === "effect1") {
2506
+ const L = SA(H, "video");
2507
+ h = YA(L);
2508
+ } else {
2509
+ const L = SA(H, "audio");
2510
+ h = me(L);
2511
+ }
2512
+ const U = x[h];
2513
+ if (U && MA(U, String(f.action.id), b, p)) return !1;
1938
2514
  }
1939
- if ((N || d.snapped) && l((O) => {
1940
- const M = N ? XA(O, String(A.id), Q, C) : zA(O, String(A.id), Q, C);
1941
- return b.current = M, M;
1942
- }), d.snapped) {
1943
- const O = X.current.lastPointerTime;
1944
- return X.current = {
1945
- actionId: r,
2515
+ if ((f || D.snapped || N.clamped) && E((R) => {
2516
+ const H = f ? le(R, String(A.id), b, p) : de(R, String(A.id), b, p);
2517
+ return F.current = H, H;
2518
+ }), D.snapped || N.clamped) {
2519
+ const R = $.current.lastPointerTime;
2520
+ return $.current = {
2521
+ ...$.current,
2522
+ actionId: s,
1946
2523
  mode: "move",
1947
2524
  dir: null,
1948
- basePointerTime: O,
1949
- lastPointerTime: X.current.lastPointerTime,
1950
- initialStart: a,
1951
- initialEnd: B,
2525
+ basePointerTime: R,
2526
+ lastPointerTime: $.current.lastPointerTime,
2527
+ initialStart: C,
2528
+ initialEnd: I,
1952
2529
  takeover: !0
1953
- }, cA(), !1;
2530
+ }, v(), !1;
1954
2531
  }
1955
2532
  },
1956
- onActionResizing: ({ action: A, row: t, start: n, end: o, dir: r }) => {
1957
- const i = String(A?.id ?? ""), a = X.current, B = r ?? "right";
1958
- if (a.takeover && a.mode === "resize" && a.actionId === i) {
1959
- const Y = a.basePointerTime, $ = a.lastPointerTime, EA = Y != null && $ != null ? $ - Y : 0, mA = B === "left" ? a.initialStart + EA : a.initialStart, xA = B === "right" ? a.initialEnd + EA : a.initialEnd, vA = se(i, mA, xA, B), bA = vA.start, gA = vA.end;
1960
- if (QA(t, String(A.id), bA, gA)) return !1;
1961
- const T = b.current, J = DA(T, String(A.id));
1962
- if (J) {
1963
- const nA = T[J.rowIndex];
1964
- if (nA && QA(nA, String(J.action.id), bA, gA)) return !1;
2533
+ onActionResizing: ({ action: A, row: n, start: t, end: r, dir: s }) => {
2534
+ const i = String(A?.id ?? ""), a = $.current, u = s ?? "right";
2535
+ if (a.actionId === i && a.mode === "resize" && (a.dir = u), hA.current.actionId === i && (hA.current.dir = u), a.takeover && a.mode === "resize" && a.actionId === i) {
2536
+ const f = a.basePointerTime, R = a.lastPointerTime, H = f != null && R != null ? R - f : 0, h = u === "left" ? a.initialStart + H : a.initialStart, U = u === "right" ? a.initialEnd + H : a.initialEnd, L = Se(i, h, U, u), T = L.start, q = L.end;
2537
+ if (MA(n, String(A.id), T, q)) return !1;
2538
+ const J = F.current, K = KA(J, String(A.id));
2539
+ if (K) {
2540
+ const V = J[K.rowIndex];
2541
+ if (V && MA(V, String(K.action.id), T, q)) return !1;
1965
2542
  }
1966
- return l((nA) => {
1967
- const AA = J ? XA(nA, String(A.id), bA, gA) : zA(nA, String(A.id), bA, gA);
1968
- return b.current = AA, AA;
2543
+ return E((V) => {
2544
+ let uA = K ? le(V, String(A.id), T, q) : de(V, String(A.id), T, q);
2545
+ if (u === "left" && hA.current.actionId === String(A.id)) {
2546
+ const EA = T - hA.current.baseStart, zA = hA.current.baseOffset + (Number.isFinite(EA) ? EA : 0), pe = hA.current.partnerBaseOffset + (Number.isFinite(EA) ? EA : 0);
2547
+ uA = K ? fA(uA, String(A.id), zA, pe) : P(uA, String(A.id), zA);
2548
+ }
2549
+ return F.current = uA, uA;
1969
2550
  }), !1;
1970
2551
  }
1971
- const d = Number(n), Q = Number(o);
1972
- if (!Number.isFinite(d) || !Number.isFinite(Q) || Q <= d) return !1;
1973
- const C = se(i, d, Q, B), F = C.start, D = C.end;
1974
- if (!Number.isFinite(F) || !Number.isFinite(D) || D <= F || QA(t, String(A.id), F, D)) return !1;
1975
- const O = b.current, M = DA(O, String(A.id));
1976
- if (M) {
1977
- const Y = O[M.rowIndex];
1978
- if (Y && QA(Y, String(M.action.id), F, D)) return !1;
2552
+ const C = Number(t), I = Number(r);
2553
+ if (!Number.isFinite(C) || !Number.isFinite(I) || I <= C) return !1;
2554
+ const D = Se(i, C, I, u), N = D.start, b = D.end;
2555
+ if (!Number.isFinite(N) || !Number.isFinite(b) || b <= N || MA(n, String(A.id), N, b)) return !1;
2556
+ const Y = F.current, x = KA(Y, String(A.id));
2557
+ if (x) {
2558
+ const f = Y[x.rowIndex];
2559
+ if (f && MA(f, String(x.action.id), N, b)) return !1;
1979
2560
  }
1980
- if ((M || C.snapped) && l((Y) => {
1981
- const $ = M ? XA(Y, String(A.id), F, D) : zA(Y, String(A.id), F, D);
1982
- return b.current = $, $;
1983
- }), C.snapped) {
1984
- const Y = X.current.lastPointerTime;
1985
- return X.current = {
2561
+ if ((x || D.snapped) && E((f) => {
2562
+ const R = x ? le(f, String(A.id), N, b) : de(f, String(A.id), N, b);
2563
+ return F.current = R, R;
2564
+ }), D.snapped) {
2565
+ const f = $.current.lastPointerTime;
2566
+ return $.current = {
2567
+ ...$.current,
1986
2568
  actionId: i,
1987
2569
  mode: "resize",
1988
- dir: B,
1989
- basePointerTime: Y,
1990
- lastPointerTime: X.current.lastPointerTime,
1991
- initialStart: d,
1992
- initialEnd: Q,
2570
+ dir: u,
2571
+ basePointerTime: f,
2572
+ lastPointerTime: $.current.lastPointerTime,
2573
+ initialStart: C,
2574
+ initialEnd: I,
1993
2575
  takeover: !0
1994
- }, cA(), !1;
2576
+ }, v(), !1;
1995
2577
  }
1996
2578
  },
1997
2579
  onChange: (A) => {
1998
- const t = $A(A), n = YA.current, o = n ? oe(t, n) : t;
1999
- l(o);
2000
- const r = V.current, i = tA.current;
2001
- r && i && (LA(o) !== i && HA(r), V.current = null, tA.current = null);
2580
+ if (W.current) {
2581
+ W.current = !1;
2582
+ return;
2583
+ }
2584
+ const n = ne(A), t = Be.current;
2585
+ let r = t ? ke(n, t) : n;
2586
+ if (t && hA.current.actionId === t && hA.current.dir === "left") {
2587
+ const u = mA(r, t);
2588
+ if (u) {
2589
+ const I = Number(u.action?.start) - hA.current.baseStart, D = hA.current.baseOffset + (Number.isFinite(I) ? I : 0), N = hA.current.partnerBaseOffset + (Number.isFinite(I) ? I : 0);
2590
+ r = !!hA.current.partnerId ? fA(r, t, D, N) : P(r, t, D);
2591
+ }
2592
+ }
2593
+ const s = Ve(r, t);
2594
+ E(s);
2595
+ const i = DA.current, a = HA.current;
2596
+ i && a && (ee(s) !== a && yA(i), DA.current = null, HA.current = null);
2002
2597
  },
2003
- getActionRender: (A, t) => {
2598
+ getActionRender: (A, n) => {
2004
2599
  if (A.effectId === "effect0")
2005
- return /* @__PURE__ */ E.jsx(it, { action: A, row: t });
2600
+ return /* @__PURE__ */ w.jsx(Kt, { action: A, row: n });
2006
2601
  if (A.effectId === "effect2")
2007
- return /* @__PURE__ */ E.jsx(st, { action: A, row: t });
2602
+ return /* @__PURE__ */ w.jsx(Tt, { action: A, row: n });
2008
2603
  if (A.effectId === "effect1")
2009
- return /* @__PURE__ */ E.jsx(ot, { action: A, row: t });
2604
+ return /* @__PURE__ */ w.jsx(jt, { action: A, row: n });
2010
2605
  }
2011
2606
  }
2012
2607
  )
2013
2608
  ]
2014
2609
  }
2015
2610
  ),
2016
- /* @__PURE__ */ E.jsx(At, { children: L ? /* @__PURE__ */ E.jsx(
2611
+ /* @__PURE__ */ w.jsx(kt, { children: dA ? /* @__PURE__ */ w.jsx(
2017
2612
  "div",
2018
2613
  {
2019
2614
  className: "footage-overlay",
2020
- style: S ? {
2021
- width: S.width,
2022
- height: S.height
2615
+ style: LA ? {
2616
+ width: LA.width,
2617
+ height: LA.height
2023
2618
  } : void 0,
2024
- children: /* @__PURE__ */ E.jsx(Te, { item: L, hint: "Drop on timeline", isDragging: !0 })
2619
+ children: /* @__PURE__ */ w.jsx(ft, { item: dA, hint: "Drop on timeline", isDragging: !0 })
2025
2620
  }
2026
2621
  ) : null })
2027
2622
  ] })
@@ -2029,5 +2624,5 @@ const bt = structuredClone(dt), Qe = 5, Te = ({ item: g, hint: s, isDragging: l
2029
2624
  );
2030
2625
  };
2031
2626
  export {
2032
- xt as MeliesVideoEditor
2627
+ In as MeliesVideoEditor
2033
2628
  };