melies-video-editor 0.1.0 → 0.1.1

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.
Files changed (3) hide show
  1. package/dist/index.cjs +8 -8
  2. package/dist/index.js +1294 -1294
  3. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -1,109 +1,109 @@
1
- import Lt, { useState as J, useRef as V, useEffect as bt, useMemo as _t, useLayoutEffect as Wt } from "react";
2
- import { Timeline as Ht } from "@xzdarcy/react-timeline-editor";
3
- import { Howl as Yt, Howler as qt } from "howler";
4
- import { Select as $t, Button as zt } from "antd";
5
- import { useSensors as Xt, useSensor as jt, PointerSensor as Jt, TouchSensor as Kt, useDroppable as Gt, DndContext as Zt, rectIntersection as Qt, DragOverlay as en, useDraggable as tn } from "@dnd-kit/core";
6
- var gt = { exports: {} }, et = {};
7
- var Dt;
8
- function nn() {
9
- if (Dt) return et;
10
- Dt = 1;
11
- var u = Lt, a = /* @__PURE__ */ Symbol.for("react.element"), m = /* @__PURE__ */ Symbol.for("react.fragment"), d = Object.prototype.hasOwnProperty, g = u.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, S = { key: !0, ref: !0, __self: !0, __source: !0 };
12
- function R(E, x, T) {
13
- var k, A = {}, q = null, z = null;
14
- T !== void 0 && (q = "" + T), x.key !== void 0 && (q = "" + x.key), x.ref !== void 0 && (z = x.ref);
15
- for (k in x) d.call(x, k) && !S.hasOwnProperty(k) && (A[k] = x[k]);
16
- if (E && E.defaultProps) for (k in x = E.defaultProps, x) A[k] === void 0 && (A[k] = x[k]);
17
- return { $$typeof: a, type: E, key: q, ref: z, props: A, _owner: g.current };
1
+ import Ge, { useState as z, useRef as j, useEffect as Ce, useMemo as Oe, useLayoutEffect as Xe } from "react";
2
+ import { Timeline as ke } from "@xzdarcy/react-timeline-editor";
3
+ import { Howl as Je, Howler as qe } from "howler";
4
+ import { Select as Ye, Button as We } from "antd";
5
+ import { useSensors as Ke, useSensor as xe, PointerSensor as ze, TouchSensor as Ve, useDroppable as Ze, DndContext as _e, rectIntersection as $e, DragOverlay as At, useDraggable as et } from "@dnd-kit/core";
6
+ var fe = { exports: {} }, Ae = {};
7
+ var Re;
8
+ function tt() {
9
+ if (Re) return Ae;
10
+ Re = 1;
11
+ var g = Ge, s = /* @__PURE__ */ Symbol.for("react.element"), l = /* @__PURE__ */ Symbol.for("react.fragment"), u = Object.prototype.hasOwnProperty, f = g.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, I = { key: !0, ref: !0, __self: !0, __source: !0 };
12
+ function h(v, m, b) {
13
+ var y, p = {}, q = null, W = null;
14
+ b !== void 0 && (q = "" + b), m.key !== void 0 && (q = "" + m.key), m.ref !== void 0 && (W = m.ref);
15
+ for (y in m) u.call(m, y) && !I.hasOwnProperty(y) && (p[y] = m[y]);
16
+ if (v && v.defaultProps) for (y in m = v.defaultProps, m) p[y] === void 0 && (p[y] = m[y]);
17
+ return { $$typeof: s, type: v, key: q, ref: W, props: p, _owner: f.current };
18
18
  }
19
- return et.Fragment = m, et.jsx = R, et.jsxs = R, et;
19
+ return Ae.Fragment = l, Ae.jsx = h, Ae.jsxs = h, Ae;
20
20
  }
21
- var tt = {};
22
- var Ot;
23
- function rn() {
24
- return Ot || (Ot = 1, process.env.NODE_ENV !== "production" && (function() {
25
- var u = Lt, a = /* @__PURE__ */ Symbol.for("react.element"), m = /* @__PURE__ */ Symbol.for("react.portal"), d = /* @__PURE__ */ Symbol.for("react.fragment"), g = /* @__PURE__ */ Symbol.for("react.strict_mode"), S = /* @__PURE__ */ Symbol.for("react.profiler"), R = /* @__PURE__ */ Symbol.for("react.provider"), E = /* @__PURE__ */ Symbol.for("react.context"), x = /* @__PURE__ */ Symbol.for("react.forward_ref"), T = /* @__PURE__ */ Symbol.for("react.suspense"), k = /* @__PURE__ */ Symbol.for("react.suspense_list"), A = /* @__PURE__ */ Symbol.for("react.memo"), q = /* @__PURE__ */ Symbol.for("react.lazy"), z = /* @__PURE__ */ Symbol.for("react.offscreen"), de = Symbol.iterator, X = "@@iterator";
26
- function U(t) {
27
- if (t === null || typeof t != "object")
21
+ var ee = {};
22
+ var Se;
23
+ function nt() {
24
+ return Se || (Se = 1, process.env.NODE_ENV !== "production" && (function() {
25
+ var g = Ge, s = /* @__PURE__ */ Symbol.for("react.element"), l = /* @__PURE__ */ Symbol.for("react.portal"), u = /* @__PURE__ */ Symbol.for("react.fragment"), f = /* @__PURE__ */ Symbol.for("react.strict_mode"), I = /* @__PURE__ */ Symbol.for("react.profiler"), h = /* @__PURE__ */ Symbol.for("react.provider"), v = /* @__PURE__ */ Symbol.for("react.context"), m = /* @__PURE__ */ Symbol.for("react.forward_ref"), b = /* @__PURE__ */ Symbol.for("react.suspense"), y = /* @__PURE__ */ Symbol.for("react.suspense_list"), p = /* @__PURE__ */ Symbol.for("react.memo"), q = /* @__PURE__ */ Symbol.for("react.lazy"), W = /* @__PURE__ */ Symbol.for("react.offscreen"), uA = Symbol.iterator, K = "@@iterator";
26
+ function L(e) {
27
+ if (e === null || typeof e != "object")
28
28
  return null;
29
- var l = de && t[de] || t[X];
30
- return typeof l == "function" ? l : null;
29
+ var c = uA && e[uA] || e[K];
30
+ return typeof c == "function" ? c : null;
31
31
  }
32
- var G = u.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;
33
- function O(t) {
32
+ var Z = g.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;
33
+ function S(e) {
34
34
  {
35
- for (var l = arguments.length, e = new Array(l > 1 ? l - 1 : 0), n = 1; n < l; n++)
36
- e[n - 1] = arguments[n];
37
- fe("error", t, e);
35
+ for (var c = arguments.length, A = new Array(c > 1 ? c - 1 : 0), t = 1; t < c; t++)
36
+ A[t - 1] = arguments[t];
37
+ BA("error", e, A);
38
38
  }
39
39
  }
40
- function fe(t, l, e) {
40
+ function BA(e, c, A) {
41
41
  {
42
- var n = G.ReactDebugCurrentFrame, r = n.getStackAddendum();
43
- r !== "" && (l += "%s", e = e.concat([r]));
44
- var s = e.map(function(i) {
45
- return String(i);
42
+ var t = Z.ReactDebugCurrentFrame, n = t.getStackAddendum();
43
+ n !== "" && (c += "%s", A = A.concat([n]));
44
+ var o = A.map(function(r) {
45
+ return String(r);
46
46
  });
47
- s.unshift("Warning: " + l), Function.prototype.apply.call(console[t], console, s);
47
+ o.unshift("Warning: " + c), Function.prototype.apply.call(console[e], console, o);
48
48
  }
49
49
  }
50
- var be = !1, oe = !1, me = !1, ot = !1, Ne = !1, ke;
51
- ke = /* @__PURE__ */ Symbol.for("react.module.reference");
52
- function Ye(t) {
53
- return !!(typeof t == "string" || typeof t == "function" || t === d || t === S || Ne || t === g || t === T || t === k || ot || t === z || be || oe || me || typeof t == "object" && t !== null && (t.$$typeof === q || t.$$typeof === A || t.$$typeof === R || t.$$typeof === E || t.$$typeof === x || // This needs to include all possible module reference object
50
+ var CA = !1, iA = !1, lA = !1, ie = !1, FA = !1, yA;
51
+ yA = /* @__PURE__ */ Symbol.for("react.module.reference");
52
+ function JA(e) {
53
+ return !!(typeof e == "string" || typeof e == "function" || e === u || e === I || FA || e === f || e === b || e === y || ie || e === W || CA || iA || lA || typeof e == "object" && e !== null && (e.$$typeof === q || e.$$typeof === p || e.$$typeof === h || e.$$typeof === v || e.$$typeof === m || // This needs to include all possible module reference object
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
- t.$$typeof === ke || t.getModuleId !== void 0));
57
+ e.$$typeof === yA || e.getModuleId !== void 0));
58
58
  }
59
- function qe(t, l, e) {
60
- var n = t.displayName;
61
- if (n)
62
- return n;
63
- var r = l.displayName || l.name || "";
64
- return r !== "" ? e + "(" + r + ")" : e;
59
+ function qA(e, c, A) {
60
+ var t = e.displayName;
61
+ if (t)
62
+ return t;
63
+ var n = c.displayName || c.name || "";
64
+ return n !== "" ? A + "(" + n + ")" : A;
65
65
  }
66
- function Oe(t) {
67
- return t.displayName || "Context";
66
+ function SA(e) {
67
+ return e.displayName || "Context";
68
68
  }
69
- function se(t) {
70
- if (t == null)
69
+ function oA(e) {
70
+ if (e == null)
71
71
  return null;
72
- if (typeof t.tag == "number" && O("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."), typeof t == "function")
73
- return t.displayName || t.name || null;
74
- if (typeof t == "string")
75
- return t;
76
- switch (t) {
77
- case d:
72
+ if (typeof e.tag == "number" && S("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."), typeof e == "function")
73
+ return e.displayName || e.name || null;
74
+ if (typeof e == "string")
75
+ return e;
76
+ switch (e) {
77
+ case u:
78
78
  return "Fragment";
79
- case m:
79
+ case l:
80
80
  return "Portal";
81
- case S:
81
+ case I:
82
82
  return "Profiler";
83
- case g:
83
+ case f:
84
84
  return "StrictMode";
85
- case T:
85
+ case b:
86
86
  return "Suspense";
87
- case k:
87
+ case y:
88
88
  return "SuspenseList";
89
89
  }
90
- if (typeof t == "object")
91
- switch (t.$$typeof) {
92
- case E:
93
- var l = t;
94
- return Oe(l) + ".Consumer";
95
- case R:
96
- var e = t;
97
- return Oe(e._context) + ".Provider";
98
- case x:
99
- return qe(t, t.render, "ForwardRef");
100
- case A:
101
- var n = t.displayName || null;
102
- return n !== null ? n : se(t.type) || "Memo";
90
+ if (typeof e == "object")
91
+ switch (e.$$typeof) {
92
+ case v:
93
+ var c = e;
94
+ return SA(c) + ".Consumer";
95
+ case h:
96
+ var A = e;
97
+ return SA(A._context) + ".Provider";
98
+ case m:
99
+ return qA(e, e.render, "ForwardRef");
100
+ case p:
101
+ var t = e.displayName || null;
102
+ return t !== null ? t : oA(e.type) || "Memo";
103
103
  case q: {
104
- var r = t, s = r._payload, i = r._init;
104
+ var n = e, o = n._payload, r = n._init;
105
105
  try {
106
- return se(i(s));
106
+ return oA(r(o));
107
107
  } catch {
108
108
  return null;
109
109
  }
@@ -111,583 +111,583 @@ function rn() {
111
111
  }
112
112
  return null;
113
113
  }
114
- var ae = Object.assign, te = 0, Me, ye, y, j, D, C, F;
115
- function M() {
114
+ var sA = Object.assign, eA = 0, UA, wA, w, x, R, P, H;
115
+ function U() {
116
116
  }
117
- M.__reactDisabledLog = !0;
118
- function H() {
117
+ U.__reactDisabledLog = !0;
118
+ function k() {
119
119
  {
120
- if (te === 0) {
121
- Me = console.log, ye = console.info, y = console.warn, j = console.error, D = console.group, C = console.groupCollapsed, F = console.groupEnd;
122
- var t = {
120
+ if (eA === 0) {
121
+ UA = console.log, wA = console.info, w = console.warn, x = console.error, R = console.group, P = console.groupCollapsed, H = console.groupEnd;
122
+ var e = {
123
123
  configurable: !0,
124
124
  enumerable: !0,
125
- value: M,
125
+ value: U,
126
126
  writable: !0
127
127
  };
128
128
  Object.defineProperties(console, {
129
- info: t,
130
- log: t,
131
- warn: t,
132
- error: t,
133
- group: t,
134
- groupCollapsed: t,
135
- groupEnd: t
129
+ info: e,
130
+ log: e,
131
+ warn: e,
132
+ error: e,
133
+ group: e,
134
+ groupCollapsed: e,
135
+ groupEnd: e
136
136
  });
137
137
  }
138
- te++;
138
+ eA++;
139
139
  }
140
140
  }
141
- function Se() {
141
+ function IA() {
142
142
  {
143
- if (te--, te === 0) {
144
- var t = {
143
+ if (eA--, eA === 0) {
144
+ var e = {
145
145
  configurable: !0,
146
146
  enumerable: !0,
147
147
  writable: !0
148
148
  };
149
149
  Object.defineProperties(console, {
150
- log: ae({}, t, {
151
- value: Me
150
+ log: sA({}, e, {
151
+ value: UA
152
152
  }),
153
- info: ae({}, t, {
154
- value: ye
153
+ info: sA({}, e, {
154
+ value: wA
155
155
  }),
156
- warn: ae({}, t, {
157
- value: y
156
+ warn: sA({}, e, {
157
+ value: w
158
158
  }),
159
- error: ae({}, t, {
160
- value: j
159
+ error: sA({}, e, {
160
+ value: x
161
161
  }),
162
- group: ae({}, t, {
163
- value: D
162
+ group: sA({}, e, {
163
+ value: R
164
164
  }),
165
- groupCollapsed: ae({}, t, {
166
- value: C
165
+ groupCollapsed: sA({}, e, {
166
+ value: P
167
167
  }),
168
- groupEnd: ae({}, t, {
169
- value: F
168
+ groupEnd: sA({}, e, {
169
+ value: H
170
170
  })
171
171
  });
172
172
  }
173
- te < 0 && O("disabledDepth fell below zero. This is a bug in React. Please file an issue.");
173
+ eA < 0 && S("disabledDepth fell below zero. This is a bug in React. Please file an issue.");
174
174
  }
175
175
  }
176
- var pe = G.ReactCurrentDispatcher, ce;
177
- function Pe(t, l, e) {
176
+ var dA = Z.ReactCurrentDispatcher, aA;
177
+ function NA(e, c, A) {
178
178
  {
179
- if (ce === void 0)
179
+ if (aA === void 0)
180
180
  try {
181
181
  throw Error();
182
- } catch (r) {
183
- var n = r.stack.trim().match(/\n( *(at )?)/);
184
- ce = n && n[1] || "";
182
+ } catch (n) {
183
+ var t = n.stack.trim().match(/\n( *(at )?)/);
184
+ aA = t && t[1] || "";
185
185
  }
186
186
  return `
187
- ` + ce + t;
187
+ ` + aA + e;
188
188
  }
189
189
  }
190
- var Le = !1, ze;
190
+ var GA = !1, WA;
191
191
  {
192
- var ge = typeof WeakMap == "function" ? WeakMap : Map;
193
- ze = new ge();
192
+ var fA = typeof WeakMap == "function" ? WeakMap : Map;
193
+ WA = new fA();
194
194
  }
195
- function K(t, l) {
196
- if (!t || Le)
195
+ function V(e, c) {
196
+ if (!e || GA)
197
197
  return "";
198
198
  {
199
- var e = ze.get(t);
200
- if (e !== void 0)
201
- return e;
199
+ var A = WA.get(e);
200
+ if (A !== void 0)
201
+ return A;
202
202
  }
203
- var n;
204
- Le = !0;
205
- var r = Error.prepareStackTrace;
203
+ var t;
204
+ GA = !0;
205
+ var n = Error.prepareStackTrace;
206
206
  Error.prepareStackTrace = void 0;
207
- var s;
208
- s = pe.current, pe.current = null, H();
207
+ var o;
208
+ o = dA.current, dA.current = null, k();
209
209
  try {
210
- if (l) {
211
- var i = function() {
210
+ if (c) {
211
+ var r = function() {
212
212
  throw Error();
213
213
  };
214
- if (Object.defineProperty(i.prototype, "props", {
214
+ if (Object.defineProperty(r.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(i, []);
221
- } catch (w) {
222
- n = w;
220
+ Reflect.construct(r, []);
221
+ } catch (D) {
222
+ t = D;
223
223
  }
224
- Reflect.construct(t, [], i);
224
+ Reflect.construct(e, [], r);
225
225
  } else {
226
226
  try {
227
- i.call();
228
- } catch (w) {
229
- n = w;
227
+ r.call();
228
+ } catch (D) {
229
+ t = D;
230
230
  }
231
- t.call(i.prototype);
231
+ e.call(r.prototype);
232
232
  }
233
233
  } else {
234
234
  try {
235
235
  throw Error();
236
- } catch (w) {
237
- n = w;
236
+ } catch (D) {
237
+ t = D;
238
238
  }
239
- t();
239
+ e();
240
240
  }
241
- } catch (w) {
242
- if (w && n && typeof w.stack == "string") {
243
- for (var o = w.stack.split(`
244
- `), c = n.stack.split(`
245
- `), f = o.length - 1, p = c.length - 1; f >= 1 && p >= 0 && o[f] !== c[p]; )
246
- p--;
247
- for (; f >= 1 && p >= 0; f--, p--)
248
- if (o[f] !== c[p]) {
249
- if (f !== 1 || p !== 1)
241
+ } catch (D) {
242
+ if (D && t && typeof D.stack == "string") {
243
+ for (var i = D.stack.split(`
244
+ `), a = t.stack.split(`
245
+ `), B = i.length - 1, d = a.length - 1; B >= 1 && d >= 0 && i[B] !== a[d]; )
246
+ d--;
247
+ for (; B >= 1 && d >= 0; B--, d--)
248
+ if (i[B] !== a[d]) {
249
+ if (B !== 1 || d !== 1)
250
250
  do
251
- if (f--, p--, p < 0 || o[f] !== c[p]) {
252
- var h = `
253
- ` + o[f].replace(" at new ", " at ");
254
- return t.displayName && h.includes("<anonymous>") && (h = h.replace("<anonymous>", t.displayName)), typeof t == "function" && ze.set(t, h), h;
251
+ if (B--, d--, d < 0 || i[B] !== a[d]) {
252
+ var Q = `
253
+ ` + i[B].replace(" at new ", " at ");
254
+ return e.displayName && Q.includes("<anonymous>") && (Q = Q.replace("<anonymous>", e.displayName)), typeof e == "function" && WA.set(e, Q), Q;
255
255
  }
256
- while (f >= 1 && p >= 0);
256
+ while (B >= 1 && d >= 0);
257
257
  break;
258
258
  }
259
259
  }
260
260
  } finally {
261
- Le = !1, pe.current = s, Se(), Error.prepareStackTrace = r;
261
+ GA = !1, dA.current = o, IA(), Error.prepareStackTrace = n;
262
262
  }
263
- var b = t ? t.displayName || t.name : "", N = b ? Pe(b) : "";
264
- return typeof t == "function" && ze.set(t, N), N;
263
+ var C = e ? e.displayName || e.name : "", F = C ? NA(C) : "";
264
+ return typeof e == "function" && WA.set(e, F), F;
265
265
  }
266
- function ne(t, l, e) {
267
- return K(t, !1);
266
+ function tA(e, c, A) {
267
+ return V(e, !1);
268
268
  }
269
- function $e(t) {
270
- var l = t.prototype;
271
- return !!(l && l.isReactComponent);
269
+ function YA(e) {
270
+ var c = e.prototype;
271
+ return !!(c && c.isReactComponent);
272
272
  }
273
- function Be(t, l, e) {
274
- if (t == null)
273
+ function TA(e, c, A) {
274
+ if (e == null)
275
275
  return "";
276
- if (typeof t == "function")
277
- return K(t, $e(t));
278
- if (typeof t == "string")
279
- return Pe(t);
280
- switch (t) {
281
- case T:
282
- return Pe("Suspense");
283
- case k:
284
- return Pe("SuspenseList");
276
+ if (typeof e == "function")
277
+ return V(e, YA(e));
278
+ if (typeof e == "string")
279
+ return NA(e);
280
+ switch (e) {
281
+ case b:
282
+ return NA("Suspense");
283
+ case y:
284
+ return NA("SuspenseList");
285
285
  }
286
- if (typeof t == "object")
287
- switch (t.$$typeof) {
288
- case x:
289
- return ne(t.render);
290
- case A:
291
- return Be(t.type, l, e);
286
+ if (typeof e == "object")
287
+ switch (e.$$typeof) {
288
+ case m:
289
+ return tA(e.render);
290
+ case p:
291
+ return TA(e.type, c, A);
292
292
  case q: {
293
- var n = t, r = n._payload, s = n._init;
293
+ var t = e, n = t._payload, o = t._init;
294
294
  try {
295
- return Be(s(r), l, e);
295
+ return TA(o(n), c, A);
296
296
  } catch {
297
297
  }
298
298
  }
299
299
  }
300
300
  return "";
301
301
  }
302
- var Ie = Object.prototype.hasOwnProperty, Z = {}, W = G.ReactDebugCurrentFrame;
303
- function Ce(t) {
304
- if (t) {
305
- var l = t._owner, e = Be(t.type, t._source, l ? l.type : null);
306
- W.setExtraStackFrame(e);
302
+ var MA = Object.prototype.hasOwnProperty, _ = {}, X = Z.ReactDebugCurrentFrame;
303
+ function PA(e) {
304
+ if (e) {
305
+ var c = e._owner, A = TA(e.type, e._source, c ? c.type : null);
306
+ X.setExtraStackFrame(A);
307
307
  } else
308
- W.setExtraStackFrame(null);
308
+ X.setExtraStackFrame(null);
309
309
  }
310
- function Ue(t, l, e, n, r) {
310
+ function LA(e, c, A, t, n) {
311
311
  {
312
- var s = Function.call.bind(Ie);
313
- for (var i in t)
314
- if (s(t, i)) {
315
- var o = void 0;
312
+ var o = Function.call.bind(MA);
313
+ for (var r in e)
314
+ if (o(e, r)) {
315
+ var i = void 0;
316
316
  try {
317
- if (typeof t[i] != "function") {
318
- var c = Error((n || "React class") + ": " + e + " type `" + i + "` is invalid; it must be a function, usually from the `prop-types` package, but received `" + typeof t[i] + "`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");
319
- throw c.name = "Invariant Violation", c;
317
+ if (typeof e[r] != "function") {
318
+ var a = Error((t || "React class") + ": " + A + " type `" + r + "` is invalid; it must be a function, usually from the `prop-types` package, but received `" + typeof e[r] + "`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");
319
+ throw a.name = "Invariant Violation", a;
320
320
  }
321
- o = t[i](l, i, n, e, null, "SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED");
322
- } catch (f) {
323
- o = f;
321
+ i = e[r](c, r, t, A, null, "SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED");
322
+ } catch (B) {
323
+ i = B;
324
324
  }
325
- o && !(o instanceof Error) && (Ce(r), O("%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).", n || "React class", e, i, typeof o), Ce(null)), o instanceof Error && !(o.message in Z) && (Z[o.message] = !0, Ce(r), O("Failed %s type: %s", e, o.message), Ce(null));
325
+ i && !(i instanceof Error) && (PA(n), S("%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).", t || "React class", A, r, typeof i), PA(null)), i instanceof Error && !(i.message in _) && (_[i.message] = !0, PA(n), S("Failed %s type: %s", A, i.message), PA(null));
326
326
  }
327
327
  }
328
328
  }
329
- var Fe = Array.isArray;
330
- function Ve(t) {
331
- return Fe(t);
329
+ var HA = Array.isArray;
330
+ function jA(e) {
331
+ return HA(e);
332
332
  }
333
- function he(t) {
333
+ function QA(e) {
334
334
  {
335
- var l = typeof Symbol == "function" && Symbol.toStringTag, e = l && t[Symbol.toStringTag] || t.constructor.name || "Object";
336
- return e;
335
+ var c = typeof Symbol == "function" && Symbol.toStringTag, A = c && e[Symbol.toStringTag] || e.constructor.name || "Object";
336
+ return A;
337
337
  }
338
338
  }
339
- function Xe(t) {
339
+ function KA(e) {
340
340
  try {
341
- return we(t), !1;
341
+ return DA(e), !1;
342
342
  } catch {
343
343
  return !0;
344
344
  }
345
345
  }
346
- function we(t) {
347
- return "" + t;
346
+ function DA(e) {
347
+ return "" + e;
348
348
  }
349
- function st(t) {
350
- if (Xe(t))
351
- return O("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.", he(t)), we(t);
349
+ function oe(e) {
350
+ if (KA(e))
351
+ return S("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.", QA(e)), DA(e);
352
352
  }
353
- var We = G.ReactCurrentOwner, Je = {
353
+ var XA = Z.ReactCurrentOwner, zA = {
354
354
  key: !0,
355
355
  ref: !0,
356
356
  __self: !0,
357
357
  __source: !0
358
- }, Ge, Ze;
359
- function at(t) {
360
- if (Ie.call(t, "ref")) {
361
- var l = Object.getOwnPropertyDescriptor(t, "ref").get;
362
- if (l && l.isReactWarning)
358
+ }, ZA, _A;
359
+ function se(e) {
360
+ if (MA.call(e, "ref")) {
361
+ var c = Object.getOwnPropertyDescriptor(e, "ref").get;
362
+ if (c && c.isReactWarning)
363
363
  return !1;
364
364
  }
365
- return t.ref !== void 0;
365
+ return e.ref !== void 0;
366
366
  }
367
- function yt(t) {
368
- if (Ie.call(t, "key")) {
369
- var l = Object.getOwnPropertyDescriptor(t, "key").get;
370
- if (l && l.isReactWarning)
367
+ function we(e) {
368
+ if (MA.call(e, "key")) {
369
+ var c = Object.getOwnPropertyDescriptor(e, "key").get;
370
+ if (c && c.isReactWarning)
371
371
  return !1;
372
372
  }
373
- return t.key !== void 0;
373
+ return e.key !== void 0;
374
374
  }
375
- function St(t, l) {
376
- typeof t.ref == "string" && We.current;
375
+ function Ie(e, c) {
376
+ typeof e.ref == "string" && XA.current;
377
377
  }
378
- function wt(t, l) {
378
+ function De(e, c) {
379
379
  {
380
- var e = function() {
381
- Ge || (Ge = !0, O("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", l));
380
+ var A = function() {
381
+ ZA || (ZA = !0, S("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", c));
382
382
  };
383
- e.isReactWarning = !0, Object.defineProperty(t, "key", {
384
- get: e,
383
+ A.isReactWarning = !0, Object.defineProperty(e, "key", {
384
+ get: A,
385
385
  configurable: !0
386
386
  });
387
387
  }
388
388
  }
389
- function He(t, l) {
389
+ function kA(e, c) {
390
390
  {
391
- var e = function() {
392
- Ze || (Ze = !0, O("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", l));
391
+ var A = function() {
392
+ _A || (_A = !0, S("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", c));
393
393
  };
394
- e.isReactWarning = !0, Object.defineProperty(t, "ref", {
395
- get: e,
394
+ A.isReactWarning = !0, Object.defineProperty(e, "ref", {
395
+ get: A,
396
396
  configurable: !0
397
397
  });
398
398
  }
399
399
  }
400
- var Rt = function(t, l, e, n, r, s, i) {
401
- var o = {
400
+ var he = function(e, c, A, t, n, o, r) {
401
+ var i = {
402
402
  // This tag allows us to uniquely identify this as a React Element
403
- $$typeof: a,
403
+ $$typeof: s,
404
404
  // Built-in properties that belong on the element
405
- type: t,
406
- key: l,
407
- ref: e,
408
- props: i,
405
+ type: e,
406
+ key: c,
407
+ ref: A,
408
+ props: r,
409
409
  // Record the component responsible for creating this element.
410
- _owner: s
410
+ _owner: o
411
411
  };
412
- return o._store = {}, Object.defineProperty(o._store, "validated", {
412
+ return i._store = {}, Object.defineProperty(i._store, "validated", {
413
413
  configurable: !1,
414
414
  enumerable: !1,
415
415
  writable: !0,
416
416
  value: !1
417
- }), Object.defineProperty(o, "_self", {
417
+ }), Object.defineProperty(i, "_self", {
418
418
  configurable: !1,
419
419
  enumerable: !1,
420
420
  writable: !1,
421
- value: n
422
- }), Object.defineProperty(o, "_source", {
421
+ value: t
422
+ }), Object.defineProperty(i, "_source", {
423
423
  configurable: !1,
424
424
  enumerable: !1,
425
425
  writable: !1,
426
- value: r
427
- }), Object.freeze && (Object.freeze(o.props), Object.freeze(o)), o;
426
+ value: n
427
+ }), Object.freeze && (Object.freeze(i.props), Object.freeze(i)), i;
428
428
  };
429
- function xt(t, l, e, n, r) {
429
+ function me(e, c, A, t, n) {
430
430
  {
431
- var s, i = {}, o = null, c = null;
432
- e !== void 0 && (st(e), o = "" + e), yt(l) && (st(l.key), o = "" + l.key), at(l) && (c = l.ref, St(l, r));
433
- for (s in l)
434
- Ie.call(l, s) && !Je.hasOwnProperty(s) && (i[s] = l[s]);
435
- if (t && t.defaultProps) {
436
- var f = t.defaultProps;
437
- for (s in f)
438
- i[s] === void 0 && (i[s] = f[s]);
431
+ var o, r = {}, i = null, a = null;
432
+ A !== void 0 && (oe(A), i = "" + A), we(c) && (oe(c.key), i = "" + c.key), se(c) && (a = c.ref, Ie(c, n));
433
+ for (o in c)
434
+ MA.call(c, o) && !zA.hasOwnProperty(o) && (r[o] = c[o]);
435
+ if (e && e.defaultProps) {
436
+ var B = e.defaultProps;
437
+ for (o in B)
438
+ r[o] === void 0 && (r[o] = B[o]);
439
439
  }
440
- if (o || c) {
441
- var p = typeof t == "function" ? t.displayName || t.name || "Unknown" : t;
442
- o && wt(i, p), c && He(i, p);
440
+ if (i || a) {
441
+ var d = typeof e == "function" ? e.displayName || e.name || "Unknown" : e;
442
+ i && De(r, d), a && kA(r, d);
443
443
  }
444
- return Rt(t, o, c, r, n, We.current, i);
444
+ return he(e, i, a, n, t, XA.current, r);
445
445
  }
446
446
  }
447
- var _e = G.ReactCurrentOwner, ct = G.ReactDebugCurrentFrame;
448
- function le(t) {
449
- if (t) {
450
- var l = t._owner, e = Be(t.type, t._source, l ? l.type : null);
451
- ct.setExtraStackFrame(e);
447
+ var OA = Z.ReactCurrentOwner, ae = Z.ReactDebugCurrentFrame;
448
+ function cA(e) {
449
+ if (e) {
450
+ var c = e._owner, A = TA(e.type, e._source, c ? c.type : null);
451
+ ae.setExtraStackFrame(A);
452
452
  } else
453
- ct.setExtraStackFrame(null);
453
+ ae.setExtraStackFrame(null);
454
454
  }
455
- var Ke;
456
- Ke = !1;
457
- function Qe(t) {
458
- return typeof t == "object" && t !== null && t.$$typeof === a;
455
+ var VA;
456
+ VA = !1;
457
+ function $A(e) {
458
+ return typeof e == "object" && e !== null && e.$$typeof === s;
459
459
  }
460
- function lt() {
460
+ function ce() {
461
461
  {
462
- if (_e.current) {
463
- var t = se(_e.current.type);
464
- if (t)
462
+ if (OA.current) {
463
+ var e = oA(OA.current.type);
464
+ if (e)
465
465
  return `
466
466
 
467
- Check the render method of \`` + t + "`.";
467
+ Check the render method of \`` + e + "`.";
468
468
  }
469
469
  return "";
470
470
  }
471
471
  }
472
- function Et(t) {
472
+ function ve(e) {
473
473
  return "";
474
474
  }
475
- var ut = {};
476
- function Tt(t) {
475
+ var ge = {};
476
+ function be(e) {
477
477
  {
478
- var l = lt();
479
- if (!l) {
480
- var e = typeof t == "string" ? t : t.displayName || t.name;
481
- e && (l = `
478
+ var c = ce();
479
+ if (!c) {
480
+ var A = typeof e == "string" ? e : e.displayName || e.name;
481
+ A && (c = `
482
482
 
483
- Check the top-level render call using <` + e + ">.");
483
+ Check the top-level render call using <` + A + ">.");
484
484
  }
485
- return l;
485
+ return c;
486
486
  }
487
487
  }
488
- function dt(t, l) {
488
+ function ue(e, c) {
489
489
  {
490
- if (!t._store || t._store.validated || t.key != null)
490
+ if (!e._store || e._store.validated || e.key != null)
491
491
  return;
492
- t._store.validated = !0;
493
- var e = Tt(l);
494
- if (ut[e])
492
+ e._store.validated = !0;
493
+ var A = be(c);
494
+ if (ge[A])
495
495
  return;
496
- ut[e] = !0;
497
- var n = "";
498
- t && t._owner && t._owner !== _e.current && (n = " It was passed a child from " + se(t._owner.type) + "."), le(t), O('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.', e, n), le(null);
496
+ ge[A] = !0;
497
+ var t = "";
498
+ e && e._owner && e._owner !== OA.current && (t = " It was passed a child from " + oA(e._owner.type) + "."), cA(e), S('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.', A, t), cA(null);
499
499
  }
500
500
  }
501
- function ft(t, l) {
501
+ function Be(e, c) {
502
502
  {
503
- if (typeof t != "object")
503
+ if (typeof e != "object")
504
504
  return;
505
- if (Ve(t))
506
- for (var e = 0; e < t.length; e++) {
507
- var n = t[e];
508
- Qe(n) && dt(n, l);
505
+ if (jA(e))
506
+ for (var A = 0; A < e.length; A++) {
507
+ var t = e[A];
508
+ $A(t) && ue(t, c);
509
509
  }
510
- else if (Qe(t))
511
- t._store && (t._store.validated = !0);
512
- else if (t) {
513
- var r = U(t);
514
- if (typeof r == "function" && r !== t.entries)
515
- for (var s = r.call(t), i; !(i = s.next()).done; )
516
- Qe(i.value) && dt(i.value, l);
510
+ else if ($A(e))
511
+ e._store && (e._store.validated = !0);
512
+ else if (e) {
513
+ var n = L(e);
514
+ if (typeof n == "function" && n !== e.entries)
515
+ for (var o = n.call(e), r; !(r = o.next()).done; )
516
+ $A(r.value) && ue(r.value, c);
517
517
  }
518
518
  }
519
519
  }
520
- function At(t) {
520
+ function pe(e) {
521
521
  {
522
- var l = t.type;
523
- if (l == null || typeof l == "string")
522
+ var c = e.type;
523
+ if (c == null || typeof c == "string")
524
524
  return;
525
- var e;
526
- if (typeof l == "function")
527
- e = l.propTypes;
528
- else if (typeof l == "object" && (l.$$typeof === x || // Note: Memo only checks outer props here.
525
+ var A;
526
+ if (typeof c == "function")
527
+ A = c.propTypes;
528
+ else if (typeof c == "object" && (c.$$typeof === m || // Note: Memo only checks outer props here.
529
529
  // Inner props are checked in the reconciler.
530
- l.$$typeof === A))
531
- e = l.propTypes;
530
+ c.$$typeof === p))
531
+ A = c.propTypes;
532
532
  else
533
533
  return;
534
- if (e) {
535
- var n = se(l);
536
- Ue(e, t.props, "prop", n, t);
537
- } else if (l.PropTypes !== void 0 && !Ke) {
538
- Ke = !0;
539
- var r = se(l);
540
- O("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?", r || "Unknown");
534
+ if (A) {
535
+ var t = oA(c);
536
+ LA(A, e.props, "prop", t, e);
537
+ } else if (c.PropTypes !== void 0 && !VA) {
538
+ VA = !0;
539
+ var n = oA(c);
540
+ S("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?", n || "Unknown");
541
541
  }
542
- typeof l.getDefaultProps == "function" && !l.getDefaultProps.isReactClassApproved && O("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.");
542
+ typeof c.getDefaultProps == "function" && !c.getDefaultProps.isReactClassApproved && S("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.");
543
543
  }
544
544
  }
545
- function Nt(t) {
545
+ function Fe(e) {
546
546
  {
547
- for (var l = Object.keys(t.props), e = 0; e < l.length; e++) {
548
- var n = l[e];
549
- if (n !== "children" && n !== "key") {
550
- le(t), O("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.", n), le(null);
547
+ for (var c = Object.keys(e.props), A = 0; A < c.length; A++) {
548
+ var t = c[A];
549
+ if (t !== "children" && t !== "key") {
550
+ cA(e), S("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.", t), cA(null);
551
551
  break;
552
552
  }
553
553
  }
554
- t.ref !== null && (le(t), O("Invalid attribute `ref` supplied to `React.Fragment`."), le(null));
554
+ e.ref !== null && (cA(e), S("Invalid attribute `ref` supplied to `React.Fragment`."), cA(null));
555
555
  }
556
556
  }
557
- var mt = {};
558
- function pt(t, l, e, n, r, s) {
557
+ var le = {};
558
+ function de(e, c, A, t, n, o) {
559
559
  {
560
- var i = Ye(t);
561
- if (!i) {
562
- var o = "";
563
- (t === void 0 || typeof t == "object" && t !== null && Object.keys(t).length === 0) && (o += " You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.");
564
- var c = Et();
565
- c ? o += c : o += lt();
566
- var f;
567
- t === null ? f = "null" : Ve(t) ? f = "array" : t !== void 0 && t.$$typeof === a ? (f = "<" + (se(t.type) || "Unknown") + " />", o = " Did you accidentally export a JSX literal instead of a component?") : f = typeof t, O("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s", f, o);
560
+ var r = JA(e);
561
+ if (!r) {
562
+ var i = "";
563
+ (e === void 0 || typeof e == "object" && e !== null && Object.keys(e).length === 0) && (i += " You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.");
564
+ var a = ve();
565
+ a ? i += a : i += ce();
566
+ var B;
567
+ e === null ? B = "null" : jA(e) ? B = "array" : e !== void 0 && e.$$typeof === s ? (B = "<" + (oA(e.type) || "Unknown") + " />", i = " Did you accidentally export a JSX literal instead of a component?") : B = typeof e, S("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s", B, i);
568
568
  }
569
- var p = xt(t, l, e, r, s);
570
- if (p == null)
571
- return p;
572
- if (i) {
573
- var h = l.children;
574
- if (h !== void 0)
575
- if (n)
576
- if (Ve(h)) {
577
- for (var b = 0; b < h.length; b++)
578
- ft(h[b], t);
579
- Object.freeze && Object.freeze(h);
569
+ var d = me(e, c, A, n, o);
570
+ if (d == null)
571
+ return d;
572
+ if (r) {
573
+ var Q = c.children;
574
+ if (Q !== void 0)
575
+ if (t)
576
+ if (jA(Q)) {
577
+ for (var C = 0; C < Q.length; C++)
578
+ Be(Q[C], e);
579
+ Object.freeze && Object.freeze(Q);
580
580
  } else
581
- O("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
+ S("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");
582
582
  else
583
- ft(h, t);
583
+ Be(Q, e);
584
584
  }
585
- if (Ie.call(l, "key")) {
586
- var N = se(t), w = Object.keys(l).filter(function(I) {
587
- return I !== "key";
588
- }), P = w.length > 0 ? "{key: someKey, " + w.join(": ..., ") + ": ...}" : "{key: someKey}";
589
- if (!mt[N + P]) {
590
- var _ = w.length > 0 ? "{" + w.join(": ..., ") + ": ...}" : "{}";
591
- O(`A props object containing a "key" prop is being spread into JSX:
585
+ if (MA.call(c, "key")) {
586
+ var F = oA(e), D = Object.keys(c).filter(function(M) {
587
+ return M !== "key";
588
+ }), N = D.length > 0 ? "{key: someKey, " + D.join(": ..., ") + ": ...}" : "{key: someKey}";
589
+ if (!le[F + N]) {
590
+ var O = D.length > 0 ? "{" + D.join(": ..., ") + ": ...}" : "{}";
591
+ S(`A props object containing a "key" prop is being spread into JSX:
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} />`, P, N, _, N), mt[N + P] = !0;
596
+ <%s key={someKey} {...props} />`, N, F, O, F), le[F + N] = !0;
597
597
  }
598
598
  }
599
- return t === d ? Nt(p) : At(p), p;
599
+ return e === u ? Fe(d) : pe(d), d;
600
600
  }
601
601
  }
602
- function kt(t, l, e) {
603
- return pt(t, l, e, !0);
602
+ function ye(e, c, A) {
603
+ return de(e, c, A, !0);
604
604
  }
605
- function Pt(t, l, e) {
606
- return pt(t, l, e, !1);
605
+ function Ne(e, c, A) {
606
+ return de(e, c, A, !1);
607
607
  }
608
- var Re = Pt, It = kt;
609
- tt.Fragment = d, tt.jsx = Re, tt.jsxs = It;
610
- })()), tt;
608
+ var hA = Ne, Me = ye;
609
+ ee.Fragment = u, ee.jsx = hA, ee.jsxs = Me;
610
+ })()), ee;
611
611
  }
612
- var Mt;
613
- function on() {
614
- return Mt || (Mt = 1, process.env.NODE_ENV === "production" ? gt.exports = nn() : gt.exports = rn()), gt.exports;
612
+ var Ue;
613
+ function rt() {
614
+ return Ue || (Ue = 1, process.env.NODE_ENV === "production" ? fe.exports = tt() : fe.exports = nt()), fe.exports;
615
615
  }
616
- var v = on();
617
- const sn = ({ action: u, row: a }) => /* @__PURE__ */ v.jsx("div", { className: "effect0", "data-action-id": u.id, "data-row-id": a.id, children: /* @__PURE__ */ v.jsx("div", { className: "effect0-text", children: `Audio: ${u.data.name}` }) }), an = ({ action: u, row: a }) => /* @__PURE__ */ v.jsx("div", { className: "effect1", "data-action-id": u.id, "data-row-id": a.id, children: /* @__PURE__ */ v.jsx("div", { className: "effect1-text", children: `Video: ${u.data.name}` }) }), cn = ({ action: u, row: a }) => /* @__PURE__ */ v.jsx("div", { className: "effect2", "data-action-id": u.id, "data-row-id": a.id, children: /* @__PURE__ */ v.jsx("div", { className: "effect2-text", children: `Video audio: ${u.data.name}` }) }), ln = (u) => {
618
- const a = u.toLowerCase();
619
- return a.endsWith(".mp4") || a.endsWith(".webm") || a.endsWith(".mov") || a.endsWith(".m4v") ? "video" : a.endsWith(".mp3") || a.endsWith(".wav") || a.endsWith(".ogg") || a.endsWith(".m4a") || a.endsWith(".aac") ? "audio" : "other";
616
+ var E = rt();
617
+ const it = ({ action: g, row: s }) => /* @__PURE__ */ E.jsx("div", { className: "effect0", "data-action-id": g.id, "data-row-id": s.id, children: /* @__PURE__ */ E.jsx("div", { className: "effect0-text", children: `Audio: ${g.data.name}` }) }), ot = ({ action: g, row: s }) => /* @__PURE__ */ E.jsx("div", { className: "effect1", "data-action-id": g.id, "data-row-id": s.id, children: /* @__PURE__ */ E.jsx("div", { className: "effect1-text", children: `Video: ${g.data.name}` }) }), st = ({ action: g, row: s }) => /* @__PURE__ */ E.jsx("div", { className: "effect2", "data-action-id": g.id, "data-row-id": s.id, children: /* @__PURE__ */ E.jsx("div", { className: "effect2-text", children: `Video audio: ${g.data.name}` }) }), at = (g) => {
618
+ const s = g.toLowerCase();
619
+ return s.endsWith(".mp4") || s.endsWith(".webm") || s.endsWith(".mov") || s.endsWith(".m4v") ? "video" : s.endsWith(".mp3") || s.endsWith(".wav") || s.endsWith(".ogg") || s.endsWith(".m4a") || s.endsWith(".aac") ? "audio" : "other";
620
620
  };
621
- class un {
621
+ class ct {
622
622
  blobUrlBySrc = /* @__PURE__ */ new Map();
623
623
  pendingBySrc = /* @__PURE__ */ new Map();
624
624
  /**
625
625
  * Preloads a URL into memory and returns a blob: URL.
626
626
  * Useful to avoid runtime buffering/stalls when seeking frequently.
627
627
  */
628
- async preloadToBlobUrl(a) {
629
- if (!a) return a;
630
- const m = this.blobUrlBySrc.get(a);
631
- if (m) return m;
632
- const d = this.pendingBySrc.get(a);
633
- if (d) return d;
634
- const g = (async () => {
635
- const S = await fetch(a, { cache: "force-cache" });
636
- if (!S.ok) throw new Error(`Failed to fetch ${a}: ${S.status}`);
637
- const R = await S.blob(), E = URL.createObjectURL(R);
638
- return this.blobUrlBySrc.set(a, E), E;
639
- })().catch((S) => (console.warn("[mediaCache] preload failed:", a, S), a)).finally(() => {
640
- this.pendingBySrc.delete(a);
628
+ async preloadToBlobUrl(s) {
629
+ if (!s) return s;
630
+ const l = this.blobUrlBySrc.get(s);
631
+ if (l) return l;
632
+ const u = this.pendingBySrc.get(s);
633
+ if (u) return u;
634
+ const f = (async () => {
635
+ const I = await fetch(s, { cache: "force-cache" });
636
+ if (!I.ok) throw new Error(`Failed to fetch ${s}: ${I.status}`);
637
+ const h = await I.blob(), v = URL.createObjectURL(h);
638
+ return this.blobUrlBySrc.set(s, v), v;
639
+ })().catch((I) => (console.warn("[mediaCache] preload failed:", s, I), s)).finally(() => {
640
+ this.pendingBySrc.delete(s);
641
641
  });
642
- return this.pendingBySrc.set(a, g), g;
642
+ return this.pendingBySrc.set(s, f), f;
643
643
  }
644
644
  /** Returns a blob URL if available, otherwise the original `src`. */
645
- resolve(a) {
646
- return this.blobUrlBySrc.get(a) ?? a;
645
+ resolve(s) {
646
+ return this.blobUrlBySrc.get(s) ?? s;
647
647
  }
648
648
  /** Starts preload in background (non-blocking). */
649
- warm(a) {
650
- this.preloadToBlobUrl(a);
649
+ warm(s) {
650
+ this.preloadToBlobUrl(s);
651
651
  }
652
652
  /** Convenience: preload all unique action.data.src from editor data. */
653
- warmFromEditorData(a) {
654
- const m = /* @__PURE__ */ new Set(), d = Array.isArray(a) ? a : [];
655
- for (const g of d) {
656
- const S = g?.actions;
657
- if (Array.isArray(S))
658
- for (const R of S) {
659
- const E = R?.data?.src;
660
- typeof E == "string" && E && m.add(E);
653
+ warmFromEditorData(s) {
654
+ const l = /* @__PURE__ */ new Set(), u = Array.isArray(s) ? s : [];
655
+ for (const f of u) {
656
+ const I = f?.actions;
657
+ if (Array.isArray(I))
658
+ for (const h of I) {
659
+ const v = h?.data?.src;
660
+ typeof v == "string" && v && l.add(v);
661
661
  }
662
662
  }
663
- for (const g of m) {
664
- const S = ln(g);
665
- (S === "video" || S === "audio") && this.warm(g);
663
+ for (const f of l) {
664
+ const I = at(f);
665
+ (I === "video" || I === "audio") && this.warm(f);
666
666
  }
667
667
  }
668
668
  }
669
- const it = new un(), dn = (u) => {
670
- if (!u) return;
671
- const m = u.split("#")[0].split("?")[0].toLowerCase(), d = m.lastIndexOf(".");
672
- if (d < 0) return;
673
- const g = m.slice(d + 1);
674
- if (g)
675
- return g === "m4a" || g === "m4v" ? "mp4" : g;
669
+ const re = new ct(), gt = (g) => {
670
+ if (!g) return;
671
+ const l = g.split("#")[0].split("?")[0].toLowerCase(), u = l.lastIndexOf(".");
672
+ if (u < 0) return;
673
+ const f = l.slice(u + 1);
674
+ if (f)
675
+ return f === "m4a" || f === "m4v" ? "mp4" : f;
676
676
  };
677
- class fn {
677
+ class ut {
678
678
  howlBySrc = {};
679
679
  activeByActionId = {};
680
- getHowl(a) {
681
- const m = it.resolve(a), d = m.startsWith("blob:") ? a : m, g = d;
682
- if (this.howlBySrc[g]) return this.howlBySrc[g];
683
- const S = dn(a), R = new Yt({
684
- src: [d],
685
- format: S ? [S] : void 0,
680
+ getHowl(s) {
681
+ const l = re.resolve(s), u = l.startsWith("blob:") ? s : l, f = u;
682
+ if (this.howlBySrc[f]) return this.howlBySrc[f];
683
+ const I = gt(s), h = new Je({
684
+ src: [u],
685
+ format: I ? [I] : void 0,
686
686
  loop: !0,
687
687
  autoplay: !1,
688
688
  preload: !0
689
689
  });
690
- return this.howlBySrc[g] = R, R;
690
+ return this.howlBySrc[f] = h, h;
691
691
  }
692
692
  /**
693
693
  * Ensure the underlying WebAudio context is resumed.
@@ -698,79 +698,79 @@ class fn {
698
698
  */
699
699
  unlock() {
700
700
  try {
701
- const a = qt.ctx;
702
- a && a.state === "suspended" && a.resume();
701
+ const s = qe.ctx;
702
+ s && s.state === "suspended" && s.resume();
703
703
  } catch {
704
704
  }
705
705
  }
706
- warm(a) {
707
- a && (it.warm(a), this.getHowl(a));
706
+ warm(s) {
707
+ s && (re.warm(s), this.getHowl(s));
708
708
  }
709
- seekForEngineTime(a, m, d, g, S) {
710
- const R = Number(S), E = Number.isFinite(R) ? R : 0, x = a.duration();
711
- if (!Number.isFinite(x) || x <= 0) {
712
- a.seek(Math.max(0, g - d + E), m);
709
+ seekForEngineTime(s, l, u, f, I) {
710
+ const h = Number(I), v = Number.isFinite(h) ? h : 0, m = s.duration();
711
+ if (!Number.isFinite(m) || m <= 0) {
712
+ s.seek(Math.max(0, f - u + v), l);
713
713
  return;
714
714
  }
715
- const T = (g - d + E) % x, k = T < 0 ? T + x : T;
716
- a.seek(k, m);
715
+ const b = (f - u + v) % m, y = b < 0 ? b + m : b;
716
+ s.seek(y, l);
717
717
  }
718
- start(a) {
719
- const { actionId: m, src: d, startTime: g, time: S, engine: R } = a, E = Number(a.offset ?? 0), x = Number.isFinite(E) ? E : 0, T = this.activeByActionId[m];
720
- if (T) {
721
- const X = this.getHowl(T.src);
722
- X.rate(R.getPlayRate(), T.soundId);
718
+ start(s) {
719
+ const { actionId: l, src: u, startTime: f, time: I, engine: h } = s, v = Number(s.offset ?? 0), m = Number.isFinite(v) ? v : 0, b = this.activeByActionId[l];
720
+ if (b) {
721
+ const K = this.getHowl(b.src);
722
+ K.rate(h.getPlayRate(), b.soundId);
723
723
  try {
724
- X.playing(T.soundId) || X.play(T.soundId);
724
+ K.playing(b.soundId) || K.play(b.soundId);
725
725
  } catch {
726
726
  }
727
- R.isPlaying || this.seekForEngineTime(X, T.soundId, T.startTime, S, T.offset);
727
+ h.isPlaying || this.seekForEngineTime(K, b.soundId, b.startTime, I, b.offset);
728
728
  return;
729
729
  }
730
- const k = this.getHowl(d), A = k.play();
731
- k.rate(R.getPlayRate(), A), this.seekForEngineTime(k, A, g, S, x);
730
+ const y = this.getHowl(u), p = y.play();
731
+ y.rate(h.getPlayRate(), p), this.seekForEngineTime(y, p, f, I, m);
732
732
  let q = performance.now();
733
- const z = ({ time: X }) => {
734
- if (!R.isPlaying) {
735
- this.seekForEngineTime(k, A, g, X, x);
733
+ const W = ({ time: K }) => {
734
+ if (!h.isPlaying) {
735
+ this.seekForEngineTime(y, p, f, K, m);
736
736
  return;
737
737
  }
738
- const U = performance.now();
739
- if (!(U - q < 500)) {
740
- q = U;
738
+ const L = performance.now();
739
+ if (!(L - q < 500)) {
740
+ q = L;
741
741
  try {
742
- const G = Math.max(0, X - g + x), O = Number(k.seek(A));
743
- Number.isFinite(O) && Math.abs(O - G) > 0.25 && this.seekForEngineTime(k, A, g, X, x);
742
+ const Z = Math.max(0, K - f + m), S = Number(y.seek(p));
743
+ Number.isFinite(S) && Math.abs(S - Z) > 0.25 && this.seekForEngineTime(y, p, f, K, m);
744
744
  } catch {
745
745
  }
746
746
  }
747
- }, de = ({ rate: X }) => {
748
- k.rate(X, A);
747
+ }, uA = ({ rate: K }) => {
748
+ y.rate(K, p);
749
749
  };
750
- R.on("afterSetTime", z), R.on("afterSetPlayRate", de), this.activeByActionId[m] = {
751
- src: d,
752
- startTime: g,
753
- offset: x,
754
- soundId: A,
755
- engine: R,
750
+ h.on("afterSetTime", W), h.on("afterSetPlayRate", uA), this.activeByActionId[l] = {
751
+ src: u,
752
+ startTime: f,
753
+ offset: m,
754
+ soundId: p,
755
+ engine: h,
756
756
  lastResyncAtMs: q,
757
- time: z,
758
- rate: de
757
+ time: W,
758
+ rate: uA
759
759
  };
760
760
  }
761
- stop(a) {
762
- const { actionId: m } = a, d = this.activeByActionId[m];
763
- if (!d) return;
764
- const g = this.getHowl(d.src);
761
+ stop(s) {
762
+ const { actionId: l } = s, u = this.activeByActionId[l];
763
+ if (!u) return;
764
+ const f = this.getHowl(u.src);
765
765
  try {
766
- g.stop(d.soundId);
766
+ f.stop(u.soundId);
767
767
  } catch {
768
768
  }
769
- d.time && d.engine.off("afterSetTime", d.time), d.rate && d.engine.off("afterSetPlayRate", d.rate), delete this.activeByActionId[m];
769
+ u.time && u.engine.off("afterSetTime", u.time), u.rate && u.engine.off("afterSetPlayRate", u.rate), delete this.activeByActionId[l];
770
770
  }
771
771
  }
772
- const ie = new fn();
773
- class mn {
772
+ const rA = new ut();
773
+ class Bt {
774
774
  videoEl = null;
775
775
  currentSrc = null;
776
776
  lastSeekAtMs = 0;
@@ -779,60 +779,60 @@ class mn {
779
779
  boundActionStart = 0;
780
780
  vfcHandle = null;
781
781
  rafHandle = null;
782
- attach(a) {
783
- this.videoEl = a, this.currentSrc = a?.currentSrc || a?.getAttribute("src") || null, this.lastSeekAtMs = 0, this.lastRate = null, this.unbindEngine(), this.setActive(!1);
782
+ attach(s) {
783
+ this.videoEl = s, this.currentSrc = s?.currentSrc || s?.getAttribute("src") || null, this.lastSeekAtMs = 0, this.lastRate = null, this.unbindEngine(), this.setActive(!1);
784
784
  }
785
- setActive(a) {
786
- this.videoEl && (this.videoEl.style.opacity = a ? "1" : "0");
785
+ setActive(s) {
786
+ this.videoEl && (this.videoEl.style.opacity = s ? "1" : "0");
787
787
  }
788
- bindEngine(a, m) {
789
- this.unbindEngine(), this.boundEngine = a, this.boundActionStart = m, this.tickFromVideo();
788
+ bindEngine(s, l) {
789
+ this.unbindEngine(), this.boundEngine = s, this.boundActionStart = l, this.tickFromVideo();
790
790
  }
791
791
  unbindEngine() {
792
- const a = this.videoEl;
793
- if (this.vfcHandle != null && a?.cancelVideoFrameCallback)
792
+ const s = this.videoEl;
793
+ if (this.vfcHandle != null && s?.cancelVideoFrameCallback)
794
794
  try {
795
- a.cancelVideoFrameCallback(this.vfcHandle);
795
+ s.cancelVideoFrameCallback(this.vfcHandle);
796
796
  } catch {
797
797
  }
798
798
  this.rafHandle != null && cancelAnimationFrame(this.rafHandle), this.vfcHandle = null, this.rafHandle = null, this.boundEngine = null;
799
799
  }
800
800
  tickFromVideo = () => {
801
801
  if (!this.videoEl || !this.boundEngine || this.videoEl.paused) return;
802
- const a = this.boundActionStart + this.videoEl.currentTime;
803
- Math.abs(this.boundEngine.getTime() - a) > 0.03 && this.boundEngine.setTime(a, !0);
804
- const m = this.videoEl;
805
- m?.requestVideoFrameCallback ? this.vfcHandle = m.requestVideoFrameCallback(() => this.tickFromVideo()) : this.rafHandle = requestAnimationFrame(() => this.tickFromVideo());
802
+ const s = this.boundActionStart + this.videoEl.currentTime;
803
+ Math.abs(this.boundEngine.getTime() - s) > 0.03 && this.boundEngine.setTime(s, !0);
804
+ const l = this.videoEl;
805
+ l?.requestVideoFrameCallback ? this.vfcHandle = l.requestVideoFrameCallback(() => this.tickFromVideo()) : this.rafHandle = requestAnimationFrame(() => this.tickFromVideo());
806
806
  };
807
- setSource(a) {
808
- if (!this.videoEl || !a) return;
809
- const m = it.resolve(a);
810
- if (!((this.videoEl.currentSrc || this.videoEl.getAttribute("src") || "") === m || this.currentSrc === m)) {
811
- this.currentSrc = m, this.videoEl.preload = "auto", this.videoEl.src = m;
807
+ setSource(s) {
808
+ if (!this.videoEl || !s) return;
809
+ const l = re.resolve(s);
810
+ if (!((this.videoEl.currentSrc || this.videoEl.getAttribute("src") || "") === l || this.currentSrc === l)) {
811
+ this.currentSrc = l, this.videoEl.preload = "auto", this.videoEl.src = l;
812
812
  try {
813
813
  this.videoEl.load();
814
814
  } catch {
815
815
  }
816
816
  }
817
817
  }
818
- warm(a) {
819
- a && it.warm(a);
818
+ warm(s) {
819
+ s && re.warm(s);
820
820
  }
821
- setRate(a) {
822
- this.videoEl && this.lastRate !== a && (this.lastRate = a, this.videoEl.playbackRate = a);
821
+ setRate(s) {
822
+ this.videoEl && this.lastRate !== s && (this.lastRate = s, this.videoEl.playbackRate = s);
823
823
  }
824
824
  /**
825
825
  * Sync the video to a desired timeline time.
826
826
  * To avoid buffering/stutters, we only seek when drift is large or when paused/scrubbing.
827
827
  */
828
- seek(a, m) {
828
+ seek(s, l) {
829
829
  if (this.videoEl)
830
830
  try {
831
- const d = performance.now(), g = m?.force === !0, S = this.videoEl.currentTime;
832
- if (!g && !this.videoEl.paused && (Math.abs(S - a) < 0.12 || d - this.lastSeekAtMs < 150))
831
+ const u = performance.now(), f = l?.force === !0, I = this.videoEl.currentTime;
832
+ if (!f && !this.videoEl.paused && (Math.abs(I - s) < 0.12 || u - this.lastSeekAtMs < 150))
833
833
  return;
834
- const R = this.videoEl.duration;
835
- Number.isFinite(R) && R > 0 ? this.videoEl.currentTime = Math.min(a, Math.max(0, R - 0.05)) : this.videoEl.currentTime = Math.max(0, a), this.lastSeekAtMs = d;
834
+ const h = this.videoEl.duration;
835
+ Number.isFinite(h) && h > 0 ? this.videoEl.currentTime = Math.min(s, Math.max(0, h - 0.05)) : this.videoEl.currentTime = Math.max(0, s), this.lastSeekAtMs = u;
836
836
  } catch {
837
837
  }
838
838
  }
@@ -847,28 +847,28 @@ class mn {
847
847
  this.videoEl && this.videoEl.pause();
848
848
  }
849
849
  }
850
- const L = new mn(), nt = 160, rt = 5, vt = 20, pn = {
850
+ const G = new Bt(), te = 160, ne = 5, Ee = 20, lt = {
851
851
  effect0: {
852
852
  id: "effect0",
853
853
  name: "Play audio",
854
854
  source: {
855
- start: ({ action: u, engine: a, isPlaying: m, time: d }) => {
856
- if (m) {
857
- const { src: g, offset: S } = u.data;
858
- ie.warm(g), ie.start({ actionId: u.id, src: g, startTime: u.start, engine: a, time: d, offset: S });
855
+ start: ({ action: g, engine: s, isPlaying: l, time: u }) => {
856
+ if (l) {
857
+ const { src: f, offset: I } = g.data;
858
+ rA.warm(f), rA.start({ actionId: g.id, src: f, startTime: g.start, engine: s, time: u, offset: I });
859
859
  }
860
860
  },
861
- enter: ({ action: u, engine: a, isPlaying: m, time: d }) => {
862
- if (m) {
863
- const { src: g, offset: S } = u.data;
864
- ie.warm(g), ie.start({ actionId: u.id, src: g, startTime: u.start, engine: a, time: d, offset: S });
861
+ enter: ({ action: g, engine: s, isPlaying: l, time: u }) => {
862
+ if (l) {
863
+ const { src: f, offset: I } = g.data;
864
+ rA.warm(f), rA.start({ actionId: g.id, src: f, startTime: g.start, engine: s, time: u, offset: I });
865
865
  }
866
866
  },
867
- leave: ({ action: u }) => {
868
- ie.stop({ actionId: u.id });
867
+ leave: ({ action: g }) => {
868
+ rA.stop({ actionId: g.id });
869
869
  },
870
- stop: ({ action: u }) => {
871
- ie.stop({ actionId: u.id });
870
+ stop: ({ action: g }) => {
871
+ rA.stop({ actionId: g.id });
872
872
  }
873
873
  }
874
874
  },
@@ -876,23 +876,23 @@ const L = new mn(), nt = 160, rt = 5, vt = 20, pn = {
876
876
  id: "effect2",
877
877
  name: "Play video audio",
878
878
  source: {
879
- start: ({ action: u, engine: a, isPlaying: m, time: d }) => {
880
- if (m) {
881
- const { src: g, offset: S } = u.data;
882
- ie.warm(g), ie.start({ actionId: u.id, src: g, startTime: u.start, engine: a, time: d, offset: S });
879
+ start: ({ action: g, engine: s, isPlaying: l, time: u }) => {
880
+ if (l) {
881
+ const { src: f, offset: I } = g.data;
882
+ rA.warm(f), rA.start({ actionId: g.id, src: f, startTime: g.start, engine: s, time: u, offset: I });
883
883
  }
884
884
  },
885
- enter: ({ action: u, engine: a, isPlaying: m, time: d }) => {
886
- if (m) {
887
- const { src: g, offset: S } = u.data;
888
- ie.warm(g), ie.start({ actionId: u.id, src: g, startTime: u.start, engine: a, time: d, offset: S });
885
+ enter: ({ action: g, engine: s, isPlaying: l, time: u }) => {
886
+ if (l) {
887
+ const { src: f, offset: I } = g.data;
888
+ rA.warm(f), rA.start({ actionId: g.id, src: f, startTime: g.start, engine: s, time: u, offset: I });
889
889
  }
890
890
  },
891
- leave: ({ action: u }) => {
892
- ie.stop({ actionId: u.id });
891
+ leave: ({ action: g }) => {
892
+ rA.stop({ actionId: g.id });
893
893
  },
894
- stop: ({ action: u }) => {
895
- ie.stop({ actionId: u.id });
894
+ stop: ({ action: g }) => {
895
+ rA.stop({ actionId: g.id });
896
896
  }
897
897
  }
898
898
  },
@@ -900,34 +900,34 @@ const L = new mn(), nt = 160, rt = 5, vt = 20, pn = {
900
900
  id: "effect1",
901
901
  name: "Play video",
902
902
  source: {
903
- start: ({ action: u, engine: a, isPlaying: m, time: d }) => {
904
- const { src: g, previewSrc: S, offset: R } = u.data ?? {}, E = S || g;
905
- E && (L.warm(E), L.setSource(E)), L.setActive(!0), L.setRate(a.getPlayRate());
906
- const x = Number(R ?? 0);
907
- L.seek(Math.max(0, d - u.start + (Number.isFinite(x) ? x : 0)), { force: !0 }), m && L.play();
903
+ start: ({ action: g, engine: s, isPlaying: l, time: u }) => {
904
+ const { src: f, previewSrc: I, offset: h } = g.data ?? {}, v = I || f;
905
+ v && (G.warm(v), G.setSource(v)), G.setActive(!0), G.setRate(s.getPlayRate());
906
+ const m = Number(h ?? 0);
907
+ G.seek(Math.max(0, u - g.start + (Number.isFinite(m) ? m : 0)), { force: !0 }), l && G.play();
908
908
  },
909
- enter: ({ action: u, engine: a, isPlaying: m, time: d }) => {
910
- const { src: g, previewSrc: S, offset: R } = u.data ?? {}, E = S || g;
911
- E && (L.warm(E), L.setSource(E)), L.setActive(!0), L.setRate(a.getPlayRate());
912
- const x = Number(R ?? 0);
913
- L.seek(Math.max(0, d - u.start + (Number.isFinite(x) ? x : 0)), { force: !0 }), m && L.play();
909
+ enter: ({ action: g, engine: s, isPlaying: l, time: u }) => {
910
+ const { src: f, previewSrc: I, offset: h } = g.data ?? {}, v = I || f;
911
+ v && (G.warm(v), G.setSource(v)), G.setActive(!0), G.setRate(s.getPlayRate());
912
+ const m = Number(h ?? 0);
913
+ G.seek(Math.max(0, u - g.start + (Number.isFinite(m) ? m : 0)), { force: !0 }), l && G.play();
914
914
  },
915
- update: ({ action: u, engine: a, time: m, isPlaying: d }) => {
916
- const { src: g, previewSrc: S, offset: R } = u.data ?? {}, E = S || g;
917
- if (E && L.setSource(E), L.setActive(!0), L.setRate(a.getPlayRate()), !d) {
918
- const x = Number(R ?? 0);
919
- L.seek(Math.max(0, m - u.start + (Number.isFinite(x) ? x : 0)), { force: !0 });
915
+ update: ({ action: g, engine: s, time: l, isPlaying: u }) => {
916
+ const { src: f, previewSrc: I, offset: h } = g.data ?? {}, v = I || f;
917
+ if (v && G.setSource(v), G.setActive(!0), G.setRate(s.getPlayRate()), !u) {
918
+ const m = Number(h ?? 0);
919
+ G.seek(Math.max(0, l - g.start + (Number.isFinite(m) ? m : 0)), { force: !0 });
920
920
  }
921
921
  },
922
922
  leave: () => {
923
- L.pause(), L.unbindEngine(), L.setActive(!1);
923
+ G.pause(), G.unbindEngine(), G.setActive(!1);
924
924
  },
925
925
  stop: () => {
926
- L.pause(), L.unbindEngine(), L.setActive(!1);
926
+ G.pause(), G.unbindEngine(), G.setActive(!1);
927
927
  }
928
928
  }
929
929
  }
930
- }, gn = [
930
+ }, dt = [
931
931
  {
932
932
  id: "0",
933
933
  actions: [
@@ -966,301 +966,301 @@ const L = new mn(), nt = 160, rt = 5, vt = 20, pn = {
966
966
  id: "3",
967
967
  actions: []
968
968
  }
969
- ], { Option: hn } = $t, vn = [0.2, 0.5, 1, 1.5, 2], bn = ({
970
- timelineState: u,
971
- autoScrollWhenPlay: a,
972
- editorData: m,
973
- selectedActionId: d,
974
- onDeleteSelectedClip: g,
975
- onSplitSelectedClip: S,
976
- canUndo: R,
977
- canRedo: E,
978
- onUndo: x,
979
- onRedo: T
969
+ ], ft = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAIACAMAAADDpiTIAAAAAXNSR0IB2cksfwAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAtlQTFRFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAANlVkNAAAAPN0Uk5TABYvRE1VWkg1HAcYU4Kt2vj/4ruTYikBCZnX7q9lGwVQ9P7KbhUfiej6Pi6jy1cCHqLUD435wqogGrj1C+vlZgMEj85AEror2REndyrp2OG9MBne/JsIx4Cc42jIOrMiBtCGNiUU/w5Fdaj3iHs8HW/E7CP2vpXTRsGOtl79+xfGNPNK39xM8DKYKLQN8dKSas0MPaxPp22ULKUK8p9Bv2uD1XI5EyaRkELPcOctOO9zO90/ECQ37eDA29ZLw7whQ7Uz5MzJ0VJgsOahTre56ough4FsjHSxVGFJf1h2ioRxhX5fxWl6plmXR2eWrlGeZFudikazJAAAFoFJREFUeJztnXt8FdW1x2fi60NauARuBNsomEbAABJALiDRAEEN70cVJFIlvK7FUIu89BYQFDE+uTxslZAHArkXKpILBBIVCVQpj/KMBotepQIV/VihvQiW6OGCiBxgzzlrnzNrZs6s3/eP/rFnnb1X5Us4mfnN3qYBRGO63QBwFwggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHAggHG8IYH7HKSPu9P8ed7sZWbgtwI/O/tkHjZwd+My1joThpgANv0g0T6gvxZ924BNnuxGKawI0Mr+sfzRUQcJpBz5wqhu5uCRAE9IP+YaHkqr5e5GNKwI0N789TCxNMs3drL1IxwUB0sy/H9Eov76qhq0V4LwAbU3zQ82P3LDna5ZWgOG8AJfXOaX/oYREc7P9rYAzOCtAR3NvZB9M3dPqbXtbAWdxVIDG174b8WdbmmalfZ2AczgoQBdzZ1Sfb2O+aVMn4DzOCXC7uS3aKeJurrCjExCEYwI0Sd4S/SQpta9aG/0sIAinBOixOYJv/wri09bjcaGdOCRAL9O2L/G3rvnGrqmAUwKkNdpo42wZ5gobZxOOIwIMMN+ydb5Mc81Xtk4oGCcEGGi+bveUddtXUh8ngZA4IcDgcoZJux86iseENuCAAPeu4Zm3p7mIZ2JR8AvQ6whbqKO3uZBrajGwCzDULA1XEt88admgM0nQLXtGmeaS+vS0QLZZ83JU3QF2AcYsDn29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", Qt = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAIACAMAAADDpiTIAAAAAXNSR0IB2cksfwAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAvRQTFRFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAm1GVhQAAAPx0Uk5TABU9YHN+iZmlqp+UiHhtVjAJClcjZZ7H7v/+4LmOTg8Quu2dZCISXqDh/MpEA0XLXKL15pE8K+f4s1UGJJPr0W4Lb9Lq+4ARDf0yMa/whIbxrS8CAekT6MMuxOxmIcIFi8AfTx7GG4yQyRncrgip3yc0vg4MOPMWzfI/99PP+S3BsQQlmNoUY2i3fMy7sLYstdaVB/9rq9lqltfldhw5oR3U4zZd1UlNPqxT297YUTt/9kJ0JnDvkoNhZyripBdMnF+CbLgadyBZe7zIVFi/+vQpW32jdZu9Szpy5EZSGFBizmmKjUgzWnmFgTea3adxl9CySnpDh8WoKI9BOfj5SQAAFvBJREFUeJzt3Xucj2X+x/HvTQrrNBNitpqxminMTKPU5JBjK79QQg5tKNS2raiorMU4VQ7JdFrnmqTGb9f5lBwSaYWkKJYSbYdtQ0akMmp+FDl97vv6zHV/Prff43G9n39e33Fd08xrvt/7e9/X/c2LgdO8s/0NwNmFAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHAByHABx31gLwjiv8P9mr912FFP9T0fyCo/j/pOA4ve8q0NkIoHwhf/Gn+aWCTwS/IQlJPxWccyjEr7HEt6U870PBb4gp6gBSjvzu8gTmifM+SfI2CUwkIc37V7V8ieelIvkJeTsF5imESANIKyjm/UduugTPWyc3m7WrN9f4t9xsiUf+Qt6Um84owgDqKTzFHXlCWS49Z6E08rzN0nPWyNsX3WtBZAFcnV/+fY15k4t7r2rMy9Ls0LeCf/wnZOTFLdSYlxBRAM29d9QOc2t5P5ydBFKqeWu05s4o7s3UmvsUkQSQVP6g6lu3EklxMzTnJ7XdlL5Kc/6ML5P/rjn/MREE0HZTxkrtNRp4udpLnKZ1cfWDj8be99O114gggE7eEvU1YrHUFR1fiGCZ4+omf65yRHOaZt5z2kuoB9BtQUSHGRUPRnfo3N2bH81Ctfb8U3kF5d9OlxllIjvHmfmV9g/ruMiiPvL7SThP96yA7n/JXWu+Up3/VF7L3VEcC6bVnRPBKr9q5f1Nc3rVAJKbRvNW5ldtvKfV16h75T/U1zhFOy9bcXbNAO7/TPV9EqWjN1p5hT7TflRe4Qwl2ozSm1wxgPRmL+pN7qfiRt1jjoe9KN9sHHP7PL23HHoB9NN/C0Pptk7ztGBi50mKs/u6c6ZaAWoBZI0/S3tN/rhH7zggrmUU5zQImfkLlGbW+i0lx6tcJeG42xuoNHPaJW8pzWxUL32AzsRKATx8IOLj/5P9ub/SxFUPKk3M0MPrpzKvTgBt1kR+qHyynn9RmXb4kyrTMt23VuUkh04AI8dwviquUZLnFeKv9ZFNF7z9AecLK3e6nz8rW+tqrKPaGtdvvrwQAQ4rKNi5nHWt9MB+/qx8KgH0m238L+rrDa7ayWLxeelJ3jTjSf++s+Uv1TW7aYjpS5I7FNm+sWXhpy44POxRL8v0Val5GhvgNALwJhiOwroled+FWaDkgWzDv3/0jjDzk4rHBT9e4r/3JIaZv9ThYn2Dv2LEfIUNAhoB1Pwy6NGMqpn7Qi+R+yevT+AXjL419BqnrfhA4MPDx/ymY+g1yq7Z/m7Q4/sUDkIVApj2QNDJuOzRnWWWqbgn6Cn5qZWyZwPiJt4b8Ogz3hcyy0y5OuhIz3v2ZpllTp5TfMYhy7b5P9i67tdiC637tFbAueaxrcQWOurGgNffcc+2lPsxXvxlwMFAt0/FT0TLBzDvLv/HLsm4VHKpafX8fx5dx+8WXGn+MP87kR4YMUhwpdjW5Mf8H5zUXHKpo8QDaFc1x++hyQekdwcU9C3j+1h2e8GFBo/ze8Sb/JH0z/Dl89/2eyjzO+krHeIBLPI9/k5IqSu92JF3Xo/7XSbxHpQ7GdD6Lb/DmrjsgBc8W5d6nfweEn5lkw+g90t+Mw5emyG81s823Hi3zyNTm4gt0tNvD0hiEel3Gz975xq/A4ESKYtkl5IOoHQpnweeOl/8FqpfnP+cz3NAXLzUfpT5D/mc2ErtxzozWXjVZ/hdSxnaXXYl4QDim/j80BO+6SW70gnJd/g8P+c2FFqhYlF63MtVuz95UBOfeynqL5a9x0Y4gKkP0uNd3/0f2YVOlu5zuDeup8yHCCT9weciwG7WJQ8721f7fPMXBJ4rKjThAKp8T4/38ntlEPG9z0ZAoauCty2jxzv+TmR6H5e3o8f/UU90GdkA7lpFPz/lKe5qPGLzLvqFp9nzItN3WEEOX/yY0lHNMRXuI4fjJoq+mZIN4J9tyOGCLheJLnOGcvQrj9dEYlvq6jb0McYs33frMqp/340cn2BxvdGfbAD9J5PDui8AR62n3xzNzhSYu1h5cnjOWoG5A3nDyOEU+gnJdhHJybrTOxe7XyC5CGnXWvLQqMVEgbnX3UiNxj25VWDuYLPo15hh9DODHdEAilYkh+dFsJVyGblGanr4+0Sa/UieZ7glJfTMRrVbkMNlJNMTDeB5ct/i4EOSa/joX5J8oRbYFuCzEaDmDaFnNqvcgxoV3RYgGsBS8hS2/hHAUXXI62TX54Se+KLD1Kj+EcBR5wymRsttEVxCMoCh5G2siWVFj1r9JN9OjXYZHnriAeS9QGWC9oeIWXkZeRBTVfCeS8kAzj+XGlU+B3DcjuXUJxAuzA67g6JuSeoQ4JWpSSHn5Vm0nhqtIvhBCJIB0O+X5q8WXCLAD49To+3D3lr9XjNqNHtXyGmZ6l9PjS5Ok1tBMgBy36w3Vfd82a9mkq+MxcLeoTbzz9RoFnlgIG/zLGp0SarcCpIB9KWebrtVElwhSP5IanRpjZDT0te3F70Rclquc6mNAfGCF6EFA2ibnEOMLntNboVgr1KnZktuDzlrybLE4OSPQ87KNoZ6y5c5W24BwQDakX8VuzQ/3+QUY6kNx72Dbx8w29KYGJyr9gmhp2t0HTWaLrczUDCATkup0eXkqIaGvycGW40NOevl1EbWsuQJGg0j86nR5nIfUyEYQNYEanSK/inzY+ZS23P6ht2INIF6EdbcCXKqKZ9Sow/J7XcVDGBrQ2p0+ga5FYI1bUAMjgh7H9KH9YnBaq1DzspWitzTcpvcuRXBAD66lhq9tYrcCsGyvyUGa80LOWsr6uW+Z+mQs7KNIi+kVNgotoBgANvJvUp/lVvAgLx2Fhf2LER1ao/TIfIcvYpHqMFVVcXmFwygzg5qNLoAXibXD/u/qKlMDVZRuRuARAYgeC4YARggADYEoAEBsCEAGwjAAAGwIQANCIANAdhAAAYIgA0BaEAAbAjABgIwQABsCEADAmBDADYQgAECYEMAGhAAGwKwgQAMEAAbAtCAANgQgA0EYIAA2BCABgTAhgBsIAADBMCGADQgADYEYAMBGCAANgSgAQGwIQAbCMAAAbAhAA0IgA0B2EAABgiADQFoQABsCMAGAjBAAGwIQAMCYEMANhCAAQJgQwAaEAAbArCBAAwQABsC0IAA2BCADQRggADYEIAGBMCGAGwgAAMEwIYANCAANgRgAwEYIAA2BKABAbAhABsIwAABsCEADQiADQHYQAAGCIANAWhAAGwIwAYCMEAAbAhAAwJgQwA2EIABAmBDABoQABsCsIEADBAAGwLQgADYEIANBGCAANgQgAYEwIYAbCAAAwTAhgA0IAA2BGADARggADYEoAEBsCEAGwjAAAGwIQANCIANAdhAAAYIgA0BaEAAbAjABgIwQABsCEADAmBDADYQgAECYEMAGhAAGwKwgQAMEAAbAtCAANgQgA0EYIAA2BCABgTAhgBsIAADBMCGADQgADYEYAMBGCAANgSgAQGwIQAbCMAAAbAhAA0IgA0B2EAABgiADQFoQABsCMAGAjBAAGwIQAMCYEMANhCAAQJgQwAaEAAbArCBAAwQABsC0IAA2BCADQRggADYEIAGBMCGAGwgAAMEwIYANCAANgRgAwEYIAA2BKABAbAhABsIwAABsCEADQiADQHYQAAGCIANAWhAAGwIwAYCMEAAbAhAAwJgQwA2EIABAmBDABoQABsCsIEADBAAGwLQgADYEIANBGCAANgQgAYEwIYAbCAAAwTAhgA0IAA2BGADARggADYEoAEBsCEAGwjAAAGwIQANCIANAdhAAAYIgA0BaEAAbAjABgIwQABsCEADAmBDADYQgAECYEMAGhAAGwKwgQAMEAAbAtCAANgQgA0EYIAA2BCABgTAhgBsIAADBMCGADQgADYEYAMBGCAANgSgAQGwIQAbCMAAAbAhAA0IgA0B2EAABgiADQFoQABsCMAGAjBAAGwIQAMCYEMANhCAAQJgQwAaEAAbArCBAAwQABsC0IAA2BCADQRggADYEIAGBMCGAGwgAAMEwIYANCAANgRgAwEYIAA2BKABAbAhABsIwAABsCEADQiADQHYQAAGCIANAWhAAGwIwAYCMEAAbAhAAwJgQwA2EIABAmBDABoQABsCsIEADBAAGwLQgADYEIANBGCAANgQgAYEwIYAbCAAAwTAhgA0IAA2BGADARggADYEoAEBsCEAGwjAAAGwIQANCIANAdhAAAYIgA0BaEAAbAjABgIwQABsCEADAmBDADYQgAECYEMAGhAAGwKwgQAMEAAbAtCAANgQgA0EYIAA2BCABgTAhgBsIAADBMCGADQgADYEYAMBGCAANgSgAQGwIQAbCMAAAbAhAA0IgA0B2EAABgiADQFoQABsCMAGAjBAAGwIQAMCYEMANhCAAQJgQwAaEAAbArCBAAwQABsC0IAA2BCADQRggADYEIAGBMCGAGwgAAMEwIYANCAANgRgAwEYIAA2BKABAbAhABsIwAABsCEADQiADQHYQAAGCIANAWhAAGwIwAYCMEAAbAhAAwJgQwA2EIABAmBDABoQABsCsIEADBAAGwLQgADYEIANBGCAANgQgAYEwIYAbCAAAwTAhgA0IAA2BGADARggADYEoAEBsCEAGwjAAAGwIQANCIANAdhAAAYIgA0BaEAAbAjAhmAA2+tRo9EFULsFMRi3OeSs1fcSg4cGh5yVjwxgVVWx+QUD+OhaavTWKnIrBMv+lhisNS/krK3WEIM9S4eclW3UIWq0wkaxBQQD2NqQGp2+QW6FYE0bEIMjOoec9cP6xGC11iFnZSv1F2r0tlFiCwgGkDWBGp2yVW6FYHM3EYN9e4WcdUIWMTj2s5CzsuWPpEYful9sAcEAVpN/Fi9/ILdCsIa/JwZbjQ056+VfEYNle4SclW3DQmq0+SSxBQQDaPcGNborW26FYGO/JgZ79wk565bGxOBc6sBARaPrqNH0V8UWEAygbXIOMbrsNbkVgi2lfiu5DUPOWrEoMTj545Czso05SAxmzpZbQDCA2KgniMHh+wVXCLKLPARZWiPktKVLUaORHdlUpl5s4gVfViUDKB5HLbCKfBWTV6U7NfpEx5DT7qhDjfYvCDktU8221OiSVLkVJAPY1JQanfW24BIB9oyjRtuHPQR5rxk1ek2TkNMylXuQGr3/IbkVJAM4/1xqNHuX4BL+diynTvouzH4h5Lx1S75PjFauSJ12lPfD49So4Jlg0QDqbadGE7/uKbiGrxa1qdEHyL+gQvnkGmp0GnXSQdzKyyZSw/m75ZaQDCBWLY8aXTNXcg0/dZpTo2svCj3xZ1dRo68tCz0xgzeMGi3yueQSgnPFLttHjT4T9oIcxysbyMOyt38beubl9JW/9TNDz2xWdAg1WpJ8prUkGsCKDuRwFBdP/zWDGk0tuij0zM0eu4EazpM7He+rzRXk8AXvCq4hGkAOeeUilnKL5CKkN1eQTwCNXhaY+4Ii1GjGnrCXmcxK9yWHW5JnPCyJBhBrsI0czjosugph7RJyeEMlgblHjiGHO/5OYO5A0+mzTd2HSi4iG8AH5JnrWGZCddFlzpBGv/Z4M8i3BoXUdRF91ucd8lVHTvXvu5HjK1IkV5EN4M07qf0z6ucCambR50YX0K+hhTVoPDlcb4TuOc5F68nhuIZ/k1xFNoDYhT/S47ovAlffRI/nXC8yfYVz6PEFgudjzjRzCz1+38OiywgHsNHnR55YW24X2xluyaDHx60cLTJ/4m3P0Q+893eR+UntnybPAR155SG3qVoTDiCu6Ur6gfrLBsmudEL2QZ8rM5vKC63wus8VJe/5D4VWOMPejavoBy7eRr/K2hIOIDZpgM8DrXsrvWKOLOXzE0ndIHXGdGiu3xJd9wgtcZobyvpd8JvQUnYl6QD6/MdvA0jr/x0kvNbPEtb7PD/HKsltR/3ab1fBnc+qbBC/8gu/PWclUsKf2jqFdACxpr5XSRK2k2e2w/Hm+50Wy2gqt3NyyRN+q8QtUrjSMaWH74He4jThtcQDSKnuu18u8w3pP5etE+J9H8v7TnChFvRbsqMGvX+p4EJH1ZqT4/fQ5Ht2Ci8mHkBsb8BJny1VRM9ifTT4Mt/Hxk1/UXCleg38Xmhise6ZOwVXig046B917NLXJZc6Sj6AIb38fyux93ctFVsod9QC/9+K6K6ZI7663P+xrusulXsSqLHnXv8HqzcYKLbQMfIBxK76PGjDXJ9vKsgsk9Uh6ILswMMBP0cLcbcGrfbUGKELnm+OD0op45auMsucRCGAWMmygSv2/jIx9BIF6buD781445LQa5xqf/AZ+MGje4T/UZb8dHzgZtNlCpdUNAJo18JwtrJv+x3+B1UML9z0jOH7Ft0z8Yvn+wU/XtCjRqidOlemTR4e/BXlfqQvtoaiEUDsqnLURspT9Ci47snyFq+cK4de1Xm68Zsefj91l1A4jVoZfj9H3qTf0L7iAOpmUoOtu3st9Z4xfdXCDfIvAEoB+NxNcbqMbjsavNGfP+sj7w7tx7rP6JVd1G2CYWVdcTfny5JfHJBRiA9FGHbtis+2sbb4hL7HhaQTQNvnpN8bF8o06kbx8PyuCkbj4VXTNabVCSD2aBy5nTEa31CfFCHhvIB36NoGP65wABBTCyCWc2EnpZmN+uRo7dlP+5PoeazCGJIqsbmJoBVAbMwItamDLXj+abW5694ss8Og0GoV09qFrvdbenBZFPcDnKH69p2Ks/fuSd4npG3czT9pTa34Z/rtsBy9yf20Gqd7366XTn1iiLLMrjeqza35PP1FL59dLXrmDBS+XH6GRs0i+8iT4+rvV9x9qvpC3enGSO4LPWHqlLA3A5vVnafyftzf01v8dllJ0D1Su+cOveeuM3kfdVZ5q3yaNqUXR/TxED/7eDX1KUVilA/Vh6wqKnkjW6DGAwKuQ4vK/avkZpNAXsJ5b+ouoDp7LMIfVvwVkjtAguUsXh7NQvpR679Z714mV32NWGxhwnjxvRIBuozdSt4zLGzO5tu1l4jibE1uvuzNLIQ/lpXbAcpz34Xq54QSDqTpH9NEcrqu0braxuvDYVycF8FP6gx1LvK5CUZG6t4GUZx2jOh8bdbIhmoHgyUu2fqJ1tyBktamq/34MmaNjeY5LbIT9uX311d5FqhRZNtOjXlZ+ryz7wuNeTNezztPY15ChFdsksuWE//g6Lf+fZP83p/CiD/cS+6Dm4+p91K36N7QRHrJLq2gmCd4hWjI+IoRfQppoCWjqgneJZzoecn6pzNPiPqabdLcm0dIbNhO3bgxvoPyR3SwpT1y3Qf9JF7g3v/vN+0jPp45GxftOw3dmdnd/kPEM7pVmtRl/lm6MO+rd4tpnb6cbH+k27jgrh/KKG36CHKWdm3EYu06xqdPHJLvFeIb8K589d0NLyWW19vwEda9uz/5Q82mNdcX4lpBQUGxgTVKVRqg+FkTgc5aAPD/AwJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJwHAJw3P8Bbo+ylz0kh3gAAAAASUVORK5CYII=", Et = "data:image/png;base64,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", Ct = "data:image/png;base64,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AIFwAhQA4aaMhBFAAAEEEKguQAFQ3ZAWEEAAAQQQCCdAARBuykgYAQQQQACB6gIUANUNaQEBBBBAAIFwAhQA4aaMhBFAAAEEEKguQAFQ3ZAWEEAAAQQQCCdAARBuykgYAQQQQACB6gIUANUNaQEBBBBAAIFwAhQA4aaMhBFAAAEEEKguQAFQ3ZAWEEAAAQQQCCdAARBuykgYAQQQQACB6gIUANUNaQEBBBBAAIFwAhQA4aaMhBFAAAEEEKguQAFQ3ZAWEEAAAQQQCCdAARBuykgYAQQQQACB6gIUANUNaQEBBBBAAIFwAhQA4aaMhBFAAAEEEKguQAFQ3ZAWEEAAAQQQCCdAARBuykgYAQQQQACB6gIUANUNaQEBBBBAAIFwAhQA4aaMhBFAAAEEEKguQAFQ3ZAWEEAAAQQQCCdAARBuykgYAQQQQACB6gIUANUNaQEBBBBAAIFwAhQA4aaMhBFAAAEEEKguQAFQ3ZAWEEAAAQQQCCdAARBuykgYAQQQQACB6gIUANUNaQEBBBBAAIFwAhQA4aaMhBFAAAEEEKguQAFQ3ZAWEEAAAQQQCCdAARBuykgYAQQQQACB6gIUANUNaQEBBBBAAIFwAhQA4aaMhBFAAAEEEKguQAFQ3ZAWEEAAAQQQCCdAARBuykgYAQQQQACB6gIUANUNaQEBBBBAAIFwAhQA4aaMhBFAAAEEEKgu8P8Ho19MJOV4IQAAAABJRU5ErkJggg==", wt = "data:image/png;base64,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", It = "data:image/png;base64,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UEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIAAFBIAABAIQEAAIUEAAAUEgAAUEgAAEAhAQAAhQQAABQSAABQSAAAQCEBAACFBAAAFBIA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", { Option: Dt } = Ye, ht = [0.2, 0.5, 1, 1.5, 2], mt = ({
970
+ timelineState: g,
971
+ autoScrollWhenPlay: s,
972
+ editorData: l,
973
+ selectedActionId: u,
974
+ onDeleteSelectedClip: f,
975
+ onSplitSelectedClip: I,
976
+ canUndo: h,
977
+ canRedo: v,
978
+ onUndo: m,
979
+ onRedo: b
980
980
  }) => {
981
- const [k, A] = J(!1), [q, z] = J(0), [de, X] = J(!1), U = V(0), G = V(0), O = V(0), fe = V(0), be = V(0), oe = V(0), me = !!d, Ne = (() => {
982
- if (!d) return null;
983
- const y = Array.isArray(m) ? m : [];
984
- for (const j of y) {
985
- const D = j?.actions;
986
- if (Array.isArray(D))
987
- for (const C of D) {
988
- if (String(C?.id) !== d) continue;
989
- const F = Number(C?.start), M = Number(C?.end);
990
- return !Number.isFinite(F) || !Number.isFinite(M) ? null : { start: F, end: M };
981
+ const [y, p] = z(!1), [q, W] = z(0), [uA, K] = z(!1), L = j(0), Z = j(0), S = j(0), BA = j(0), CA = j(0), iA = j(0), lA = !!u, FA = (() => {
982
+ if (!u) return null;
983
+ const w = Array.isArray(l) ? l : [];
984
+ for (const x of w) {
985
+ const R = x?.actions;
986
+ if (Array.isArray(R))
987
+ for (const P of R) {
988
+ if (String(P?.id) !== u) continue;
989
+ const H = Number(P?.start), U = Number(P?.end);
990
+ return !Number.isFinite(H) || !Number.isFinite(U) ? null : { start: H, end: U };
991
991
  }
992
992
  }
993
993
  return null;
994
- })(), ke = !!(Ne && q > Ne.start && q < Ne.end), Ye = (y) => {
995
- const j = Array.isArray(m) ? m : [];
996
- for (const D of j) {
997
- const C = D?.actions;
998
- if (Array.isArray(C))
999
- for (const F of C) {
1000
- if (F?.effectId !== "effect1") continue;
1001
- const M = Number(F?.start), H = Number(F?.end);
1002
- if (!(!Number.isFinite(M) || !Number.isFinite(H)) && y >= M && y < H)
994
+ })(), yA = !!(FA && q > FA.start && q < FA.end), JA = (w) => {
995
+ const x = Array.isArray(l) ? l : [];
996
+ for (const R of x) {
997
+ const P = R?.actions;
998
+ if (Array.isArray(P))
999
+ for (const H of P) {
1000
+ if (H?.effectId !== "effect1") continue;
1001
+ const U = Number(H?.start), k = Number(H?.end);
1002
+ if (!(!Number.isFinite(U) || !Number.isFinite(k)) && w >= U && w < k)
1003
1003
  return !0;
1004
1004
  }
1005
1005
  }
1006
1006
  return !1;
1007
- }, qe = (y) => {
1008
- Ye(y) || (L.pause(), L.unbindEngine(), L.setActive(!1));
1007
+ }, qA = (w) => {
1008
+ JA(w) || (G.pause(), G.unbindEngine(), G.setActive(!1));
1009
1009
  };
1010
- bt(() => {
1011
- if (!u.current) return;
1012
- const y = u.current, j = () => A(!0), D = () => A(!1), C = ({ time: M }) => {
1013
- z(M), qe(M);
1014
- }, F = ({ time: M }) => {
1015
- const H = performance.now();
1016
- if (!(H - U.current < 33) && (U.current = H, z(M), qe(M), a.current)) {
1017
- const pe = M * (nt / rt) + vt - 500, ce = u.current;
1018
- ce && ce.setScrollLeft(pe);
1010
+ Ce(() => {
1011
+ if (!g.current) return;
1012
+ const w = g.current, x = () => p(!0), R = () => p(!1), P = ({ time: U }) => {
1013
+ W(U), qA(U);
1014
+ }, H = ({ time: U }) => {
1015
+ const k = performance.now();
1016
+ if (!(k - L.current < 33) && (L.current = k, W(U), qA(U), s.current)) {
1017
+ const dA = U * (te / ne) + Ee - 500, aA = g.current;
1018
+ aA && aA.setScrollLeft(dA);
1019
1019
  }
1020
1020
  };
1021
- return y.listener.on("play", j), y.listener.on("paused", D), y.listener.on("afterSetTime", C), y.listener.on("setTimeByTick", F), () => {
1022
- y.listener.off("play", j), y.listener.off("paused", D), y.listener.off("afterSetTime", C), y.listener.off("setTimeByTick", F);
1021
+ return w.listener.on("play", x), w.listener.on("paused", R), w.listener.on("afterSetTime", P), w.listener.on("setTimeByTick", H), () => {
1022
+ w.listener.off("play", x), w.listener.off("paused", R), w.listener.off("afterSetTime", P), w.listener.off("setTimeByTick", H);
1023
1023
  };
1024
- }, [m]);
1025
- const Oe = () => {
1026
- u.current && (u.current.isPlaying ? u.current.pause() : (ie.unlock(), u.current.play({ autoEnd: !0 })));
1027
- }, se = (y) => {
1028
- u.current && u.current.setPlayRate(y);
1029
- }, ae = (y) => {
1030
- const j = (parseInt(y % 1 * 100 + "") + "").padStart(2, "0"), D = (parseInt(y / 60 + "") + "").padStart(2, "0"), C = (parseInt(y % 60 + "") + "").padStart(2, "0");
1031
- return /* @__PURE__ */ v.jsx(v.Fragment, { children: `${D}:${C}.${j.replace("0.", "")}` });
1032
- }, te = () => {
1033
- const y = [], j = /* @__PURE__ */ new Set(), D = Array.isArray(m) ? m : [];
1034
- for (const C of D) {
1035
- const F = C?.actions;
1036
- if (Array.isArray(F))
1037
- for (const M of F) {
1038
- const H = M?.data?.src;
1039
- if (!H) continue;
1040
- const Se = String(H);
1041
- j.has(Se) || (j.add(Se), y.push(Se));
1024
+ }, [l]);
1025
+ const SA = () => {
1026
+ g.current && (g.current.isPlaying ? g.current.pause() : (rA.unlock(), g.current.play({ autoEnd: !0 })));
1027
+ }, oA = (w) => {
1028
+ g.current && g.current.setPlayRate(w);
1029
+ }, sA = (w) => {
1030
+ const x = (parseInt(w % 1 * 100 + "") + "").padStart(2, "0"), R = (parseInt(w / 60 + "") + "").padStart(2, "0"), P = (parseInt(w % 60 + "") + "").padStart(2, "0");
1031
+ return /* @__PURE__ */ E.jsx(E.Fragment, { children: `${R}:${P}.${x.replace("0.", "")}` });
1032
+ }, eA = () => {
1033
+ const w = [], x = /* @__PURE__ */ new Set(), R = Array.isArray(l) ? l : [];
1034
+ for (const P of R) {
1035
+ const H = P?.actions;
1036
+ if (Array.isArray(H))
1037
+ for (const U of H) {
1038
+ const k = U?.data?.src;
1039
+ if (!k) continue;
1040
+ const IA = String(k);
1041
+ x.has(IA) || (x.add(IA), w.push(IA));
1042
1042
  }
1043
1043
  }
1044
- return y;
1045
- }, Me = (y, j) => {
1046
- const D = URL.createObjectURL(y), C = document.createElement("a");
1047
- C.href = D, C.download = j, document.body.appendChild(C), C.click(), C.remove(), setTimeout(() => URL.revokeObjectURL(D), 3e3);
1048
- }, ye = async () => {
1049
- if (!de) {
1050
- X(!0);
1044
+ return w;
1045
+ }, UA = (w, x) => {
1046
+ const R = URL.createObjectURL(w), P = document.createElement("a");
1047
+ P.href = R, P.download = x, document.body.appendChild(P), P.click(), P.remove(), setTimeout(() => URL.revokeObjectURL(R), 3e3);
1048
+ }, wA = async () => {
1049
+ if (!uA) {
1050
+ K(!0);
1051
1051
  try {
1052
- const y = te(), j = new FormData();
1053
- j.append("timeline", JSON.stringify({ editorData: m }));
1054
- for (const F of y) {
1055
- const M = await fetch(F);
1056
- if (!M.ok) throw new Error(`Failed to fetch asset: ${F} (${M.status})`);
1057
- const H = await M.blob();
1058
- j.append("assets", H, encodeURIComponent(F));
1052
+ const w = eA(), x = new FormData();
1053
+ x.append("timeline", JSON.stringify({ editorData: l }));
1054
+ for (const H of w) {
1055
+ const U = await fetch(H);
1056
+ if (!U.ok) throw new Error(`Failed to fetch asset: ${H} (${U.status})`);
1057
+ const k = await U.blob();
1058
+ x.append("assets", k, encodeURIComponent(H));
1059
1059
  }
1060
- const D = await fetch("/export", {
1060
+ const R = await fetch("/export", {
1061
1061
  method: "POST",
1062
- body: j
1062
+ body: x
1063
1063
  });
1064
- if (!D.ok) {
1065
- const F = await D.text().catch(() => "");
1066
- throw new Error(F || `Export failed (${D.status})`);
1064
+ if (!R.ok) {
1065
+ const H = await R.text().catch(() => "");
1066
+ throw new Error(H || `Export failed (${R.status})`);
1067
1067
  }
1068
- const C = await D.blob();
1069
- Me(C, "export.mp4");
1068
+ const P = await R.blob();
1069
+ UA(P, "export.mp4");
1070
1070
  } finally {
1071
- X(!1);
1071
+ K(!1);
1072
1072
  }
1073
1073
  }
1074
1074
  };
1075
- return /* @__PURE__ */ v.jsxs("div", { className: "timeline-player", children: [
1076
- /* @__PURE__ */ v.jsx(
1075
+ return /* @__PURE__ */ E.jsxs("div", { className: "timeline-player", children: [
1076
+ /* @__PURE__ */ E.jsx(
1077
1077
  "div",
1078
1078
  {
1079
1079
  className: "play-control",
1080
1080
  role: "button",
1081
1081
  tabIndex: 0,
1082
- "aria-label": k ? "Pause" : "Play",
1082
+ "aria-label": y ? "Pause" : "Play",
1083
1083
  onClick: () => {
1084
- Date.now() - G.current < 450 || Oe();
1084
+ Date.now() - Z.current < 450 || SA();
1085
1085
  },
1086
- onPointerUp: (y) => {
1087
- y.pointerType !== "mouse" && (G.current = Date.now(), Oe());
1086
+ onPointerUp: (w) => {
1087
+ w.pointerType !== "mouse" && (Z.current = Date.now(), SA());
1088
1088
  },
1089
- children: /* @__PURE__ */ v.jsx(
1089
+ children: /* @__PURE__ */ E.jsx(
1090
1090
  "img",
1091
1091
  {
1092
- src: k ? "/pause-button.png" : "/play-button.png",
1092
+ src: y ? Qt : ft,
1093
1093
  alt: "",
1094
1094
  draggable: !1
1095
1095
  }
1096
1096
  )
1097
1097
  }
1098
1098
  ),
1099
- /* @__PURE__ */ v.jsx("div", { className: "time", children: ae(q) }),
1100
- /* @__PURE__ */ v.jsxs("div", { className: "history-tools", children: [
1101
- /* @__PURE__ */ v.jsx(
1099
+ /* @__PURE__ */ E.jsx("div", { className: "time", children: sA(q) }),
1100
+ /* @__PURE__ */ E.jsxs("div", { className: "history-tools", children: [
1101
+ /* @__PURE__ */ E.jsx(
1102
1102
  "button",
1103
1103
  {
1104
1104
  type: "button",
1105
1105
  className: "history-tool",
1106
- disabled: !R,
1106
+ disabled: !h,
1107
1107
  "aria-label": "Undo",
1108
1108
  onClick: () => {
1109
- Date.now() - be.current < 450 || R && x();
1109
+ Date.now() - CA.current < 450 || h && m();
1110
1110
  },
1111
- onPointerUp: (y) => {
1112
- y.pointerType !== "mouse" && (be.current = Date.now(), R && x());
1111
+ onPointerUp: (w) => {
1112
+ w.pointerType !== "mouse" && (CA.current = Date.now(), h && m());
1113
1113
  },
1114
- children: /* @__PURE__ */ v.jsx("img", { src: "/undo.png", alt: "", draggable: !1 })
1114
+ children: /* @__PURE__ */ E.jsx("img", { src: Et, alt: "", draggable: !1 })
1115
1115
  }
1116
1116
  ),
1117
- /* @__PURE__ */ v.jsx(
1117
+ /* @__PURE__ */ E.jsx(
1118
1118
  "button",
1119
1119
  {
1120
1120
  type: "button",
1121
1121
  className: "history-tool",
1122
- disabled: !E,
1122
+ disabled: !v,
1123
1123
  "aria-label": "Redo",
1124
1124
  onClick: () => {
1125
- Date.now() - oe.current < 450 || E && T();
1125
+ Date.now() - iA.current < 450 || v && b();
1126
1126
  },
1127
- onPointerUp: (y) => {
1128
- y.pointerType !== "mouse" && (oe.current = Date.now(), E && T());
1127
+ onPointerUp: (w) => {
1128
+ w.pointerType !== "mouse" && (iA.current = Date.now(), v && b());
1129
1129
  },
1130
- children: /* @__PURE__ */ v.jsx("img", { src: "/redo.png", alt: "", draggable: !1 })
1130
+ children: /* @__PURE__ */ E.jsx("img", { src: Ct, alt: "", draggable: !1 })
1131
1131
  }
1132
1132
  )
1133
1133
  ] }),
1134
- /* @__PURE__ */ v.jsx("div", { className: "rate-control", children: /* @__PURE__ */ v.jsx($t, { size: "small", defaultValue: 1, style: { width: 120 }, onChange: se, children: vn.map((y) => /* @__PURE__ */ v.jsx(hn, { value: y, children: `${y.toFixed(1)}x` }, y)) }) }),
1135
- /* @__PURE__ */ v.jsxs("div", { className: "clip-tools", children: [
1136
- /* @__PURE__ */ v.jsx(
1134
+ /* @__PURE__ */ E.jsx("div", { className: "rate-control", children: /* @__PURE__ */ E.jsx(Ye, { size: "small", defaultValue: 1, style: { width: 120 }, onChange: oA, children: ht.map((w) => /* @__PURE__ */ E.jsx(Dt, { value: w, children: `${w.toFixed(1)}x` }, w)) }) }),
1135
+ /* @__PURE__ */ E.jsxs("div", { className: "clip-tools", children: [
1136
+ /* @__PURE__ */ E.jsx(
1137
1137
  "button",
1138
1138
  {
1139
1139
  type: "button",
1140
1140
  className: "clip-tool clip-tool-delete",
1141
- disabled: !me,
1141
+ disabled: !lA,
1142
1142
  "aria-label": "Delete selected clip",
1143
1143
  onClick: () => {
1144
- Date.now() - O.current < 450 || me && g();
1144
+ Date.now() - S.current < 450 || lA && f();
1145
1145
  },
1146
- onPointerUp: (y) => {
1147
- y.pointerType !== "mouse" && (O.current = Date.now(), me && g());
1146
+ onPointerUp: (w) => {
1147
+ w.pointerType !== "mouse" && (S.current = Date.now(), lA && f());
1148
1148
  },
1149
- children: /* @__PURE__ */ v.jsx("img", { src: "/bin.png", alt: "", draggable: !1 })
1149
+ children: /* @__PURE__ */ E.jsx("img", { src: wt, alt: "", draggable: !1 })
1150
1150
  }
1151
1151
  ),
1152
- /* @__PURE__ */ v.jsx(
1152
+ /* @__PURE__ */ E.jsx(
1153
1153
  "button",
1154
1154
  {
1155
1155
  type: "button",
1156
1156
  className: "clip-tool clip-tool-split",
1157
- disabled: !ke,
1157
+ disabled: !yA,
1158
1158
  "aria-label": "Split selected clip at cursor",
1159
1159
  onClick: () => {
1160
- Date.now() - fe.current < 450 || ke && S();
1160
+ Date.now() - BA.current < 450 || yA && I();
1161
1161
  },
1162
- onPointerUp: (y) => {
1163
- y.pointerType !== "mouse" && (fe.current = Date.now(), ke && S());
1162
+ onPointerUp: (w) => {
1163
+ w.pointerType !== "mouse" && (BA.current = Date.now(), yA && I());
1164
1164
  },
1165
- children: /* @__PURE__ */ v.jsx("img", { src: "/split.png", alt: "", draggable: !1 })
1165
+ children: /* @__PURE__ */ E.jsx("img", { src: It, alt: "", draggable: !1 })
1166
1166
  }
1167
1167
  )
1168
1168
  ] }),
1169
- /* @__PURE__ */ v.jsx("div", { className: "export-control", children: /* @__PURE__ */ v.jsx(zt, { size: "small", type: "primary", loading: de, onClick: ye, children: "Export" }) })
1169
+ /* @__PURE__ */ E.jsx("div", { className: "export-control", children: /* @__PURE__ */ E.jsx(We, { size: "small", type: "primary", loading: uA, onClick: wA, children: "Export" }) })
1170
1170
  ] });
1171
1171
  };
1172
- function yn() {
1173
- const u = () => typeof window > "u" ? !1 : typeof navigator < "u" && // maxTouchPoints is the most reliable cross-browser hint.
1174
- (navigator.maxTouchPoints ?? 0) > 0, [a, m] = J(u);
1175
- return bt(() => {
1172
+ function vt() {
1173
+ const g = () => typeof window > "u" ? !1 : typeof navigator < "u" && // maxTouchPoints is the most reliable cross-browser hint.
1174
+ (navigator.maxTouchPoints ?? 0) > 0, [s, l] = z(g);
1175
+ return Ce(() => {
1176
1176
  if (typeof window > "u" || typeof window.matchMedia != "function") return;
1177
- const d = window.matchMedia("(pointer: coarse)"), g = () => m(!!d.matches || u());
1178
- return g(), typeof d.addEventListener == "function" ? (d.addEventListener("change", g), () => d.removeEventListener("change", g)) : (d.addListener(g), () => d.removeListener(g));
1179
- }, []), a;
1177
+ const u = window.matchMedia("(pointer: coarse)"), f = () => l(!!u.matches || g());
1178
+ return f(), typeof u.addEventListener == "function" ? (u.addEventListener("change", f), () => u.removeEventListener("change", f)) : (u.addListener(f), () => u.removeListener(f));
1179
+ }, []), s;
1180
1180
  }
1181
- const Sn = structuredClone(gn), ht = 5, Bt = ({ item: u, hint: a, isDragging: m }) => /* @__PURE__ */ v.jsxs("div", { className: `footage-card${m ? " is-dragging" : ""}`, children: [
1182
- /* @__PURE__ */ v.jsx("div", { className: "footage-name", children: u.name }),
1183
- u.kind === "video" ? /* @__PURE__ */ v.jsx(
1181
+ const bt = structuredClone(dt), Qe = 5, Te = ({ item: g, hint: s, isDragging: l }) => /* @__PURE__ */ E.jsxs("div", { className: `footage-card${l ? " is-dragging" : ""}`, children: [
1182
+ /* @__PURE__ */ E.jsx("div", { className: "footage-name", children: g.name }),
1183
+ g.kind === "video" ? /* @__PURE__ */ E.jsx(
1184
1184
  "video",
1185
1185
  {
1186
1186
  className: "footage-preview",
1187
- src: u.src,
1187
+ src: g.src,
1188
1188
  muted: !0,
1189
1189
  preload: "metadata",
1190
1190
  draggable: !1,
1191
- onDragStart: (d) => d.preventDefault(),
1191
+ onDragStart: (u) => u.preventDefault(),
1192
1192
  playsInline: !0
1193
1193
  }
1194
- ) : /* @__PURE__ */ v.jsx(
1194
+ ) : /* @__PURE__ */ E.jsx(
1195
1195
  "audio",
1196
1196
  {
1197
1197
  className: "footage-audio",
1198
- src: u.src,
1198
+ src: g.src,
1199
1199
  controls: !0,
1200
1200
  preload: "metadata",
1201
1201
  draggable: !1,
1202
- onDragStart: (d) => d.preventDefault()
1202
+ onDragStart: (u) => u.preventDefault()
1203
1203
  }
1204
1204
  ),
1205
- /* @__PURE__ */ v.jsx("div", { className: "footage-kind", children: a })
1206
- ] }), wn = ({ item: u, hint: a }) => {
1207
- const { attributes: m, listeners: d, setNodeRef: g, transform: S, isDragging: R } = tn({
1208
- id: `footage-${u.id}`,
1209
- data: { item: u }
1210
- }), E = S ? {
1211
- transform: `translate3d(${S.x}px, ${S.y}px, 0)`
1205
+ /* @__PURE__ */ E.jsx("div", { className: "footage-kind", children: s })
1206
+ ] }), pt = ({ item: g, hint: s }) => {
1207
+ const { attributes: l, listeners: u, setNodeRef: f, transform: I, isDragging: h } = et({
1208
+ id: `footage-${g.id}`,
1209
+ data: { item: g }
1210
+ }), v = I ? {
1211
+ transform: `translate3d(${I.x}px, ${I.y}px, 0)`
1212
1212
  } : void 0;
1213
- return /* @__PURE__ */ v.jsx("div", { ref: g, style: E, ...d, ...m, children: /* @__PURE__ */ v.jsx(Bt, { item: u, hint: a, isDragging: R }) });
1214
- }, Rn = (u) => String(u ?? "").toLowerCase().match(/\.(mp3|wav|m4a|aac|ogg)(\?|#|$)/) ? "audio" : "video", xn = (u, a) => {
1213
+ return /* @__PURE__ */ E.jsx("div", { ref: f, style: v, ...u, ...l, children: /* @__PURE__ */ E.jsx(Te, { item: g, hint: s, isDragging: h }) });
1214
+ }, Ft = (g) => String(g ?? "").toLowerCase().match(/\.(mp3|wav|m4a|aac|ogg)(\?|#|$)/) ? "audio" : "video", yt = (g, s) => {
1215
1215
  try {
1216
- const m = String(u ?? "").split("/").pop() || "";
1217
- return decodeURIComponent(m.split("?")[0].split("#")[0]) || `Footage ${a + 1}`;
1216
+ const l = String(g ?? "").split("/").pop() || "";
1217
+ return decodeURIComponent(l.split("?")[0].split("#")[0]) || `Footage ${s + 1}`;
1218
1218
  } catch {
1219
- return `Footage ${a + 1}`;
1219
+ return `Footage ${s + 1}`;
1220
1220
  }
1221
- }, Pn = ({ footageUrls: u }) => {
1222
- const [a, m] = J(Sn), [d, g] = J(null), [S, R] = J([]), [E, x] = J([]), T = V(a), k = yn(), A = V(null), q = V(null), z = V(null), de = V(!0), X = _t(() => {
1223
- const e = Array.isArray(u) ? u.filter(Boolean) : [];
1224
- return e.length ? e.map((n, r) => ({
1225
- id: `url-${r}`,
1226
- kind: Rn(n),
1227
- name: xn(n, r),
1228
- src: n,
1221
+ }, xt = ({ footageUrls: g }) => {
1222
+ const [s, l] = z(bt), [u, f] = z(null), [I, h] = z([]), [v, m] = z([]), b = j(s), y = vt(), p = j(null), q = j(null), W = j(null), uA = j(!0), K = Oe(() => {
1223
+ const A = Array.isArray(g) ? g.filter(Boolean) : [];
1224
+ return A.length ? A.map((t, n) => ({
1225
+ id: `url-${n}`,
1226
+ kind: Ft(t),
1227
+ name: yt(t, n),
1228
+ src: t,
1229
1229
  defaultDuration: 10
1230
1230
  })) : [];
1231
- }, [u]), [U, G] = J(null), [O, fe] = J(null), [be, oe] = J(null), [me, ot] = J(0), [Ne, ke] = J(0), [Ye, qe] = J(0), [Oe, se] = J(0), [ae, te] = J(!1), [Me, ye] = J(null), y = V(null), j = V(null), D = V(null), C = V(null), F = k ? 48 : 32, M = [0, 1], H = [2, 3], Se = ["V1", "V2", "A1", "A2"], pe = (e, n) => {
1232
- if (n.length === 0) return null;
1233
- if (e == null) return n[0];
1234
- let r = n[0], s = Math.abs(e - r);
1235
- for (const i of n) {
1236
- const o = Math.abs(e - i);
1237
- o < s && (r = i, s = o);
1238
- }
1239
- return r;
1240
- }, ce = (e, n) => e ? e.kind === "video" ? pe(n, M) : pe(n, H) : null, Pe = (e) => e === M[1] ? H[1] : H[0];
1241
- bt(() => {
1242
- it.warmFromEditorData(a);
1243
- }, [a]), bt(() => {
1244
- T.current = a;
1245
- }, [a]), Wt(() => {
1246
- const e = z.current;
1247
- if (!e) return;
1248
- const n = () => {
1249
- const s = e.getBoundingClientRect(), i = e.querySelector(".timeline-editor-edit-area");
1250
- if (!i) return;
1251
- const o = i.getBoundingClientRect();
1252
- qe(o.top - s.top), se(o.left - s.left);
1253
- }, r = requestAnimationFrame(n);
1254
- return window.addEventListener("resize", n), () => {
1255
- cancelAnimationFrame(r), window.removeEventListener("resize", n);
1231
+ }, [g]), [L, Z] = z(null), [S, BA] = z(null), [CA, iA] = z(null), [lA, ie] = z(0), [FA, yA] = z(0), [JA, qA] = z(0), [SA, oA] = z(0), [sA, eA] = z(!1), [UA, wA] = z(null), w = j(null), x = j(null), R = j(null), P = j(null), H = y ? 48 : 32, U = [0, 1], k = [2, 3], IA = ["V1", "V2", "A1", "A2"], dA = (A, t) => {
1232
+ if (t.length === 0) return null;
1233
+ if (A == null) return t[0];
1234
+ let n = t[0], o = Math.abs(A - n);
1235
+ for (const r of t) {
1236
+ const i = Math.abs(A - r);
1237
+ i < o && (n = r, o = i);
1238
+ }
1239
+ return n;
1240
+ }, aA = (A, t) => A ? A.kind === "video" ? dA(t, U) : dA(t, k) : null, NA = (A) => A === U[1] ? k[1] : k[0];
1241
+ Ce(() => {
1242
+ re.warmFromEditorData(s);
1243
+ }, [s]), Ce(() => {
1244
+ b.current = s;
1245
+ }, [s]), Xe(() => {
1246
+ const A = W.current;
1247
+ if (!A) return;
1248
+ const t = () => {
1249
+ const o = A.getBoundingClientRect(), r = A.querySelector(".timeline-editor-edit-area");
1250
+ if (!r) return;
1251
+ const i = r.getBoundingClientRect();
1252
+ qA(i.top - o.top), oA(i.left - o.left);
1253
+ }, n = requestAnimationFrame(t);
1254
+ return window.addEventListener("resize", t), () => {
1255
+ cancelAnimationFrame(n), window.removeEventListener("resize", t);
1256
1256
  };
1257
- }, [k, a.length]);
1258
- const Le = (e) => {
1259
- const n = z.current;
1260
- if (!n || !e) return !1;
1261
- const r = n.getBoundingClientRect();
1262
- return e.x >= r.left && e.x <= r.right && e.y >= r.top && e.y <= r.bottom;
1263
- }, ze = V(0), ge = () => globalThis.crypto?.randomUUID ? globalThis.crypto.randomUUID() : `uid-${++ze.current}`, K = V(null), ne = V(null), $e = V(null), Be = 0.9, Ie = 1.05, Z = V({ actionId: null, edge: null }), W = V({
1257
+ }, [y, s.length]);
1258
+ const GA = (A) => {
1259
+ const t = W.current;
1260
+ if (!t || !A) return !1;
1261
+ const n = t.getBoundingClientRect();
1262
+ return A.x >= n.left && A.x <= n.right && A.y >= n.top && A.y <= n.bottom;
1263
+ }, WA = j(0), fA = () => globalThis.crypto?.randomUUID ? globalThis.crypto.randomUUID() : `uid-${++WA.current}`, V = j(null), tA = j(null), YA = j(null), TA = 0.9, MA = 1.05, _ = j({ actionId: null, edge: null }), X = j({
1264
1264
  actionId: null,
1265
1265
  mode: null,
1266
1266
  dir: null,
@@ -1269,233 +1269,233 @@ const Sn = structuredClone(gn), ht = 5, Bt = ({ item: u, hint: a, isDragging: m
1269
1269
  initialStart: 0,
1270
1270
  initialEnd: 0,
1271
1271
  takeover: !1
1272
- }), Ce = V(!1), Ue = (e) => e.map((n) => {
1273
- const r = (n.actions ?? []).map((s) => `${String(s.id)}@${Number(s.start)}-${Number(s.end)}`).join("|");
1274
- return `${String(n.id)}:${r}`;
1275
- }).join("||"), Fe = (e) => {
1276
- const n = structuredClone(e);
1277
- R((r) => {
1278
- const s = [...r, n];
1279
- return s.length > ht && s.splice(0, s.length - ht), s;
1280
- }), x([]);
1281
- }, Ve = (e, n, r, s) => e < s && n > r, he = (e, n, r, s) => {
1282
- const i = Array.isArray(e?.actions) ? e.actions : [];
1283
- for (const o of i)
1284
- if (!(!o || o.id === n) && Ve(r, s, Number(o.start), Number(o.end)))
1272
+ }), PA = j(!1), LA = (A) => A.map((t) => {
1273
+ const n = (t.actions ?? []).map((o) => `${String(o.id)}@${Number(o.start)}-${Number(o.end)}`).join("|");
1274
+ return `${String(t.id)}:${n}`;
1275
+ }).join("||"), HA = (A) => {
1276
+ const t = structuredClone(A);
1277
+ h((n) => {
1278
+ const o = [...n, t];
1279
+ return o.length > Qe && o.splice(0, o.length - Qe), o;
1280
+ }), m([]);
1281
+ }, jA = (A, t, n, o) => A < o && t > n, QA = (A, t, n, o) => {
1282
+ const r = Array.isArray(A?.actions) ? A.actions : [];
1283
+ for (const i of r)
1284
+ if (!(!i || i.id === t) && jA(n, o, Number(i.start), Number(i.end)))
1285
1285
  return !0;
1286
1286
  return !1;
1287
- }, Xe = (e, n) => {
1288
- for (let r = 0; r < e.length; r++) {
1289
- const s = e[r], i = Array.isArray(s?.actions) ? s.actions : [];
1290
- for (let o = 0; o < i.length; o++) {
1291
- const c = i[o];
1292
- if (String(c?.id) === n)
1293
- return { rowIndex: r, actionIndex: o, action: c };
1287
+ }, KA = (A, t) => {
1288
+ for (let n = 0; n < A.length; n++) {
1289
+ const o = A[n], r = Array.isArray(o?.actions) ? o.actions : [];
1290
+ for (let i = 0; i < r.length; i++) {
1291
+ const a = r[i];
1292
+ if (String(a?.id) === t)
1293
+ return { rowIndex: n, actionIndex: i, action: a };
1294
1294
  }
1295
1295
  }
1296
1296
  return null;
1297
- }, we = (e, n) => {
1298
- const r = Xe(e, n), s = r?.action?.data?.linkId;
1299
- if (!r || !s) return null;
1300
- for (let i = 0; i < e.length; i++) {
1301
- const o = e[i], c = Array.isArray(o?.actions) ? o.actions : [];
1302
- for (let f = 0; f < c.length; f++) {
1303
- const p = c[f];
1304
- if (p?.data?.linkId && String(p.data.linkId) === String(s) && String(p.id) !== String(n))
1305
- return { rowIndex: i, actionIndex: f, action: p };
1297
+ }, DA = (A, t) => {
1298
+ const n = KA(A, t), o = n?.action?.data?.linkId;
1299
+ if (!n || !o) return null;
1300
+ for (let r = 0; r < A.length; r++) {
1301
+ const i = A[r], a = Array.isArray(i?.actions) ? i.actions : [];
1302
+ for (let B = 0; B < a.length; B++) {
1303
+ const d = a[B];
1304
+ if (d?.data?.linkId && String(d.data.linkId) === String(o) && String(d.id) !== String(t))
1305
+ return { rowIndex: r, actionIndex: B, action: d };
1306
1306
  }
1307
1307
  }
1308
1308
  return null;
1309
- }, st = (e, n) => {
1310
- const r = Xe(e, n);
1311
- if (!r) return e;
1312
- const s = we(e, n);
1313
- if (!s) return e;
1314
- const i = Number(r.action.start), o = Number(r.action.end);
1315
- if (!Number.isFinite(i) || !Number.isFinite(o) || o <= i || Number(s.action.start) === i && Number(s.action.end) === o) return e;
1316
- const c = structuredClone(e), f = c[s.rowIndex], p = Array.isArray(f.actions) ? [...f.actions] : [], h = { ...p[s.actionIndex], start: i, end: o };
1317
- return p.splice(s.actionIndex, 1, h), f.actions = p, c;
1318
- }, We = (e, n, r, s) => {
1319
- if (!Number.isFinite(r) || !Number.isFinite(s) || s <= r) return e;
1320
- const i = Xe(e, n);
1321
- if (!i) return e;
1322
- const o = we(e, n);
1323
- if (!o) return e;
1324
- const c = structuredClone(e), f = c[i.rowIndex], p = Array.isArray(f.actions) ? [...f.actions] : [], h = { ...p[i.actionIndex], start: r, end: s };
1325
- p.splice(i.actionIndex, 1, h), f.actions = p;
1326
- const b = c[o.rowIndex], N = Array.isArray(b.actions) ? [...b.actions] : [], w = { ...N[o.actionIndex], start: r, end: s };
1327
- return N.splice(o.actionIndex, 1, w), b.actions = N, c;
1328
- }, Je = (e, n, r, s) => {
1329
- if (!Number.isFinite(r) || !Number.isFinite(s) || s <= r) return e;
1330
- const i = Xe(e, n);
1331
- if (!i) return e;
1332
- const o = Number(i.action.start), c = Number(i.action.end);
1333
- if (o === r && c === s) return e;
1334
- const f = structuredClone(e), p = f[i.rowIndex], h = Array.isArray(p.actions) ? [...p.actions] : [], b = { ...h[i.actionIndex], start: r, end: s };
1335
- return h.splice(i.actionIndex, 1, b), p.actions = h, f;
1336
- }, Ge = () => {
1337
- const e = A.current?.getTime ? Number(A.current.getTime()) : 0;
1338
- return Number.isFinite(e) ? Math.max(0, e) : 0;
1339
- }, Ze = (e, n, r) => {
1340
- const s = Ge(), i = r - n;
1341
- if (!Number.isFinite(i) || i <= 0)
1342
- return { start: n, end: r, snapped: !1, edge: null };
1343
- const o = Math.abs(n - s), c = Math.abs(r - s), f = o <= c ? "start" : "end", p = Math.min(o, c), h = Z.current;
1344
- if (h.actionId === e && h.edge != null) {
1345
- if ((h.edge === "start" ? o : c) > Ie)
1346
- return Z.current = { actionId: e, edge: null }, { start: n, end: r, snapped: !1, edge: null };
1309
+ }, oe = (A, t) => {
1310
+ const n = KA(A, t);
1311
+ if (!n) return A;
1312
+ const o = DA(A, t);
1313
+ if (!o) return A;
1314
+ const r = Number(n.action.start), i = Number(n.action.end);
1315
+ if (!Number.isFinite(r) || !Number.isFinite(i) || i <= r || Number(o.action.start) === r && Number(o.action.end) === i) return A;
1316
+ const a = structuredClone(A), B = a[o.rowIndex], d = Array.isArray(B.actions) ? [...B.actions] : [], Q = { ...d[o.actionIndex], start: r, end: i };
1317
+ return d.splice(o.actionIndex, 1, Q), B.actions = d, a;
1318
+ }, XA = (A, t, n, o) => {
1319
+ if (!Number.isFinite(n) || !Number.isFinite(o) || o <= n) return A;
1320
+ const r = KA(A, t);
1321
+ if (!r) return A;
1322
+ const i = DA(A, t);
1323
+ if (!i) return A;
1324
+ const a = structuredClone(A), B = a[r.rowIndex], d = Array.isArray(B.actions) ? [...B.actions] : [], Q = { ...d[r.actionIndex], start: n, end: o };
1325
+ d.splice(r.actionIndex, 1, Q), B.actions = d;
1326
+ const C = a[i.rowIndex], F = Array.isArray(C.actions) ? [...C.actions] : [], D = { ...F[i.actionIndex], start: n, end: o };
1327
+ return F.splice(i.actionIndex, 1, D), C.actions = F, a;
1328
+ }, zA = (A, t, n, o) => {
1329
+ if (!Number.isFinite(n) || !Number.isFinite(o) || o <= n) return A;
1330
+ const r = KA(A, t);
1331
+ if (!r) return A;
1332
+ const i = Number(r.action.start), a = Number(r.action.end);
1333
+ if (i === n && a === o) return A;
1334
+ const B = structuredClone(A), d = B[r.rowIndex], Q = Array.isArray(d.actions) ? [...d.actions] : [], C = { ...Q[r.actionIndex], start: n, end: o };
1335
+ return Q.splice(r.actionIndex, 1, C), d.actions = Q, B;
1336
+ }, ZA = () => {
1337
+ const A = p.current?.getTime ? Number(p.current.getTime()) : 0;
1338
+ return Number.isFinite(A) ? Math.max(0, A) : 0;
1339
+ }, _A = (A, t, n) => {
1340
+ const o = ZA(), r = n - t;
1341
+ if (!Number.isFinite(r) || r <= 0)
1342
+ return { start: t, end: n, snapped: !1, edge: null };
1343
+ const i = Math.abs(t - o), a = Math.abs(n - o), B = i <= a ? "start" : "end", d = Math.min(i, a), Q = _.current;
1344
+ if (Q.actionId === A && Q.edge != null) {
1345
+ if ((Q.edge === "start" ? i : a) > MA)
1346
+ return _.current = { actionId: A, edge: null }, { start: t, end: n, snapped: !1, edge: null };
1347
1347
  } else {
1348
- if (p > Be)
1349
- return { start: n, end: r, snapped: !1, edge: null };
1350
- Z.current = { actionId: e, edge: f };
1351
- }
1352
- const w = Z.current.edge;
1353
- if (w === "start") {
1354
- const I = s, $ = I + i;
1355
- return { start: Math.max(0, I), end: Math.max(Math.max(0, I), $), snapped: !0, edge: w };
1356
- }
1357
- const P = s, _ = P - i;
1358
- return { start: Math.max(0, _), end: Math.max(0, P), snapped: !0, edge: w };
1359
- }, at = (e, n, r, s) => {
1360
- const i = Ge(), o = s === "left" ? "start" : "end", c = Math.abs(o === "start" ? n - i : r - i), f = Z.current;
1361
- if (f.actionId === e && f.edge === o) {
1362
- if (c > Ie)
1363
- return Z.current = { actionId: e, edge: null }, { start: n, end: r, snapped: !1 };
1348
+ if (d > TA)
1349
+ return { start: t, end: n, snapped: !1, edge: null };
1350
+ _.current = { actionId: A, edge: B };
1351
+ }
1352
+ const D = _.current.edge;
1353
+ if (D === "start") {
1354
+ const M = o, Y = M + r;
1355
+ return { start: Math.max(0, M), end: Math.max(Math.max(0, M), Y), snapped: !0, edge: D };
1356
+ }
1357
+ const N = o, O = N - r;
1358
+ return { start: Math.max(0, O), end: Math.max(0, N), snapped: !0, edge: D };
1359
+ }, se = (A, t, n, o) => {
1360
+ const r = ZA(), i = o === "left" ? "start" : "end", a = Math.abs(i === "start" ? t - r : n - r), B = _.current;
1361
+ if (B.actionId === A && B.edge === i) {
1362
+ if (a > MA)
1363
+ return _.current = { actionId: A, edge: null }, { start: t, end: n, snapped: !1 };
1364
1364
  } else {
1365
- if (c > Be)
1366
- return { start: n, end: r, snapped: !1 };
1367
- Z.current = { actionId: e, edge: o };
1368
- }
1369
- if (o === "start") {
1370
- const w = Math.max(0, i), P = Math.max(w + 0.01, r);
1371
- return { start: w, end: P, snapped: !0 };
1372
- }
1373
- const b = Math.max(0, i), N = Math.min(n, b - 0.01);
1374
- return { start: Math.max(0, N), end: b, snapped: !0 };
1375
- }, yt = (e, n, r) => {
1376
- const s = e.defaultDuration ?? 10;
1377
- let i = Math.max(0, n), o = i + s;
1378
- const c = A.current;
1379
- c?.isPlaying && c.pause(), m((f) => {
1380
- Fe(f);
1381
- const p = structuredClone(f);
1382
- for (; p.length < 4; ) p.push({ id: `${p.length}`, actions: [] });
1383
- const h = Number.isFinite(Number(r)) ? Number(r) : null, b = pe(h, M) ?? M[0], N = pe(h, H) ?? H[0], w = (P) => {
1384
- const _ = [];
1385
- for (const I of P) {
1386
- const $ = Array.isArray(p[I]?.actions) ? p[I].actions : [];
1387
- for (const Q of $) {
1388
- const ve = Number(Q?.start), xe = Number(Q?.end);
1389
- !Number.isFinite(ve) || !Number.isFinite(xe) || _.push({ start: ve, end: xe });
1365
+ if (a > TA)
1366
+ return { start: t, end: n, snapped: !1 };
1367
+ _.current = { actionId: A, edge: i };
1368
+ }
1369
+ if (i === "start") {
1370
+ const D = Math.max(0, r), N = Math.max(D + 0.01, n);
1371
+ return { start: D, end: N, snapped: !0 };
1372
+ }
1373
+ const C = Math.max(0, r), F = Math.min(t, C - 0.01);
1374
+ return { start: Math.max(0, F), end: C, snapped: !0 };
1375
+ }, we = (A, t, n) => {
1376
+ const o = A.defaultDuration ?? 10;
1377
+ let r = Math.max(0, t), i = r + o;
1378
+ const a = p.current;
1379
+ a?.isPlaying && a.pause(), l((B) => {
1380
+ HA(B);
1381
+ const d = structuredClone(B);
1382
+ for (; d.length < 4; ) d.push({ id: `${d.length}`, actions: [] });
1383
+ const Q = Number.isFinite(Number(n)) ? Number(n) : null, C = dA(Q, U) ?? U[0], F = dA(Q, k) ?? k[0], D = (N) => {
1384
+ const O = [];
1385
+ for (const M of N) {
1386
+ const Y = Array.isArray(d[M]?.actions) ? d[M].actions : [];
1387
+ for (const $ of Y) {
1388
+ const EA = Number($?.start), mA = Number($?.end);
1389
+ !Number.isFinite(EA) || !Number.isFinite(mA) || O.push({ start: EA, end: mA });
1390
1390
  }
1391
1391
  }
1392
- _.sort((I, $) => I.start - $.start);
1393
- for (const I of _)
1394
- Ve(i, o, I.start, I.end) && (i = I.end, o = i + s);
1392
+ O.sort((M, Y) => M.start - Y.start);
1393
+ for (const M of O)
1394
+ jA(r, i, M.start, M.end) && (r = M.end, i = r + o);
1395
1395
  };
1396
- if (e.kind === "video") {
1397
- const P = b, _ = Pe(P);
1398
- w([P, _]);
1399
- const I = `link-${ge()}`, $ = `video-${ge()}`, Q = `video-audio-${ge()}`;
1400
- p[P].actions = [
1401
- ...p[P].actions ?? [],
1396
+ if (A.kind === "video") {
1397
+ const N = C, O = NA(N);
1398
+ D([N, O]);
1399
+ const M = `link-${fA()}`, Y = `video-${fA()}`, $ = `video-audio-${fA()}`;
1400
+ d[N].actions = [
1401
+ ...d[N].actions ?? [],
1402
1402
  {
1403
- id: $,
1404
- start: i,
1405
- end: o,
1403
+ id: Y,
1404
+ start: r,
1405
+ end: i,
1406
1406
  effectId: "effect1",
1407
- data: { src: e.src, previewSrc: e.previewSrc, name: e.name, linkId: I }
1407
+ data: { src: A.src, previewSrc: A.previewSrc, name: A.name, linkId: M }
1408
1408
  }
1409
- ], p[_].actions = [
1410
- ...p[_].actions ?? [],
1409
+ ], d[O].actions = [
1410
+ ...d[O].actions ?? [],
1411
1411
  {
1412
- id: Q,
1413
- start: i,
1414
- end: o,
1412
+ id: $,
1413
+ start: r,
1414
+ end: i,
1415
1415
  effectId: "effect2",
1416
- data: { src: e.src, name: e.name, linkId: I }
1416
+ data: { src: A.src, name: A.name, linkId: M }
1417
1417
  }
1418
1418
  ];
1419
1419
  } else {
1420
- const P = N;
1421
- w([P]), p[P].actions = [
1422
- ...p[P].actions ?? [],
1420
+ const N = F;
1421
+ D([N]), d[N].actions = [
1422
+ ...d[N].actions ?? [],
1423
1423
  {
1424
- id: `audio-${ge()}`,
1425
- start: i,
1426
- end: o,
1424
+ id: `audio-${fA()}`,
1425
+ start: r,
1426
+ end: i,
1427
1427
  effectId: "effect0",
1428
- data: { src: e.src, name: e.name }
1428
+ data: { src: A.src, name: A.name }
1429
1429
  }
1430
1430
  ];
1431
1431
  }
1432
- return p;
1432
+ return d;
1433
1433
  });
1434
- }, St = () => {
1435
- const e = z.current;
1436
- return e ? e.querySelector(".timeline-editor-edit-area .ReactVirtualized__Grid")?.scrollLeft ?? 0 : 0;
1437
- }, wt = () => me, He = (e) => {
1438
- const n = z.current;
1439
- if (!n) return 0;
1440
- const s = (n.querySelector(".timeline-editor-edit-area") ?? n).getBoundingClientRect(), c = (e - s.x + St() - vt) * rt / nt;
1441
- return Math.max(0, c);
1442
- }, Rt = (e) => {
1443
- const n = Number(e);
1444
- return Number.isFinite(n) ? vt + n * nt / rt : 0;
1445
- }, xt = (e, n, r, s) => {
1446
- const i = e.defaultDuration ?? 10;
1447
- let o = Math.max(0, n), c = o + i;
1448
- const f = [];
1449
- if (e.kind === "video") {
1450
- const h = r, b = Pe(h);
1451
- f.push(h, b);
1434
+ }, Ie = () => {
1435
+ const A = W.current;
1436
+ return A ? A.querySelector(".timeline-editor-edit-area .ReactVirtualized__Grid")?.scrollLeft ?? 0 : 0;
1437
+ }, De = () => lA, kA = (A) => {
1438
+ const t = W.current;
1439
+ if (!t) return 0;
1440
+ const o = (t.querySelector(".timeline-editor-edit-area") ?? t).getBoundingClientRect(), a = (A - o.x + Ie() - Ee) * ne / te;
1441
+ return Math.max(0, a);
1442
+ }, he = (A) => {
1443
+ const t = Number(A);
1444
+ return Number.isFinite(t) ? Ee + t * te / ne : 0;
1445
+ }, me = (A, t, n, o) => {
1446
+ const r = A.defaultDuration ?? 10;
1447
+ let i = Math.max(0, t), a = i + r;
1448
+ const B = [];
1449
+ if (A.kind === "video") {
1450
+ const Q = n, C = NA(Q);
1451
+ B.push(Q, C);
1452
1452
  } else
1453
- f.push(r);
1454
- const p = [];
1455
- for (const h of f) {
1456
- const b = Array.isArray(s[h]?.actions) ? s[h].actions : [];
1457
- for (const N of b) {
1458
- const w = Number(N?.start), P = Number(N?.end);
1459
- !Number.isFinite(w) || !Number.isFinite(P) || p.push({ start: w, end: P });
1453
+ B.push(n);
1454
+ const d = [];
1455
+ for (const Q of B) {
1456
+ const C = Array.isArray(o[Q]?.actions) ? o[Q].actions : [];
1457
+ for (const F of C) {
1458
+ const D = Number(F?.start), N = Number(F?.end);
1459
+ !Number.isFinite(D) || !Number.isFinite(N) || d.push({ start: D, end: N });
1460
1460
  }
1461
1461
  }
1462
- p.sort((h, b) => h.start - b.start);
1463
- for (const h of p)
1464
- Ve(o, c, h.start, h.end) && (o = h.end, c = o + i);
1465
- return Math.max(0, o);
1466
- }, _e = (e) => {
1467
- const n = z.current;
1462
+ d.sort((Q, C) => Q.start - C.start);
1463
+ for (const Q of d)
1464
+ jA(i, a, Q.start, Q.end) && (i = Q.end, a = i + r);
1465
+ return Math.max(0, i);
1466
+ }, OA = (A) => {
1467
+ const t = W.current;
1468
+ if (!t) return null;
1469
+ const n = t.querySelector(".timeline-editor-edit-area");
1468
1470
  if (!n) return null;
1469
- const r = n.querySelector(".timeline-editor-edit-area");
1470
- if (!r) return null;
1471
- const s = r.getBoundingClientRect(), i = e - s.y;
1472
- if (i < 0 || i > s.height) return null;
1473
- const o = i + wt(), c = Math.floor(o / F);
1474
- if (!Number.isFinite(c)) return null;
1475
- const f = Math.max(0, T.current.length - 1);
1476
- return Math.min(Math.max(0, c), f);
1477
- }, ct = (e) => {
1478
- if (!e) return null;
1479
- if ("clientX" in e && "clientY" in e) {
1480
- const i = Number(e.clientX), o = Number(e.clientY);
1481
- if (Number.isFinite(i) && Number.isFinite(o)) return { x: i, y: o };
1482
- }
1483
- const n = e.touches, r = e.changedTouches, s = (n && n.length ? n[0] : null) || (r && r.length ? r[0] : null);
1484
- if (s) {
1485
- const i = Number(s.clientX), o = Number(s.clientY);
1486
- if (Number.isFinite(i) && Number.isFinite(o)) return { x: i, y: o };
1471
+ const o = n.getBoundingClientRect(), r = A - o.y;
1472
+ if (r < 0 || r > o.height) return null;
1473
+ const i = r + De(), a = Math.floor(i / H);
1474
+ if (!Number.isFinite(a)) return null;
1475
+ const B = Math.max(0, b.current.length - 1);
1476
+ return Math.min(Math.max(0, a), B);
1477
+ }, ae = (A) => {
1478
+ if (!A) return null;
1479
+ if ("clientX" in A && "clientY" in A) {
1480
+ const r = Number(A.clientX), i = Number(A.clientY);
1481
+ if (Number.isFinite(r) && Number.isFinite(i)) return { x: r, y: i };
1482
+ }
1483
+ const t = A.touches, n = A.changedTouches, o = (t && t.length ? t[0] : null) || (n && n.length ? n[0] : null);
1484
+ if (o) {
1485
+ const r = Number(o.clientX), i = Number(o.clientY);
1486
+ if (Number.isFinite(r) && Number.isFinite(i)) return { x: r, y: i };
1487
1487
  }
1488
1488
  return null;
1489
- }, le = () => {
1490
- if (Ce.current) return;
1491
- Ce.current = !0;
1492
- const e = (r) => {
1493
- const s = W.current;
1494
- if (!s.actionId || !s.mode || r.isPrimary === !1) return;
1495
- const i = He(r.clientX);
1496
- s.basePointerTime == null && (s.basePointerTime = i), s.lastPointerTime = i;
1497
- }, n = () => {
1498
- W.current = {
1489
+ }, cA = () => {
1490
+ if (PA.current) return;
1491
+ PA.current = !0;
1492
+ const A = (n) => {
1493
+ const o = X.current;
1494
+ if (!o.actionId || !o.mode || n.isPrimary === !1) return;
1495
+ const r = kA(n.clientX);
1496
+ o.basePointerTime == null && (o.basePointerTime = r), o.lastPointerTime = r;
1497
+ }, t = () => {
1498
+ X.current = {
1499
1499
  actionId: null,
1500
1500
  mode: null,
1501
1501
  dir: null,
@@ -1504,258 +1504,258 @@ const Sn = structuredClone(gn), ht = 5, Bt = ({ item: u, hint: a, isDragging: m
1504
1504
  initialStart: 0,
1505
1505
  initialEnd: 0,
1506
1506
  takeover: !1
1507
- }, Z.current = { actionId: null, edge: null };
1507
+ }, _.current = { actionId: null, edge: null };
1508
1508
  };
1509
- window.addEventListener("pointermove", e, { capture: !0 }), window.addEventListener("pointerup", n, { capture: !0 }), window.addEventListener("pointercancel", n, { capture: !0 }), W.current._removePointerListeners = () => {
1510
- window.removeEventListener("pointermove", e, { capture: !0 }), window.removeEventListener("pointerup", n, { capture: !0 }), window.removeEventListener("pointercancel", n, { capture: !0 }), Ce.current = !1;
1509
+ window.addEventListener("pointermove", A, { capture: !0 }), window.addEventListener("pointerup", t, { capture: !0 }), window.addEventListener("pointercancel", t, { capture: !0 }), X.current._removePointerListeners = () => {
1510
+ window.removeEventListener("pointermove", A, { capture: !0 }), window.removeEventListener("pointerup", t, { capture: !0 }), window.removeEventListener("pointercancel", t, { capture: !0 }), PA.current = !1;
1511
1511
  };
1512
- }, Ke = () => {
1513
- const e = W.current?._removePointerListeners;
1514
- e?.(), delete W.current._removePointerListeners;
1515
- }, Qe = (e) => e.map((n) => ({
1516
- ...n,
1512
+ }, VA = () => {
1513
+ const A = X.current?._removePointerListeners;
1514
+ A?.(), delete X.current._removePointerListeners;
1515
+ }, $A = (A) => A.map((t) => ({
1516
+ ...t,
1517
1517
  selected: void 0,
1518
- actions: (n.actions ?? []).map((r) => ({ ...r, selected: void 0 }))
1519
- })), lt = _t(() => a.map((e, n) => {
1520
- const r = d ? (e.actions ?? []).some((c) => String(c.id) === d) : !1, s = U != null && be != null && n === be, i = Array.isArray(e.classNames) ? e.classNames : [], o = s ? [...i, "dnd-drop-hover"] : i;
1518
+ actions: (t.actions ?? []).map((n) => ({ ...n, selected: void 0 }))
1519
+ })), ce = Oe(() => s.map((A, t) => {
1520
+ const n = u ? (A.actions ?? []).some((a) => String(a.id) === u) : !1, o = L != null && CA != null && t === CA, r = Array.isArray(A.classNames) ? A.classNames : [], i = o ? [...r, "dnd-drop-hover"] : r;
1521
1521
  return {
1522
- ...e,
1523
- classNames: o,
1524
- selected: r,
1525
- actions: (e.actions ?? []).map((c) => ({
1526
- ...c,
1527
- selected: d ? String(c.id) === d : !1
1522
+ ...A,
1523
+ classNames: i,
1524
+ selected: n,
1525
+ actions: (A.actions ?? []).map((a) => ({
1526
+ ...a,
1527
+ selected: u ? String(a.id) === u : !1
1528
1528
  }))
1529
1529
  };
1530
- }), [a, d, U, be]), Et = () => {
1531
- if (!d) return;
1532
- const e = A.current;
1533
- e?.isPlaying && e.pause(), m((n) => {
1534
- Fe(n);
1535
- let r = null;
1536
- for (const i of n) {
1537
- const o = Array.isArray(i?.actions) ? i.actions : [];
1538
- for (const c of o) {
1539
- if (String(c?.id) !== d) continue;
1540
- const f = c?.data?.linkId;
1541
- f != null && (r = String(f));
1530
+ }), [s, u, L, CA]), ve = () => {
1531
+ if (!u) return;
1532
+ const A = p.current;
1533
+ A?.isPlaying && A.pause(), l((t) => {
1534
+ HA(t);
1535
+ let n = null;
1536
+ for (const r of t) {
1537
+ const i = Array.isArray(r?.actions) ? r.actions : [];
1538
+ for (const a of i) {
1539
+ if (String(a?.id) !== u) continue;
1540
+ const B = a?.data?.linkId;
1541
+ B != null && (n = String(B));
1542
1542
  break;
1543
1543
  }
1544
- if (r != null) break;
1544
+ if (n != null) break;
1545
1545
  }
1546
- return n.map((i) => ({
1547
- ...i,
1548
- actions: (i.actions ?? []).filter((o) => !(String(o?.id) === d || r && String(o?.data?.linkId ?? "") === r))
1546
+ return t.map((r) => ({
1547
+ ...r,
1548
+ actions: (r.actions ?? []).filter((i) => !(String(i?.id) === u || n && String(i?.data?.linkId ?? "") === n))
1549
1549
  }));
1550
- }), g(null);
1551
- }, ut = () => {
1552
- if (!d) return;
1553
- const e = A.current, n = e?.getTime ? e.getTime() : null;
1554
- if (n == null) return;
1555
- const r = Number(n);
1556
- Number.isFinite(r) && (e?.isPlaying && e.pause(), K.current = null, ne.current = null, m((s) => {
1557
- let i = -1, o = -1, c = null;
1558
- for (let B = 0; B < s.length; B++) {
1559
- const Y = s[B], re = Array.isArray(Y?.actions) ? Y.actions : [];
1560
- for (let ee = 0; ee < re.length; ee++) {
1561
- const De = re[ee];
1562
- if (String(De?.id) === d) {
1563
- i = B, o = ee, c = De;
1550
+ }), f(null);
1551
+ }, ge = () => {
1552
+ if (!u) return;
1553
+ const A = p.current, t = A?.getTime ? A.getTime() : null;
1554
+ if (t == null) return;
1555
+ const n = Number(t);
1556
+ Number.isFinite(n) && (A?.isPlaying && A.pause(), V.current = null, tA.current = null, l((o) => {
1557
+ let r = -1, i = -1, a = null;
1558
+ for (let T = 0; T < o.length; T++) {
1559
+ const J = o[T], nA = Array.isArray(J?.actions) ? J.actions : [];
1560
+ for (let AA = 0; AA < nA.length; AA++) {
1561
+ const RA = nA[AA];
1562
+ if (String(RA?.id) === u) {
1563
+ r = T, i = AA, a = RA;
1564
1564
  break;
1565
1565
  }
1566
1566
  }
1567
- if (c) break;
1567
+ if (a) break;
1568
1568
  }
1569
- if (!c) return s;
1570
- const f = c?.data?.linkId ? String(c.data.linkId) : null;
1571
- let p = -1, h = -1, b = null;
1572
- if (f)
1573
- for (let B = 0; B < s.length; B++) {
1574
- const Y = s[B], re = Array.isArray(Y?.actions) ? Y.actions : [];
1575
- for (let ee = 0; ee < re.length; ee++) {
1576
- const De = re[ee];
1577
- if (String(De?.id) !== d && String(De?.data?.linkId ?? "") === f) {
1578
- p = B, h = ee, b = De;
1569
+ if (!a) return o;
1570
+ const B = a?.data?.linkId ? String(a.data.linkId) : null;
1571
+ let d = -1, Q = -1, C = null;
1572
+ if (B)
1573
+ for (let T = 0; T < o.length; T++) {
1574
+ const J = o[T], nA = Array.isArray(J?.actions) ? J.actions : [];
1575
+ for (let AA = 0; AA < nA.length; AA++) {
1576
+ const RA = nA[AA];
1577
+ if (String(RA?.id) !== u && String(RA?.data?.linkId ?? "") === B) {
1578
+ d = T, Q = AA, C = RA;
1579
1579
  break;
1580
1580
  }
1581
1581
  }
1582
- if (b) break;
1582
+ if (C) break;
1583
1583
  }
1584
- const N = Number(c.start), w = Number(c.end);
1585
- if (!Number.isFinite(N) || !Number.isFinite(w) || !(N < r && r < w)) return s;
1586
- Fe(s);
1587
- const P = f && b ? `link-${ge()}` : f, _ = f && b ? `link-${ge()}` : f, I = `${String(c.id)}-r-${ge()}`, $ = Number(c?.data?.offset ?? 0), Q = Number.isFinite($) ? $ : 0, ve = r - N, xe = Q + (Number.isFinite(ve) ? ve : 0), je = {
1588
- ...c,
1589
- start: N,
1590
- end: r,
1591
- id: c.id,
1592
- data: { ...c.data, offset: Q, linkId: P ?? void 0 }
1593
- }, Ee = {
1594
- ...c,
1595
- start: r,
1596
- end: w,
1597
- id: I,
1598
- data: { ...c.data, offset: xe, linkId: _ ?? void 0 }
1599
- }, Te = structuredClone(s), ue = Te[i], Ae = Array.isArray(ue.actions) ? [...ue.actions] : [];
1600
- if (Ae.splice(o, 1, je, Ee), Ae.sort((B, Y) => Number(B.start) - Number(Y.start)), ue.actions = Ae, b && p >= 0 && h >= 0) {
1601
- const B = Number(b.start), Y = Number(b.end);
1602
- if (Number.isFinite(B) && Number.isFinite(Y) && B === N && Y === w) {
1603
- const re = `${String(b.id)}-r-${ge()}`, ee = {
1604
- ...b,
1605
- start: N,
1606
- end: r,
1607
- id: b.id,
1608
- data: { ...b.data, linkId: P ?? void 0 }
1609
- }, De = {
1610
- ...b,
1611
- start: r,
1612
- end: w,
1613
- id: re,
1614
- data: { ...b.data, linkId: _ ?? void 0 }
1615
- }, Ct = Te[p], Ft = Array.isArray(Ct.actions) ? [...Ct.actions] : [];
1616
- Ft.splice(h, 1, ee, De), Ft.sort((Ut, Vt) => Number(Ut.start) - Number(Vt.start)), Ct.actions = Ft;
1584
+ const F = Number(a.start), D = Number(a.end);
1585
+ if (!Number.isFinite(F) || !Number.isFinite(D) || !(F < n && n < D)) return o;
1586
+ HA(o);
1587
+ const N = B && C ? `link-${fA()}` : B, O = B && C ? `link-${fA()}` : B, M = `${String(a.id)}-r-${fA()}`, Y = Number(a?.data?.offset ?? 0), $ = Number.isFinite(Y) ? Y : 0, EA = n - F, mA = $ + (Number.isFinite(EA) ? EA : 0), xA = {
1588
+ ...a,
1589
+ start: F,
1590
+ end: n,
1591
+ id: a.id,
1592
+ data: { ...a.data, offset: $, linkId: N ?? void 0 }
1593
+ }, vA = {
1594
+ ...a,
1595
+ start: n,
1596
+ end: D,
1597
+ id: M,
1598
+ data: { ...a.data, offset: mA, linkId: O ?? void 0 }
1599
+ }, bA = structuredClone(o), gA = bA[r], pA = Array.isArray(gA.actions) ? [...gA.actions] : [];
1600
+ if (pA.splice(i, 1, xA, vA), pA.sort((T, J) => Number(T.start) - Number(J.start)), gA.actions = pA, C && d >= 0 && Q >= 0) {
1601
+ const T = Number(C.start), J = Number(C.end);
1602
+ if (Number.isFinite(T) && Number.isFinite(J) && T === F && J === D) {
1603
+ const nA = `${String(C.id)}-r-${fA()}`, AA = {
1604
+ ...C,
1605
+ start: F,
1606
+ end: n,
1607
+ id: C.id,
1608
+ data: { ...C.data, linkId: N ?? void 0 }
1609
+ }, RA = {
1610
+ ...C,
1611
+ start: n,
1612
+ end: D,
1613
+ id: nA,
1614
+ data: { ...C.data, linkId: O ?? void 0 }
1615
+ }, Pe = bA[d], He = Array.isArray(Pe.actions) ? [...Pe.actions] : [];
1616
+ He.splice(Q, 1, AA, RA), He.sort((Le, je) => Number(Le.start) - Number(je.start)), Pe.actions = He;
1617
1617
  }
1618
1618
  }
1619
- return Te;
1619
+ return bA;
1620
1620
  }));
1621
- }, Tt = () => {
1622
- const e = A.current, n = e?.getTime ? e.getTime() : null;
1623
- e?.isPlaying && e.pause(), K.current = null, ne.current = null, g(null), R((r) => {
1624
- if (r.length === 0) return r;
1625
- const s = r[r.length - 1], i = structuredClone(T.current);
1626
- return x((o) => [...o, i]), m(structuredClone(s)), r.slice(0, -1);
1627
- }), n != null && requestAnimationFrame(() => {
1628
- const r = A.current;
1629
- r?.setTime && r.setTime(n);
1621
+ }, be = () => {
1622
+ const A = p.current, t = A?.getTime ? A.getTime() : null;
1623
+ A?.isPlaying && A.pause(), V.current = null, tA.current = null, f(null), h((n) => {
1624
+ if (n.length === 0) return n;
1625
+ const o = n[n.length - 1], r = structuredClone(b.current);
1626
+ return m((i) => [...i, r]), l(structuredClone(o)), n.slice(0, -1);
1627
+ }), t != null && requestAnimationFrame(() => {
1628
+ const n = p.current;
1629
+ n?.setTime && n.setTime(t);
1630
1630
  });
1631
- }, dt = () => {
1632
- const e = A.current, n = e?.getTime ? e.getTime() : null;
1633
- e?.isPlaying && e.pause(), K.current = null, ne.current = null, g(null), x((r) => {
1634
- if (r.length === 0) return r;
1635
- const s = r[r.length - 1], i = structuredClone(T.current);
1636
- return R((o) => {
1637
- const c = [...o, i];
1638
- return c.length > ht && c.splice(0, c.length - ht), c;
1639
- }), m(structuredClone(s)), r.slice(0, -1);
1640
- }), n != null && requestAnimationFrame(() => {
1641
- const r = A.current;
1642
- r?.setTime && r.setTime(n);
1631
+ }, ue = () => {
1632
+ const A = p.current, t = A?.getTime ? A.getTime() : null;
1633
+ A?.isPlaying && A.pause(), V.current = null, tA.current = null, f(null), m((n) => {
1634
+ if (n.length === 0) return n;
1635
+ const o = n[n.length - 1], r = structuredClone(b.current);
1636
+ return h((i) => {
1637
+ const a = [...i, r];
1638
+ return a.length > Qe && a.splice(0, a.length - Qe), a;
1639
+ }), l(structuredClone(o)), n.slice(0, -1);
1640
+ }), t != null && requestAnimationFrame(() => {
1641
+ const n = p.current;
1642
+ n?.setTime && n.setTime(t);
1643
1643
  });
1644
- }, ft = Xt(
1645
- jt(Jt, { activationConstraint: { distance: 6 } }),
1644
+ }, Be = Ke(
1645
+ xe(ze, { activationConstraint: { distance: 6 } }),
1646
1646
  // On touch, require a short press-hold before starting drag, so scroll is still possible.
1647
- jt(Kt, { activationConstraint: { delay: 180, tolerance: 6 } })
1648
- ), { setNodeRef: At, isOver: Nt } = Gt({ id: "timeline-drop" }), mt = (e) => {
1649
- const n = e.active.data.current?.item;
1650
- G(n ?? null);
1651
- const r = ct(e.activatorEvent);
1652
- if (y.current = r, j.current = r, ye(r), r) {
1653
- const i = Le(r);
1654
- te(i);
1655
- const o = _e(r.y);
1656
- oe(i ? ce(n ?? null, o) : null);
1647
+ xe(Ve, { activationConstraint: { delay: 180, tolerance: 6 } })
1648
+ ), { setNodeRef: pe, isOver: Fe } = Ze({ id: "timeline-drop" }), le = (A) => {
1649
+ const t = A.active.data.current?.item;
1650
+ Z(t ?? null);
1651
+ const n = ae(A.activatorEvent);
1652
+ if (w.current = n, x.current = n, wA(n), n) {
1653
+ const r = GA(n);
1654
+ eA(r);
1655
+ const i = OA(n.y);
1656
+ iA(r ? aA(t ?? null, i) : null);
1657
1657
  } else
1658
- oe(null), te(!1);
1659
- const s = e.active.rect.current.initial;
1660
- fe(s ? { width: s.width, height: s.height } : null);
1661
- }, pt = (e) => {
1662
- const n = e.active.rect.current.initial;
1663
- !O && n && fe({ width: n.width, height: n.height });
1664
- const r = j.current;
1665
- if (!r) {
1666
- oe(null);
1658
+ iA(null), eA(!1);
1659
+ const o = A.active.rect.current.initial;
1660
+ BA(o ? { width: o.width, height: o.height } : null);
1661
+ }, de = (A) => {
1662
+ const t = A.active.rect.current.initial;
1663
+ !S && t && BA({ width: t.width, height: t.height });
1664
+ const n = x.current;
1665
+ if (!n) {
1666
+ iA(null);
1667
1667
  return;
1668
1668
  }
1669
- const s = Number(e?.delta?.x ?? 0), i = Number(e?.delta?.y ?? 0), o = { x: r.x + (Number.isFinite(s) ? s : 0), y: r.y + (Number.isFinite(i) ? i : 0) };
1670
- y.current = o, ye(o);
1671
- const c = Le(o);
1672
- te(c);
1673
- const f = _e(o.y);
1674
- oe(c ? ce(U, f) : null);
1675
- }, kt = (e) => {
1676
- const n = e.active.data.current?.item, r = j.current, s = Number(e?.delta?.x ?? 0), i = Number(e?.delta?.y ?? 0), o = r ? { x: r.x + (Number.isFinite(s) ? s : 0), y: r.y + (Number.isFinite(i) ? i : 0) } : y.current;
1677
- y.current = o;
1678
- const f = String(e.over?.id ?? "") === "timeline-drop" || Le(o);
1679
- if (n && f && o) {
1680
- const p = He(o.x), h = _e(o.y), b = ce(n, h);
1681
- oe(b), yt(n, Math.max(0, p), b);
1682
- }
1683
- G(null), fe(null), oe(null), te(!1), ye(null), j.current = null;
1684
- }, Pt = () => {
1685
- G(null), fe(null), oe(null), te(!1), ye(null), j.current = null;
1686
- }, Re = _t(() => {
1687
- if (!U || !ae) return null;
1688
- const e = Me;
1689
- if (!e) return null;
1690
- const n = _e(e.y), r = ce(U, n);
1691
- if (r == null) return null;
1692
- const s = He(e.x), i = xt(U, s, r, T.current), o = U.defaultDuration ?? 10;
1669
+ const o = Number(A?.delta?.x ?? 0), r = Number(A?.delta?.y ?? 0), i = { x: n.x + (Number.isFinite(o) ? o : 0), y: n.y + (Number.isFinite(r) ? r : 0) };
1670
+ w.current = i, wA(i);
1671
+ const a = GA(i);
1672
+ eA(a);
1673
+ const B = OA(i.y);
1674
+ iA(a ? aA(L, B) : null);
1675
+ }, ye = (A) => {
1676
+ const t = A.active.data.current?.item, n = x.current, o = Number(A?.delta?.x ?? 0), r = Number(A?.delta?.y ?? 0), i = n ? { x: n.x + (Number.isFinite(o) ? o : 0), y: n.y + (Number.isFinite(r) ? r : 0) } : w.current;
1677
+ w.current = i;
1678
+ const B = String(A.over?.id ?? "") === "timeline-drop" || GA(i);
1679
+ if (t && B && i) {
1680
+ const d = kA(i.x), Q = OA(i.y), C = aA(t, Q);
1681
+ iA(C), we(t, Math.max(0, d), C);
1682
+ }
1683
+ Z(null), BA(null), iA(null), eA(!1), wA(null), x.current = null;
1684
+ }, Ne = () => {
1685
+ Z(null), BA(null), iA(null), eA(!1), wA(null), x.current = null;
1686
+ }, hA = Oe(() => {
1687
+ if (!L || !sA) return null;
1688
+ const A = UA;
1689
+ if (!A) return null;
1690
+ const t = OA(A.y), n = aA(L, t);
1691
+ if (n == null) return null;
1692
+ const o = kA(A.x), r = me(L, o, n, b.current), i = L.defaultDuration ?? 10;
1693
1693
  return {
1694
- laneRow: r,
1695
- desiredStart: s,
1696
- start: i,
1697
- end: i + o,
1698
- duration: o,
1699
- kind: U.kind
1694
+ laneRow: n,
1695
+ desiredStart: o,
1696
+ start: r,
1697
+ end: r + i,
1698
+ duration: i,
1699
+ kind: L.kind
1700
1700
  };
1701
- }, [U, ae, Me, Ne, me, F]), It = (e) => {
1702
- if (!k || e.pointerType === "mouse" || U) return;
1703
- if (!!e.target?.closest?.(".timeline-editor-cursor-area, .timeline-editor-cursor")) {
1704
- C.current = { pointerId: e.pointerId }, D.current = null;
1701
+ }, [L, sA, UA, FA, lA, H]), Me = (A) => {
1702
+ if (!y || A.pointerType === "mouse" || L) return;
1703
+ if (!!A.target?.closest?.(".timeline-editor-cursor-area, .timeline-editor-cursor")) {
1704
+ P.current = { pointerId: A.pointerId }, R.current = null;
1705
1705
  try {
1706
- e.currentTarget.setPointerCapture(e.pointerId);
1706
+ A.currentTarget.setPointerCapture(A.pointerId);
1707
1707
  } catch {
1708
1708
  }
1709
- e.preventDefault();
1709
+ A.preventDefault();
1710
1710
  return;
1711
1711
  }
1712
- D.current = { x: e.clientX, y: e.clientY };
1713
- }, t = (e) => {
1714
- if (!k || e.pointerType === "mouse" || U || !C.current || C.current.pointerId !== e.pointerId) return;
1715
- const n = He(e.clientX);
1716
- A.current && A.current.setTime(n), e.preventDefault();
1717
- }, l = (e) => {
1718
- if (!k || e.pointerType === "mouse" || U) return;
1719
- if (C.current && C.current.pointerId === e.pointerId) {
1720
- C.current = null;
1712
+ R.current = { x: A.clientX, y: A.clientY };
1713
+ }, e = (A) => {
1714
+ if (!y || A.pointerType === "mouse" || L || !P.current || P.current.pointerId !== A.pointerId) return;
1715
+ const t = kA(A.clientX);
1716
+ p.current && p.current.setTime(t), A.preventDefault();
1717
+ }, c = (A) => {
1718
+ if (!y || A.pointerType === "mouse" || L) return;
1719
+ if (P.current && P.current.pointerId === A.pointerId) {
1720
+ P.current = null;
1721
1721
  try {
1722
- e.currentTarget.releasePointerCapture(e.pointerId);
1722
+ A.currentTarget.releasePointerCapture(A.pointerId);
1723
1723
  } catch {
1724
1724
  }
1725
- e.preventDefault();
1725
+ A.preventDefault();
1726
1726
  return;
1727
1727
  }
1728
- const n = D.current;
1729
- D.current = null;
1730
- const r = n ? Math.abs(e.clientX - n.x) : 0, s = n ? Math.abs(e.clientY - n.y) : 0;
1731
- if (r > 10 || s > 10) return;
1732
- const o = e.target?.closest?.("[data-action-id]"), c = o?.getAttribute("data-row-id"), f = o?.getAttribute("data-action-id");
1733
- if (c && f) {
1734
- g(f);
1728
+ const t = R.current;
1729
+ R.current = null;
1730
+ const n = t ? Math.abs(A.clientX - t.x) : 0, o = t ? Math.abs(A.clientY - t.y) : 0;
1731
+ if (n > 10 || o > 10) return;
1732
+ const i = A.target?.closest?.("[data-action-id]"), a = i?.getAttribute("data-row-id"), B = i?.getAttribute("data-action-id");
1733
+ if (a && B) {
1734
+ f(B);
1735
1735
  return;
1736
1736
  }
1737
- const p = He(e.clientX);
1738
- g(null), A.current && A.current.setTime(p);
1737
+ const d = kA(A.clientX);
1738
+ f(null), p.current && p.current.setTime(d);
1739
1739
  };
1740
- return /* @__PURE__ */ v.jsx(
1741
- Zt,
1740
+ return /* @__PURE__ */ E.jsx(
1741
+ _e,
1742
1742
  {
1743
- sensors: ft,
1744
- collisionDetection: Qt,
1745
- onDragStart: mt,
1746
- onDragMove: pt,
1747
- onDragEnd: kt,
1748
- onDragCancel: Pt,
1749
- children: /* @__PURE__ */ v.jsxs("div", { className: "timeline-editor-engine", children: [
1750
- /* @__PURE__ */ v.jsx("div", { className: "player-config", children: /* @__PURE__ */ v.jsx("div", { className: "footage-bin", children: X.map((e) => /* @__PURE__ */ v.jsx(
1751
- wn,
1743
+ sensors: Be,
1744
+ collisionDetection: $e,
1745
+ onDragStart: le,
1746
+ onDragMove: de,
1747
+ onDragEnd: ye,
1748
+ onDragCancel: Ne,
1749
+ children: /* @__PURE__ */ E.jsxs("div", { className: "timeline-editor-engine", children: [
1750
+ /* @__PURE__ */ E.jsx("div", { className: "player-config", children: /* @__PURE__ */ E.jsx("div", { className: "footage-bin", children: K.map((A) => /* @__PURE__ */ E.jsx(
1751
+ pt,
1752
1752
  {
1753
- item: e,
1754
- hint: k ? "Press-hold, then drag into timeline" : "Drag into timeline"
1753
+ item: A,
1754
+ hint: y ? "Press-hold, then drag into timeline" : "Drag into timeline"
1755
1755
  },
1756
- e.id
1756
+ A.id
1757
1757
  )) }) }),
1758
- /* @__PURE__ */ v.jsx("div", { className: "player-panel", ref: q, children: /* @__PURE__ */ v.jsx(
1758
+ /* @__PURE__ */ E.jsx("div", { className: "player-panel", ref: q, children: /* @__PURE__ */ E.jsx(
1759
1759
  "video",
1760
1760
  {
1761
1761
  className: "player-video",
@@ -1767,114 +1767,114 @@ const Sn = structuredClone(gn), ht = 5, Bt = ({ item: u, hint: a, isDragging: m
1767
1767
  disableRemotePlayback: !0,
1768
1768
  controlsList: "nodownload noplaybackrate noremoteplayback",
1769
1769
  tabIndex: -1,
1770
- onContextMenu: (e) => e.preventDefault(),
1771
- ref: (e) => L.attach(e)
1770
+ onContextMenu: (A) => A.preventDefault(),
1771
+ ref: (A) => G.attach(A)
1772
1772
  }
1773
1773
  ) }),
1774
- /* @__PURE__ */ v.jsx(
1775
- bn,
1774
+ /* @__PURE__ */ E.jsx(
1775
+ mt,
1776
1776
  {
1777
- timelineState: A,
1778
- autoScrollWhenPlay: de,
1779
- editorData: a,
1780
- selectedActionId: d,
1781
- onDeleteSelectedClip: Et,
1782
- onSplitSelectedClip: ut,
1783
- canUndo: S.length > 0,
1784
- canRedo: E.length > 0,
1785
- onUndo: Tt,
1786
- onRedo: dt
1777
+ timelineState: p,
1778
+ autoScrollWhenPlay: uA,
1779
+ editorData: s,
1780
+ selectedActionId: u,
1781
+ onDeleteSelectedClip: ve,
1782
+ onSplitSelectedClip: ge,
1783
+ canUndo: I.length > 0,
1784
+ canRedo: v.length > 0,
1785
+ onUndo: be,
1786
+ onRedo: ue
1787
1787
  }
1788
1788
  ),
1789
- /* @__PURE__ */ v.jsxs(
1789
+ /* @__PURE__ */ E.jsxs(
1790
1790
  "div",
1791
1791
  {
1792
- className: `timeline-drop${Nt ? " is-over" : ""}`,
1793
- ref: (e) => {
1794
- z.current = e, At(e);
1792
+ className: `timeline-drop${Fe ? " is-over" : ""}`,
1793
+ ref: (A) => {
1794
+ W.current = A, pe(A);
1795
1795
  },
1796
- onPointerDown: It,
1797
- onPointerMove: t,
1798
- onPointerUp: l,
1796
+ onPointerDown: Me,
1797
+ onPointerMove: e,
1798
+ onPointerUp: c,
1799
1799
  children: [
1800
- /* @__PURE__ */ v.jsx(
1800
+ /* @__PURE__ */ E.jsx(
1801
1801
  "div",
1802
1802
  {
1803
1803
  className: "timeline-lane-labels",
1804
1804
  style: {
1805
- top: Ye,
1806
- transform: `translateY(${-me}px)`,
1807
- height: F * Se.length
1805
+ top: JA,
1806
+ transform: `translateY(${-lA}px)`,
1807
+ height: H * IA.length
1808
1808
  },
1809
- children: Se.map((e, n) => /* @__PURE__ */ v.jsx(
1809
+ children: IA.map((A, t) => /* @__PURE__ */ E.jsx(
1810
1810
  "div",
1811
1811
  {
1812
- className: `timeline-lane-label${be === n ? " is-hover" : ""}`,
1813
- style: { height: F },
1814
- children: e
1812
+ className: `timeline-lane-label${CA === t ? " is-hover" : ""}`,
1813
+ style: { height: H },
1814
+ children: A
1815
1815
  },
1816
- e
1816
+ A
1817
1817
  ))
1818
1818
  }
1819
1819
  ),
1820
- Re ? /* @__PURE__ */ v.jsx("div", { className: "timeline-ghost-layer", style: { top: Ye, left: Oe }, children: (() => {
1821
- const e = nt / rt, n = Re.duration * e, r = Rt(Re.start) - Ne, s = [];
1822
- return Re.kind === "video" ? (s.push({ row: Re.laneRow, kind: "video" }), s.push({ row: Pe(Re.laneRow), kind: "audio" })) : s.push({ row: Re.laneRow, kind: "audio" }), s.map((i) => /* @__PURE__ */ v.jsx(
1820
+ hA ? /* @__PURE__ */ E.jsx("div", { className: "timeline-ghost-layer", style: { top: JA, left: SA }, children: (() => {
1821
+ const A = te / ne, t = hA.duration * A, n = he(hA.start) - FA, o = [];
1822
+ return hA.kind === "video" ? (o.push({ row: hA.laneRow, kind: "video" }), o.push({ row: NA(hA.laneRow), kind: "audio" })) : o.push({ row: hA.laneRow, kind: "audio" }), o.map((r) => /* @__PURE__ */ E.jsx(
1823
1823
  "div",
1824
1824
  {
1825
- className: `timeline-ghost-clip${i.kind === "video" ? " is-video" : " is-audio"}`,
1825
+ className: `timeline-ghost-clip${r.kind === "video" ? " is-video" : " is-audio"}`,
1826
1826
  style: {
1827
- left: r,
1828
- top: i.row * F - me,
1829
- width: n,
1830
- height: F
1827
+ left: n,
1828
+ top: r.row * H - lA,
1829
+ width: t,
1830
+ height: H
1831
1831
  }
1832
1832
  },
1833
- `${i.kind}-${i.row}`
1833
+ `${r.kind}-${r.row}`
1834
1834
  ));
1835
1835
  })() }) : null,
1836
- /* @__PURE__ */ v.jsx(
1837
- Ht,
1836
+ /* @__PURE__ */ E.jsx(
1837
+ ke,
1838
1838
  {
1839
- scale: rt,
1840
- scaleWidth: nt,
1841
- startLeft: vt,
1842
- rowHeight: F,
1839
+ scale: ne,
1840
+ scaleWidth: te,
1841
+ startLeft: Ee,
1842
+ rowHeight: H,
1843
1843
  autoScroll: !0,
1844
- ref: A,
1845
- editorData: lt,
1846
- effects: pn,
1847
- onScroll: (e) => {
1848
- const n = Number(e?.scrollTop ?? 0), r = Number(e?.scrollLeft ?? 0);
1849
- Number.isFinite(n) && ot(n), Number.isFinite(r) && ke(r);
1844
+ ref: p,
1845
+ editorData: ce,
1846
+ effects: lt,
1847
+ onScroll: (A) => {
1848
+ const t = Number(A?.scrollTop ?? 0), n = Number(A?.scrollLeft ?? 0);
1849
+ Number.isFinite(t) && ie(t), Number.isFinite(n) && yA(n);
1850
1850
  },
1851
- onClickTimeArea: (e, n) => {
1852
- g(null);
1851
+ onClickTimeArea: (A, t) => {
1852
+ f(null);
1853
1853
  },
1854
- onClickRow: (e) => {
1855
- e.target?.closest?.(".timeline-editor-action") || g(null);
1854
+ onClickRow: (A) => {
1855
+ A.target?.closest?.(".timeline-editor-action") || f(null);
1856
1856
  },
1857
- onClickActionOnly: (e, { action: n }) => {
1858
- const r = n;
1859
- r?.id && g(String(r.id));
1857
+ onClickActionOnly: (A, { action: t }) => {
1858
+ const n = t;
1859
+ n?.id && f(String(n.id));
1860
1860
  },
1861
- onActionMoveStart: ({ action: e }) => {
1862
- $e.current = String(e?.id ?? ""), Z.current = { actionId: String(e?.id ?? ""), edge: null };
1863
- const n = Number(e?.start), r = Number(e?.end);
1864
- W.current = {
1865
- actionId: String(e?.id ?? ""),
1861
+ onActionMoveStart: ({ action: A }) => {
1862
+ YA.current = String(A?.id ?? ""), _.current = { actionId: String(A?.id ?? ""), edge: null };
1863
+ const t = Number(A?.start), n = Number(A?.end);
1864
+ X.current = {
1865
+ actionId: String(A?.id ?? ""),
1866
1866
  mode: "move",
1867
1867
  dir: null,
1868
1868
  basePointerTime: null,
1869
1869
  lastPointerTime: null,
1870
- initialStart: Number.isFinite(n) ? n : 0,
1871
- initialEnd: Number.isFinite(r) ? r : 0,
1870
+ initialStart: Number.isFinite(t) ? t : 0,
1871
+ initialEnd: Number.isFinite(n) ? n : 0,
1872
1872
  takeover: !1
1873
- }, le(), !K.current && (K.current = structuredClone(a), ne.current = Ue(a));
1873
+ }, cA(), !V.current && (V.current = structuredClone(s), tA.current = LA(s));
1874
1874
  },
1875
1875
  onActionMoveEnd: () => {
1876
- const e = K.current, n = ne.current;
1877
- e && n && Ue(T.current) !== n && Fe(e), K.current = null, ne.current = null, $e.current = null, Z.current = { actionId: null, edge: null }, W.current = {
1876
+ const A = V.current, t = tA.current;
1877
+ A && t && LA(b.current) !== t && HA(A), V.current = null, tA.current = null, YA.current = null, _.current = { actionId: null, edge: null }, X.current = {
1878
1878
  actionId: null,
1879
1879
  mode: null,
1880
1880
  dir: null,
@@ -1883,25 +1883,25 @@ const Sn = structuredClone(gn), ht = 5, Bt = ({ item: u, hint: a, isDragging: m
1883
1883
  initialStart: 0,
1884
1884
  initialEnd: 0,
1885
1885
  takeover: !1
1886
- }, Ke();
1886
+ }, VA();
1887
1887
  },
1888
- onActionResizeStart: ({ action: e }) => {
1889
- $e.current = String(e?.id ?? ""), Z.current = { actionId: String(e?.id ?? ""), edge: null };
1890
- const n = Number(e?.start), r = Number(e?.end);
1891
- W.current = {
1892
- actionId: String(e?.id ?? ""),
1888
+ onActionResizeStart: ({ action: A }) => {
1889
+ YA.current = String(A?.id ?? ""), _.current = { actionId: String(A?.id ?? ""), edge: null };
1890
+ const t = Number(A?.start), n = Number(A?.end);
1891
+ X.current = {
1892
+ actionId: String(A?.id ?? ""),
1893
1893
  mode: "resize",
1894
1894
  dir: null,
1895
1895
  basePointerTime: null,
1896
1896
  lastPointerTime: null,
1897
- initialStart: Number.isFinite(n) ? n : 0,
1898
- initialEnd: Number.isFinite(r) ? r : 0,
1897
+ initialStart: Number.isFinite(t) ? t : 0,
1898
+ initialEnd: Number.isFinite(n) ? n : 0,
1899
1899
  takeover: !1
1900
- }, le(), !K.current && (K.current = structuredClone(a), ne.current = Ue(a));
1900
+ }, cA(), !V.current && (V.current = structuredClone(s), tA.current = LA(s));
1901
1901
  },
1902
1902
  onActionResizeEnd: () => {
1903
- const e = K.current, n = ne.current;
1904
- e && n && Ue(T.current) !== n && Fe(e), K.current = null, ne.current = null, $e.current = null, Z.current = { actionId: null, edge: null }, W.current = {
1903
+ const A = V.current, t = tA.current;
1904
+ A && t && LA(b.current) !== t && HA(A), V.current = null, tA.current = null, YA.current = null, _.current = { actionId: null, edge: null }, X.current = {
1905
1905
  actionId: null,
1906
1906
  mode: null,
1907
1907
  dir: null,
@@ -1910,118 +1910,118 @@ const Sn = structuredClone(gn), ht = 5, Bt = ({ item: u, hint: a, isDragging: m
1910
1910
  initialStart: 0,
1911
1911
  initialEnd: 0,
1912
1912
  takeover: !1
1913
- }, Ke();
1913
+ }, VA();
1914
1914
  },
1915
- onActionMoving: ({ action: e, row: n, start: r, end: s }) => {
1916
- const i = String(e?.id ?? ""), o = W.current;
1917
- if (o.takeover && o.mode === "move" && o.actionId === i) {
1918
- const _ = o.basePointerTime, I = o.lastPointerTime, $ = _ != null && I != null ? I - _ : 0, Q = o.initialStart + $, ve = o.initialEnd + $, xe = Ze(i, Q, ve), je = xe.start, Ee = xe.end;
1919
- if (he(n, String(e.id), je, Ee)) return !1;
1920
- const ue = T.current, Ae = we(ue, String(e.id));
1921
- if (Ae) {
1922
- const B = ue[Ae.rowIndex];
1923
- if (B && he(B, String(Ae.action.id), je, Ee)) return !1;
1915
+ onActionMoving: ({ action: A, row: t, start: n, end: o }) => {
1916
+ const r = String(A?.id ?? ""), i = X.current;
1917
+ if (i.takeover && i.mode === "move" && i.actionId === r) {
1918
+ const O = i.basePointerTime, M = i.lastPointerTime, Y = O != null && M != null ? M - O : 0, $ = i.initialStart + Y, EA = i.initialEnd + Y, mA = _A(r, $, EA), xA = mA.start, vA = mA.end;
1919
+ if (QA(t, String(A.id), xA, vA)) return !1;
1920
+ const gA = b.current, pA = DA(gA, String(A.id));
1921
+ if (pA) {
1922
+ const T = gA[pA.rowIndex];
1923
+ if (T && QA(T, String(pA.action.id), xA, vA)) return !1;
1924
1924
  }
1925
- return m((B) => {
1926
- const Y = Ae ? We(B, String(e.id), je, Ee) : Je(B, String(e.id), je, Ee);
1927
- return T.current = Y, Y;
1925
+ return l((T) => {
1926
+ const J = pA ? XA(T, String(A.id), xA, vA) : zA(T, String(A.id), xA, vA);
1927
+ return b.current = J, J;
1928
1928
  }), !1;
1929
1929
  }
1930
- const c = Number(r), f = Number(s);
1931
- if (!Number.isFinite(c) || !Number.isFinite(f) || f <= c) return !1;
1932
- const p = Ze(i, c, f), h = p.start, b = p.end;
1933
- if (!Number.isFinite(h) || !Number.isFinite(b) || b <= h || he(n, String(e.id), h, b)) return !1;
1934
- const w = T.current, P = we(w, String(e.id));
1935
- if (P) {
1936
- const _ = w[P.rowIndex];
1937
- if (_ && he(_, String(P.action.id), h, b)) return !1;
1930
+ const a = Number(n), B = Number(o);
1931
+ if (!Number.isFinite(a) || !Number.isFinite(B) || B <= a) return !1;
1932
+ const d = _A(r, a, B), Q = d.start, C = d.end;
1933
+ if (!Number.isFinite(Q) || !Number.isFinite(C) || C <= Q || QA(t, String(A.id), Q, C)) return !1;
1934
+ const D = b.current, N = DA(D, String(A.id));
1935
+ if (N) {
1936
+ const O = D[N.rowIndex];
1937
+ if (O && QA(O, String(N.action.id), Q, C)) return !1;
1938
1938
  }
1939
- if ((P || p.snapped) && m((_) => {
1940
- const I = P ? We(_, String(e.id), h, b) : Je(_, String(e.id), h, b);
1941
- return T.current = I, I;
1942
- }), p.snapped) {
1943
- const _ = W.current.lastPointerTime;
1944
- return W.current = {
1945
- actionId: i,
1939
+ if ((N || d.snapped) && l((O) => {
1940
+ const M = N ? XA(O, String(A.id), Q, C) : zA(O, String(A.id), Q, C);
1941
+ return b.current = M, M;
1942
+ }), d.snapped) {
1943
+ const O = X.current.lastPointerTime;
1944
+ return X.current = {
1945
+ actionId: r,
1946
1946
  mode: "move",
1947
1947
  dir: null,
1948
- basePointerTime: _,
1949
- lastPointerTime: W.current.lastPointerTime,
1950
- initialStart: c,
1951
- initialEnd: f,
1948
+ basePointerTime: O,
1949
+ lastPointerTime: X.current.lastPointerTime,
1950
+ initialStart: a,
1951
+ initialEnd: B,
1952
1952
  takeover: !0
1953
- }, le(), !1;
1953
+ }, cA(), !1;
1954
1954
  }
1955
1955
  },
1956
- onActionResizing: ({ action: e, row: n, start: r, end: s, dir: i }) => {
1957
- const o = String(e?.id ?? ""), c = W.current, f = i ?? "right";
1958
- if (c.takeover && c.mode === "resize" && c.actionId === o) {
1959
- const $ = c.basePointerTime, Q = c.lastPointerTime, ve = $ != null && Q != null ? Q - $ : 0, xe = f === "left" ? c.initialStart + ve : c.initialStart, je = f === "right" ? c.initialEnd + ve : c.initialEnd, Ee = at(o, xe, je, f), Te = Ee.start, ue = Ee.end;
1960
- if (he(n, String(e.id), Te, ue)) return !1;
1961
- const B = T.current, Y = we(B, String(e.id));
1962
- if (Y) {
1963
- const re = B[Y.rowIndex];
1964
- if (re && he(re, String(Y.action.id), Te, ue)) return !1;
1956
+ onActionResizing: ({ action: A, row: t, start: n, end: o, dir: r }) => {
1957
+ const i = String(A?.id ?? ""), a = X.current, B = r ?? "right";
1958
+ if (a.takeover && a.mode === "resize" && a.actionId === i) {
1959
+ const Y = a.basePointerTime, $ = a.lastPointerTime, EA = Y != null && $ != null ? $ - Y : 0, mA = B === "left" ? a.initialStart + EA : a.initialStart, xA = B === "right" ? a.initialEnd + EA : a.initialEnd, vA = se(i, mA, xA, B), bA = vA.start, gA = vA.end;
1960
+ if (QA(t, String(A.id), bA, gA)) return !1;
1961
+ const T = b.current, J = DA(T, String(A.id));
1962
+ if (J) {
1963
+ const nA = T[J.rowIndex];
1964
+ if (nA && QA(nA, String(J.action.id), bA, gA)) return !1;
1965
1965
  }
1966
- return m((re) => {
1967
- const ee = Y ? We(re, String(e.id), Te, ue) : Je(re, String(e.id), Te, ue);
1968
- return T.current = ee, ee;
1966
+ return l((nA) => {
1967
+ const AA = J ? XA(nA, String(A.id), bA, gA) : zA(nA, String(A.id), bA, gA);
1968
+ return b.current = AA, AA;
1969
1969
  }), !1;
1970
1970
  }
1971
- const p = Number(r), h = Number(s);
1972
- if (!Number.isFinite(p) || !Number.isFinite(h) || h <= p) return !1;
1973
- const b = at(o, p, h, f), N = b.start, w = b.end;
1974
- if (!Number.isFinite(N) || !Number.isFinite(w) || w <= N || he(n, String(e.id), N, w)) return !1;
1975
- const _ = T.current, I = we(_, String(e.id));
1976
- if (I) {
1977
- const $ = _[I.rowIndex];
1978
- if ($ && he($, String(I.action.id), N, w)) return !1;
1971
+ const d = Number(n), Q = Number(o);
1972
+ if (!Number.isFinite(d) || !Number.isFinite(Q) || Q <= d) return !1;
1973
+ const C = se(i, d, Q, B), F = C.start, D = C.end;
1974
+ if (!Number.isFinite(F) || !Number.isFinite(D) || D <= F || QA(t, String(A.id), F, D)) return !1;
1975
+ const O = b.current, M = DA(O, String(A.id));
1976
+ if (M) {
1977
+ const Y = O[M.rowIndex];
1978
+ if (Y && QA(Y, String(M.action.id), F, D)) return !1;
1979
1979
  }
1980
- if ((I || b.snapped) && m(($) => {
1981
- const Q = I ? We($, String(e.id), N, w) : Je($, String(e.id), N, w);
1982
- return T.current = Q, Q;
1983
- }), b.snapped) {
1984
- const $ = W.current.lastPointerTime;
1985
- return W.current = {
1986
- actionId: o,
1980
+ if ((M || C.snapped) && l((Y) => {
1981
+ const $ = M ? XA(Y, String(A.id), F, D) : zA(Y, String(A.id), F, D);
1982
+ return b.current = $, $;
1983
+ }), C.snapped) {
1984
+ const Y = X.current.lastPointerTime;
1985
+ return X.current = {
1986
+ actionId: i,
1987
1987
  mode: "resize",
1988
- dir: f,
1989
- basePointerTime: $,
1990
- lastPointerTime: W.current.lastPointerTime,
1991
- initialStart: p,
1992
- initialEnd: h,
1988
+ dir: B,
1989
+ basePointerTime: Y,
1990
+ lastPointerTime: X.current.lastPointerTime,
1991
+ initialStart: d,
1992
+ initialEnd: Q,
1993
1993
  takeover: !0
1994
- }, le(), !1;
1994
+ }, cA(), !1;
1995
1995
  }
1996
1996
  },
1997
- onChange: (e) => {
1998
- const n = Qe(e), r = $e.current, s = r ? st(n, r) : n;
1999
- m(s);
2000
- const i = K.current, o = ne.current;
2001
- i && o && (Ue(s) !== o && Fe(i), K.current = null, ne.current = null);
1997
+ onChange: (A) => {
1998
+ const t = $A(A), n = YA.current, o = n ? oe(t, n) : t;
1999
+ l(o);
2000
+ const r = V.current, i = tA.current;
2001
+ r && i && (LA(o) !== i && HA(r), V.current = null, tA.current = null);
2002
2002
  },
2003
- getActionRender: (e, n) => {
2004
- if (e.effectId === "effect0")
2005
- return /* @__PURE__ */ v.jsx(sn, { action: e, row: n });
2006
- if (e.effectId === "effect2")
2007
- return /* @__PURE__ */ v.jsx(cn, { action: e, row: n });
2008
- if (e.effectId === "effect1")
2009
- return /* @__PURE__ */ v.jsx(an, { action: e, row: n });
2003
+ getActionRender: (A, t) => {
2004
+ if (A.effectId === "effect0")
2005
+ return /* @__PURE__ */ E.jsx(it, { action: A, row: t });
2006
+ if (A.effectId === "effect2")
2007
+ return /* @__PURE__ */ E.jsx(st, { action: A, row: t });
2008
+ if (A.effectId === "effect1")
2009
+ return /* @__PURE__ */ E.jsx(ot, { action: A, row: t });
2010
2010
  }
2011
2011
  }
2012
2012
  )
2013
2013
  ]
2014
2014
  }
2015
2015
  ),
2016
- /* @__PURE__ */ v.jsx(en, { children: U ? /* @__PURE__ */ v.jsx(
2016
+ /* @__PURE__ */ E.jsx(At, { children: L ? /* @__PURE__ */ E.jsx(
2017
2017
  "div",
2018
2018
  {
2019
2019
  className: "footage-overlay",
2020
- style: O ? {
2021
- width: O.width,
2022
- height: O.height
2020
+ style: S ? {
2021
+ width: S.width,
2022
+ height: S.height
2023
2023
  } : void 0,
2024
- children: /* @__PURE__ */ v.jsx(Bt, { item: U, hint: "Drop on timeline", isDragging: !0 })
2024
+ children: /* @__PURE__ */ E.jsx(Te, { item: L, hint: "Drop on timeline", isDragging: !0 })
2025
2025
  }
2026
2026
  ) : null })
2027
2027
  ] })
@@ -2029,5 +2029,5 @@ const Sn = structuredClone(gn), ht = 5, Bt = ({ item: u, hint: a, isDragging: m
2029
2029
  );
2030
2030
  };
2031
2031
  export {
2032
- Pn as MeliesVideoEditor
2032
+ xt as MeliesVideoEditor
2033
2033
  };