melies-video-editor 0.1.1 → 0.1.2

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