melies-video-editor 0.1.2 → 0.1.3

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