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.
- package/dist/index.cjs +8 -8
- package/dist/index.js +1294 -1294
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,109 +1,109 @@
|
|
|
1
|
-
import
|
|
2
|
-
import { Timeline as
|
|
3
|
-
import { Howl as
|
|
4
|
-
import { Select as
|
|
5
|
-
import { useSensors as
|
|
6
|
-
var
|
|
7
|
-
var
|
|
8
|
-
function
|
|
9
|
-
if (
|
|
10
|
-
|
|
11
|
-
var
|
|
12
|
-
function
|
|
13
|
-
var
|
|
14
|
-
|
|
15
|
-
for (
|
|
16
|
-
if (
|
|
17
|
-
return { $$typeof:
|
|
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
|
|
19
|
+
return Ae.Fragment = l, Ae.jsx = h, Ae.jsxs = h, Ae;
|
|
20
20
|
}
|
|
21
|
-
var
|
|
22
|
-
var
|
|
23
|
-
function
|
|
24
|
-
return
|
|
25
|
-
var
|
|
26
|
-
function
|
|
27
|
-
if (
|
|
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
|
|
30
|
-
return typeof
|
|
29
|
+
var c = uA && e[uA] || e[K];
|
|
30
|
+
return typeof c == "function" ? c : null;
|
|
31
31
|
}
|
|
32
|
-
var
|
|
33
|
-
function
|
|
32
|
+
var Z = g.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;
|
|
33
|
+
function S(e) {
|
|
34
34
|
{
|
|
35
|
-
for (var
|
|
36
|
-
|
|
37
|
-
|
|
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
|
|
40
|
+
function BA(e, c, A) {
|
|
41
41
|
{
|
|
42
|
-
var
|
|
43
|
-
|
|
44
|
-
var
|
|
45
|
-
return String(
|
|
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
|
-
|
|
47
|
+
o.unshift("Warning: " + c), Function.prototype.apply.call(console[e], console, o);
|
|
48
48
|
}
|
|
49
49
|
}
|
|
50
|
-
var
|
|
51
|
-
|
|
52
|
-
function
|
|
53
|
-
return !!(typeof
|
|
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
|
-
|
|
57
|
+
e.$$typeof === yA || e.getModuleId !== void 0));
|
|
58
58
|
}
|
|
59
|
-
function
|
|
60
|
-
var
|
|
61
|
-
if (
|
|
62
|
-
return
|
|
63
|
-
var
|
|
64
|
-
return
|
|
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
|
|
67
|
-
return
|
|
66
|
+
function SA(e) {
|
|
67
|
+
return e.displayName || "Context";
|
|
68
68
|
}
|
|
69
|
-
function
|
|
70
|
-
if (
|
|
69
|
+
function oA(e) {
|
|
70
|
+
if (e == null)
|
|
71
71
|
return null;
|
|
72
|
-
if (typeof
|
|
73
|
-
return
|
|
74
|
-
if (typeof
|
|
75
|
-
return
|
|
76
|
-
switch (
|
|
77
|
-
case
|
|
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
|
|
79
|
+
case l:
|
|
80
80
|
return "Portal";
|
|
81
|
-
case
|
|
81
|
+
case I:
|
|
82
82
|
return "Profiler";
|
|
83
|
-
case
|
|
83
|
+
case f:
|
|
84
84
|
return "StrictMode";
|
|
85
|
-
case
|
|
85
|
+
case b:
|
|
86
86
|
return "Suspense";
|
|
87
|
-
case
|
|
87
|
+
case y:
|
|
88
88
|
return "SuspenseList";
|
|
89
89
|
}
|
|
90
|
-
if (typeof
|
|
91
|
-
switch (
|
|
92
|
-
case
|
|
93
|
-
var
|
|
94
|
-
return
|
|
95
|
-
case
|
|
96
|
-
var
|
|
97
|
-
return
|
|
98
|
-
case
|
|
99
|
-
return
|
|
100
|
-
case
|
|
101
|
-
var
|
|
102
|
-
return
|
|
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
|
|
104
|
+
var n = e, o = n._payload, r = n._init;
|
|
105
105
|
try {
|
|
106
|
-
return
|
|
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
|
|
115
|
-
function
|
|
114
|
+
var sA = Object.assign, eA = 0, UA, wA, w, x, R, P, H;
|
|
115
|
+
function U() {
|
|
116
116
|
}
|
|
117
|
-
|
|
118
|
-
function
|
|
117
|
+
U.__reactDisabledLog = !0;
|
|
118
|
+
function k() {
|
|
119
119
|
{
|
|
120
|
-
if (
|
|
121
|
-
|
|
122
|
-
var
|
|
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:
|
|
125
|
+
value: U,
|
|
126
126
|
writable: !0
|
|
127
127
|
};
|
|
128
128
|
Object.defineProperties(console, {
|
|
129
|
-
info:
|
|
130
|
-
log:
|
|
131
|
-
warn:
|
|
132
|
-
error:
|
|
133
|
-
group:
|
|
134
|
-
groupCollapsed:
|
|
135
|
-
groupEnd:
|
|
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
|
-
|
|
138
|
+
eA++;
|
|
139
139
|
}
|
|
140
140
|
}
|
|
141
|
-
function
|
|
141
|
+
function IA() {
|
|
142
142
|
{
|
|
143
|
-
if (
|
|
144
|
-
var
|
|
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:
|
|
151
|
-
value:
|
|
150
|
+
log: sA({}, e, {
|
|
151
|
+
value: UA
|
|
152
152
|
}),
|
|
153
|
-
info:
|
|
154
|
-
value:
|
|
153
|
+
info: sA({}, e, {
|
|
154
|
+
value: wA
|
|
155
155
|
}),
|
|
156
|
-
warn:
|
|
157
|
-
value:
|
|
156
|
+
warn: sA({}, e, {
|
|
157
|
+
value: w
|
|
158
158
|
}),
|
|
159
|
-
error:
|
|
160
|
-
value:
|
|
159
|
+
error: sA({}, e, {
|
|
160
|
+
value: x
|
|
161
161
|
}),
|
|
162
|
-
group:
|
|
163
|
-
value:
|
|
162
|
+
group: sA({}, e, {
|
|
163
|
+
value: R
|
|
164
164
|
}),
|
|
165
|
-
groupCollapsed:
|
|
166
|
-
value:
|
|
165
|
+
groupCollapsed: sA({}, e, {
|
|
166
|
+
value: P
|
|
167
167
|
}),
|
|
168
|
-
groupEnd:
|
|
169
|
-
value:
|
|
168
|
+
groupEnd: sA({}, e, {
|
|
169
|
+
value: H
|
|
170
170
|
})
|
|
171
171
|
});
|
|
172
172
|
}
|
|
173
|
-
|
|
173
|
+
eA < 0 && S("disabledDepth fell below zero. This is a bug in React. Please file an issue.");
|
|
174
174
|
}
|
|
175
175
|
}
|
|
176
|
-
var
|
|
177
|
-
function
|
|
176
|
+
var dA = Z.ReactCurrentDispatcher, aA;
|
|
177
|
+
function NA(e, c, A) {
|
|
178
178
|
{
|
|
179
|
-
if (
|
|
179
|
+
if (aA === void 0)
|
|
180
180
|
try {
|
|
181
181
|
throw Error();
|
|
182
|
-
} catch (
|
|
183
|
-
var
|
|
184
|
-
|
|
182
|
+
} catch (n) {
|
|
183
|
+
var t = n.stack.trim().match(/\n( *(at )?)/);
|
|
184
|
+
aA = t && t[1] || "";
|
|
185
185
|
}
|
|
186
186
|
return `
|
|
187
|
-
` +
|
|
187
|
+
` + aA + e;
|
|
188
188
|
}
|
|
189
189
|
}
|
|
190
|
-
var
|
|
190
|
+
var GA = !1, WA;
|
|
191
191
|
{
|
|
192
|
-
var
|
|
193
|
-
|
|
192
|
+
var fA = typeof WeakMap == "function" ? WeakMap : Map;
|
|
193
|
+
WA = new fA();
|
|
194
194
|
}
|
|
195
|
-
function
|
|
196
|
-
if (!
|
|
195
|
+
function V(e, c) {
|
|
196
|
+
if (!e || GA)
|
|
197
197
|
return "";
|
|
198
198
|
{
|
|
199
|
-
var
|
|
200
|
-
if (
|
|
201
|
-
return
|
|
199
|
+
var A = WA.get(e);
|
|
200
|
+
if (A !== void 0)
|
|
201
|
+
return A;
|
|
202
202
|
}
|
|
203
|
-
var
|
|
204
|
-
|
|
205
|
-
var
|
|
203
|
+
var t;
|
|
204
|
+
GA = !0;
|
|
205
|
+
var n = Error.prepareStackTrace;
|
|
206
206
|
Error.prepareStackTrace = void 0;
|
|
207
|
-
var
|
|
208
|
-
|
|
207
|
+
var o;
|
|
208
|
+
o = dA.current, dA.current = null, k();
|
|
209
209
|
try {
|
|
210
|
-
if (
|
|
211
|
-
var
|
|
210
|
+
if (c) {
|
|
211
|
+
var r = function() {
|
|
212
212
|
throw Error();
|
|
213
213
|
};
|
|
214
|
-
if (Object.defineProperty(
|
|
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(
|
|
221
|
-
} catch (
|
|
222
|
-
|
|
220
|
+
Reflect.construct(r, []);
|
|
221
|
+
} catch (D) {
|
|
222
|
+
t = D;
|
|
223
223
|
}
|
|
224
|
-
Reflect.construct(
|
|
224
|
+
Reflect.construct(e, [], r);
|
|
225
225
|
} else {
|
|
226
226
|
try {
|
|
227
|
-
|
|
228
|
-
} catch (
|
|
229
|
-
|
|
227
|
+
r.call();
|
|
228
|
+
} catch (D) {
|
|
229
|
+
t = D;
|
|
230
230
|
}
|
|
231
|
-
|
|
231
|
+
e.call(r.prototype);
|
|
232
232
|
}
|
|
233
233
|
} else {
|
|
234
234
|
try {
|
|
235
235
|
throw Error();
|
|
236
|
-
} catch (
|
|
237
|
-
|
|
236
|
+
} catch (D) {
|
|
237
|
+
t = D;
|
|
238
238
|
}
|
|
239
|
-
|
|
239
|
+
e();
|
|
240
240
|
}
|
|
241
|
-
} catch (
|
|
242
|
-
if (
|
|
243
|
-
for (var
|
|
244
|
-
`),
|
|
245
|
-
`),
|
|
246
|
-
|
|
247
|
-
for (;
|
|
248
|
-
if (
|
|
249
|
-
if (
|
|
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 (
|
|
252
|
-
var
|
|
253
|
-
` +
|
|
254
|
-
return
|
|
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 (
|
|
256
|
+
while (B >= 1 && d >= 0);
|
|
257
257
|
break;
|
|
258
258
|
}
|
|
259
259
|
}
|
|
260
260
|
} finally {
|
|
261
|
-
|
|
261
|
+
GA = !1, dA.current = o, IA(), Error.prepareStackTrace = n;
|
|
262
262
|
}
|
|
263
|
-
var
|
|
264
|
-
return typeof
|
|
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
|
|
267
|
-
return
|
|
266
|
+
function tA(e, c, A) {
|
|
267
|
+
return V(e, !1);
|
|
268
268
|
}
|
|
269
|
-
function
|
|
270
|
-
var
|
|
271
|
-
return !!(
|
|
269
|
+
function YA(e) {
|
|
270
|
+
var c = e.prototype;
|
|
271
|
+
return !!(c && c.isReactComponent);
|
|
272
272
|
}
|
|
273
|
-
function
|
|
274
|
-
if (
|
|
273
|
+
function TA(e, c, A) {
|
|
274
|
+
if (e == null)
|
|
275
275
|
return "";
|
|
276
|
-
if (typeof
|
|
277
|
-
return
|
|
278
|
-
if (typeof
|
|
279
|
-
return
|
|
280
|
-
switch (
|
|
281
|
-
case
|
|
282
|
-
return
|
|
283
|
-
case
|
|
284
|
-
return
|
|
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
|
|
287
|
-
switch (
|
|
288
|
-
case
|
|
289
|
-
return
|
|
290
|
-
case
|
|
291
|
-
return
|
|
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
|
|
293
|
+
var t = e, n = t._payload, o = t._init;
|
|
294
294
|
try {
|
|
295
|
-
return
|
|
295
|
+
return TA(o(n), c, A);
|
|
296
296
|
} catch {
|
|
297
297
|
}
|
|
298
298
|
}
|
|
299
299
|
}
|
|
300
300
|
return "";
|
|
301
301
|
}
|
|
302
|
-
var
|
|
303
|
-
function
|
|
304
|
-
if (
|
|
305
|
-
var
|
|
306
|
-
|
|
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
|
-
|
|
308
|
+
X.setExtraStackFrame(null);
|
|
309
309
|
}
|
|
310
|
-
function
|
|
310
|
+
function LA(e, c, A, t, n) {
|
|
311
311
|
{
|
|
312
|
-
var
|
|
313
|
-
for (var
|
|
314
|
-
if (
|
|
315
|
-
var
|
|
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
|
|
318
|
-
var
|
|
319
|
-
throw
|
|
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
|
-
|
|
322
|
-
} catch (
|
|
323
|
-
|
|
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
|
-
|
|
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
|
|
330
|
-
function
|
|
331
|
-
return
|
|
329
|
+
var HA = Array.isArray;
|
|
330
|
+
function jA(e) {
|
|
331
|
+
return HA(e);
|
|
332
332
|
}
|
|
333
|
-
function
|
|
333
|
+
function QA(e) {
|
|
334
334
|
{
|
|
335
|
-
var
|
|
336
|
-
return
|
|
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
|
|
339
|
+
function KA(e) {
|
|
340
340
|
try {
|
|
341
|
-
return
|
|
341
|
+
return DA(e), !1;
|
|
342
342
|
} catch {
|
|
343
343
|
return !0;
|
|
344
344
|
}
|
|
345
345
|
}
|
|
346
|
-
function
|
|
347
|
-
return "" +
|
|
346
|
+
function DA(e) {
|
|
347
|
+
return "" + e;
|
|
348
348
|
}
|
|
349
|
-
function
|
|
350
|
-
if (
|
|
351
|
-
return
|
|
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
|
|
353
|
+
var XA = Z.ReactCurrentOwner, zA = {
|
|
354
354
|
key: !0,
|
|
355
355
|
ref: !0,
|
|
356
356
|
__self: !0,
|
|
357
357
|
__source: !0
|
|
358
|
-
},
|
|
359
|
-
function
|
|
360
|
-
if (
|
|
361
|
-
var
|
|
362
|
-
if (
|
|
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
|
|
365
|
+
return e.ref !== void 0;
|
|
366
366
|
}
|
|
367
|
-
function
|
|
368
|
-
if (
|
|
369
|
-
var
|
|
370
|
-
if (
|
|
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
|
|
373
|
+
return e.key !== void 0;
|
|
374
374
|
}
|
|
375
|
-
function
|
|
376
|
-
typeof
|
|
375
|
+
function Ie(e, c) {
|
|
376
|
+
typeof e.ref == "string" && XA.current;
|
|
377
377
|
}
|
|
378
|
-
function
|
|
378
|
+
function De(e, c) {
|
|
379
379
|
{
|
|
380
|
-
var
|
|
381
|
-
|
|
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
|
-
|
|
384
|
-
get:
|
|
383
|
+
A.isReactWarning = !0, Object.defineProperty(e, "key", {
|
|
384
|
+
get: A,
|
|
385
385
|
configurable: !0
|
|
386
386
|
});
|
|
387
387
|
}
|
|
388
388
|
}
|
|
389
|
-
function
|
|
389
|
+
function kA(e, c) {
|
|
390
390
|
{
|
|
391
|
-
var
|
|
392
|
-
|
|
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
|
-
|
|
395
|
-
get:
|
|
394
|
+
A.isReactWarning = !0, Object.defineProperty(e, "ref", {
|
|
395
|
+
get: A,
|
|
396
396
|
configurable: !0
|
|
397
397
|
});
|
|
398
398
|
}
|
|
399
399
|
}
|
|
400
|
-
var
|
|
401
|
-
var
|
|
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:
|
|
403
|
+
$$typeof: s,
|
|
404
404
|
// Built-in properties that belong on the element
|
|
405
|
-
type:
|
|
406
|
-
key:
|
|
407
|
-
ref:
|
|
408
|
-
props:
|
|
405
|
+
type: e,
|
|
406
|
+
key: c,
|
|
407
|
+
ref: A,
|
|
408
|
+
props: r,
|
|
409
409
|
// Record the component responsible for creating this element.
|
|
410
|
-
_owner:
|
|
410
|
+
_owner: o
|
|
411
411
|
};
|
|
412
|
-
return
|
|
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(
|
|
417
|
+
}), Object.defineProperty(i, "_self", {
|
|
418
418
|
configurable: !1,
|
|
419
419
|
enumerable: !1,
|
|
420
420
|
writable: !1,
|
|
421
|
-
value:
|
|
422
|
-
}), Object.defineProperty(
|
|
421
|
+
value: t
|
|
422
|
+
}), Object.defineProperty(i, "_source", {
|
|
423
423
|
configurable: !1,
|
|
424
424
|
enumerable: !1,
|
|
425
425
|
writable: !1,
|
|
426
|
-
value:
|
|
427
|
-
}), Object.freeze && (Object.freeze(
|
|
426
|
+
value: n
|
|
427
|
+
}), Object.freeze && (Object.freeze(i.props), Object.freeze(i)), i;
|
|
428
428
|
};
|
|
429
|
-
function
|
|
429
|
+
function me(e, c, A, t, n) {
|
|
430
430
|
{
|
|
431
|
-
var
|
|
432
|
-
|
|
433
|
-
for (
|
|
434
|
-
|
|
435
|
-
if (
|
|
436
|
-
var
|
|
437
|
-
for (
|
|
438
|
-
|
|
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 (
|
|
441
|
-
var
|
|
442
|
-
|
|
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
|
|
444
|
+
return he(e, i, a, n, t, XA.current, r);
|
|
445
445
|
}
|
|
446
446
|
}
|
|
447
|
-
var
|
|
448
|
-
function
|
|
449
|
-
if (
|
|
450
|
-
var
|
|
451
|
-
|
|
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
|
-
|
|
453
|
+
ae.setExtraStackFrame(null);
|
|
454
454
|
}
|
|
455
|
-
var
|
|
456
|
-
|
|
457
|
-
function
|
|
458
|
-
return typeof
|
|
455
|
+
var VA;
|
|
456
|
+
VA = !1;
|
|
457
|
+
function $A(e) {
|
|
458
|
+
return typeof e == "object" && e !== null && e.$$typeof === s;
|
|
459
459
|
}
|
|
460
|
-
function
|
|
460
|
+
function ce() {
|
|
461
461
|
{
|
|
462
|
-
if (
|
|
463
|
-
var
|
|
464
|
-
if (
|
|
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 \`` +
|
|
467
|
+
Check the render method of \`` + e + "`.";
|
|
468
468
|
}
|
|
469
469
|
return "";
|
|
470
470
|
}
|
|
471
471
|
}
|
|
472
|
-
function
|
|
472
|
+
function ve(e) {
|
|
473
473
|
return "";
|
|
474
474
|
}
|
|
475
|
-
var
|
|
476
|
-
function
|
|
475
|
+
var ge = {};
|
|
476
|
+
function be(e) {
|
|
477
477
|
{
|
|
478
|
-
var
|
|
479
|
-
if (!
|
|
480
|
-
var
|
|
481
|
-
|
|
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 <` +
|
|
483
|
+
Check the top-level render call using <` + A + ">.");
|
|
484
484
|
}
|
|
485
|
-
return
|
|
485
|
+
return c;
|
|
486
486
|
}
|
|
487
487
|
}
|
|
488
|
-
function
|
|
488
|
+
function ue(e, c) {
|
|
489
489
|
{
|
|
490
|
-
if (!
|
|
490
|
+
if (!e._store || e._store.validated || e.key != null)
|
|
491
491
|
return;
|
|
492
|
-
|
|
493
|
-
var
|
|
494
|
-
if (
|
|
492
|
+
e._store.validated = !0;
|
|
493
|
+
var A = be(c);
|
|
494
|
+
if (ge[A])
|
|
495
495
|
return;
|
|
496
|
-
|
|
497
|
-
var
|
|
498
|
-
|
|
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
|
|
501
|
+
function Be(e, c) {
|
|
502
502
|
{
|
|
503
|
-
if (typeof
|
|
503
|
+
if (typeof e != "object")
|
|
504
504
|
return;
|
|
505
|
-
if (
|
|
506
|
-
for (var
|
|
507
|
-
var
|
|
508
|
-
|
|
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 (
|
|
511
|
-
|
|
512
|
-
else if (
|
|
513
|
-
var
|
|
514
|
-
if (typeof
|
|
515
|
-
for (var
|
|
516
|
-
|
|
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
|
|
520
|
+
function pe(e) {
|
|
521
521
|
{
|
|
522
|
-
var
|
|
523
|
-
if (
|
|
522
|
+
var c = e.type;
|
|
523
|
+
if (c == null || typeof c == "string")
|
|
524
524
|
return;
|
|
525
|
-
var
|
|
526
|
-
if (typeof
|
|
527
|
-
|
|
528
|
-
else if (typeof
|
|
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
|
-
|
|
531
|
-
|
|
530
|
+
c.$$typeof === p))
|
|
531
|
+
A = c.propTypes;
|
|
532
532
|
else
|
|
533
533
|
return;
|
|
534
|
-
if (
|
|
535
|
-
var
|
|
536
|
-
|
|
537
|
-
} else if (
|
|
538
|
-
|
|
539
|
-
var
|
|
540
|
-
|
|
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
|
|
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
|
|
545
|
+
function Fe(e) {
|
|
546
546
|
{
|
|
547
|
-
for (var
|
|
548
|
-
var
|
|
549
|
-
if (
|
|
550
|
-
|
|
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
|
-
|
|
554
|
+
e.ref !== null && (cA(e), S("Invalid attribute `ref` supplied to `React.Fragment`."), cA(null));
|
|
555
555
|
}
|
|
556
556
|
}
|
|
557
|
-
var
|
|
558
|
-
function
|
|
557
|
+
var le = {};
|
|
558
|
+
function de(e, c, A, t, n, o) {
|
|
559
559
|
{
|
|
560
|
-
var
|
|
561
|
-
if (!
|
|
562
|
-
var
|
|
563
|
-
(
|
|
564
|
-
var
|
|
565
|
-
|
|
566
|
-
var
|
|
567
|
-
|
|
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
|
|
570
|
-
if (
|
|
571
|
-
return
|
|
572
|
-
if (
|
|
573
|
-
var
|
|
574
|
-
if (
|
|
575
|
-
if (
|
|
576
|
-
if (
|
|
577
|
-
for (var
|
|
578
|
-
|
|
579
|
-
Object.freeze && Object.freeze(
|
|
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
|
-
|
|
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
|
-
|
|
583
|
+
Be(Q, e);
|
|
584
584
|
}
|
|
585
|
-
if (
|
|
586
|
-
var
|
|
587
|
-
return
|
|
588
|
-
}),
|
|
589
|
-
if (!
|
|
590
|
-
var
|
|
591
|
-
|
|
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} />`,
|
|
596
|
+
<%s key={someKey} {...props} />`, N, F, O, F), le[F + N] = !0;
|
|
597
597
|
}
|
|
598
598
|
}
|
|
599
|
-
return
|
|
599
|
+
return e === u ? Fe(d) : pe(d), d;
|
|
600
600
|
}
|
|
601
601
|
}
|
|
602
|
-
function
|
|
603
|
-
return
|
|
602
|
+
function ye(e, c, A) {
|
|
603
|
+
return de(e, c, A, !0);
|
|
604
604
|
}
|
|
605
|
-
function
|
|
606
|
-
return
|
|
605
|
+
function Ne(e, c, A) {
|
|
606
|
+
return de(e, c, A, !1);
|
|
607
607
|
}
|
|
608
|
-
var
|
|
609
|
-
|
|
610
|
-
})()),
|
|
608
|
+
var hA = Ne, Me = ye;
|
|
609
|
+
ee.Fragment = u, ee.jsx = hA, ee.jsxs = Me;
|
|
610
|
+
})()), ee;
|
|
611
611
|
}
|
|
612
|
-
var
|
|
613
|
-
function
|
|
614
|
-
return
|
|
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
|
|
617
|
-
const
|
|
618
|
-
const
|
|
619
|
-
return
|
|
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
|
|
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(
|
|
629
|
-
if (!
|
|
630
|
-
const
|
|
631
|
-
if (
|
|
632
|
-
const
|
|
633
|
-
if (
|
|
634
|
-
const
|
|
635
|
-
const
|
|
636
|
-
if (!
|
|
637
|
-
const
|
|
638
|
-
return this.blobUrlBySrc.set(
|
|
639
|
-
})().catch((
|
|
640
|
-
this.pendingBySrc.delete(
|
|
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(
|
|
642
|
+
return this.pendingBySrc.set(s, f), f;
|
|
643
643
|
}
|
|
644
644
|
/** Returns a blob URL if available, otherwise the original `src`. */
|
|
645
|
-
resolve(
|
|
646
|
-
return this.blobUrlBySrc.get(
|
|
645
|
+
resolve(s) {
|
|
646
|
+
return this.blobUrlBySrc.get(s) ?? s;
|
|
647
647
|
}
|
|
648
648
|
/** Starts preload in background (non-blocking). */
|
|
649
|
-
warm(
|
|
650
|
-
this.preloadToBlobUrl(
|
|
649
|
+
warm(s) {
|
|
650
|
+
this.preloadToBlobUrl(s);
|
|
651
651
|
}
|
|
652
652
|
/** Convenience: preload all unique action.data.src from editor data. */
|
|
653
|
-
warmFromEditorData(
|
|
654
|
-
const
|
|
655
|
-
for (const
|
|
656
|
-
const
|
|
657
|
-
if (Array.isArray(
|
|
658
|
-
for (const
|
|
659
|
-
const
|
|
660
|
-
typeof
|
|
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
|
|
664
|
-
const
|
|
665
|
-
(
|
|
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
|
|
670
|
-
if (!
|
|
671
|
-
const
|
|
672
|
-
if (
|
|
673
|
-
const
|
|
674
|
-
if (
|
|
675
|
-
return
|
|
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
|
|
677
|
+
class ut {
|
|
678
678
|
howlBySrc = {};
|
|
679
679
|
activeByActionId = {};
|
|
680
|
-
getHowl(
|
|
681
|
-
const
|
|
682
|
-
if (this.howlBySrc[
|
|
683
|
-
const
|
|
684
|
-
src: [
|
|
685
|
-
format:
|
|
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[
|
|
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
|
|
702
|
-
|
|
701
|
+
const s = qe.ctx;
|
|
702
|
+
s && s.state === "suspended" && s.resume();
|
|
703
703
|
} catch {
|
|
704
704
|
}
|
|
705
705
|
}
|
|
706
|
-
warm(
|
|
707
|
-
|
|
706
|
+
warm(s) {
|
|
707
|
+
s && (re.warm(s), this.getHowl(s));
|
|
708
708
|
}
|
|
709
|
-
seekForEngineTime(
|
|
710
|
-
const
|
|
711
|
-
if (!Number.isFinite(
|
|
712
|
-
|
|
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
|
|
716
|
-
|
|
715
|
+
const b = (f - u + v) % m, y = b < 0 ? b + m : b;
|
|
716
|
+
s.seek(y, l);
|
|
717
717
|
}
|
|
718
|
-
start(
|
|
719
|
-
const { actionId:
|
|
720
|
-
if (
|
|
721
|
-
const
|
|
722
|
-
|
|
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
|
-
|
|
724
|
+
K.playing(b.soundId) || K.play(b.soundId);
|
|
725
725
|
} catch {
|
|
726
726
|
}
|
|
727
|
-
|
|
727
|
+
h.isPlaying || this.seekForEngineTime(K, b.soundId, b.startTime, I, b.offset);
|
|
728
728
|
return;
|
|
729
729
|
}
|
|
730
|
-
const
|
|
731
|
-
|
|
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
|
|
734
|
-
if (!
|
|
735
|
-
this.seekForEngineTime(
|
|
733
|
+
const W = ({ time: K }) => {
|
|
734
|
+
if (!h.isPlaying) {
|
|
735
|
+
this.seekForEngineTime(y, p, f, K, m);
|
|
736
736
|
return;
|
|
737
737
|
}
|
|
738
|
-
const
|
|
739
|
-
if (!(
|
|
740
|
-
q =
|
|
738
|
+
const L = performance.now();
|
|
739
|
+
if (!(L - q < 500)) {
|
|
740
|
+
q = L;
|
|
741
741
|
try {
|
|
742
|
-
const
|
|
743
|
-
Number.isFinite(
|
|
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
|
-
},
|
|
748
|
-
|
|
747
|
+
}, uA = ({ rate: K }) => {
|
|
748
|
+
y.rate(K, p);
|
|
749
749
|
};
|
|
750
|
-
|
|
751
|
-
src:
|
|
752
|
-
startTime:
|
|
753
|
-
offset:
|
|
754
|
-
soundId:
|
|
755
|
-
engine:
|
|
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:
|
|
758
|
-
rate:
|
|
757
|
+
time: W,
|
|
758
|
+
rate: uA
|
|
759
759
|
};
|
|
760
760
|
}
|
|
761
|
-
stop(
|
|
762
|
-
const { actionId:
|
|
763
|
-
if (!
|
|
764
|
-
const
|
|
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
|
-
|
|
766
|
+
f.stop(u.soundId);
|
|
767
767
|
} catch {
|
|
768
768
|
}
|
|
769
|
-
|
|
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
|
|
773
|
-
class
|
|
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(
|
|
783
|
-
this.videoEl =
|
|
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(
|
|
786
|
-
this.videoEl && (this.videoEl.style.opacity =
|
|
785
|
+
setActive(s) {
|
|
786
|
+
this.videoEl && (this.videoEl.style.opacity = s ? "1" : "0");
|
|
787
787
|
}
|
|
788
|
-
bindEngine(
|
|
789
|
-
this.unbindEngine(), this.boundEngine =
|
|
788
|
+
bindEngine(s, l) {
|
|
789
|
+
this.unbindEngine(), this.boundEngine = s, this.boundActionStart = l, this.tickFromVideo();
|
|
790
790
|
}
|
|
791
791
|
unbindEngine() {
|
|
792
|
-
const
|
|
793
|
-
if (this.vfcHandle != null &&
|
|
792
|
+
const s = this.videoEl;
|
|
793
|
+
if (this.vfcHandle != null && s?.cancelVideoFrameCallback)
|
|
794
794
|
try {
|
|
795
|
-
|
|
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
|
|
803
|
-
Math.abs(this.boundEngine.getTime() -
|
|
804
|
-
const
|
|
805
|
-
|
|
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(
|
|
808
|
-
if (!this.videoEl || !
|
|
809
|
-
const
|
|
810
|
-
if (!((this.videoEl.currentSrc || this.videoEl.getAttribute("src") || "") ===
|
|
811
|
-
this.currentSrc =
|
|
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(
|
|
819
|
-
|
|
818
|
+
warm(s) {
|
|
819
|
+
s && re.warm(s);
|
|
820
820
|
}
|
|
821
|
-
setRate(
|
|
822
|
-
this.videoEl && this.lastRate !==
|
|
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(
|
|
828
|
+
seek(s, l) {
|
|
829
829
|
if (this.videoEl)
|
|
830
830
|
try {
|
|
831
|
-
const
|
|
832
|
-
if (!
|
|
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
|
|
835
|
-
Number.isFinite(
|
|
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
|
|
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:
|
|
856
|
-
if (
|
|
857
|
-
const { src:
|
|
858
|
-
|
|
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:
|
|
862
|
-
if (
|
|
863
|
-
const { src:
|
|
864
|
-
|
|
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:
|
|
868
|
-
|
|
867
|
+
leave: ({ action: g }) => {
|
|
868
|
+
rA.stop({ actionId: g.id });
|
|
869
869
|
},
|
|
870
|
-
stop: ({ action:
|
|
871
|
-
|
|
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:
|
|
880
|
-
if (
|
|
881
|
-
const { src:
|
|
882
|
-
|
|
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:
|
|
886
|
-
if (
|
|
887
|
-
const { src:
|
|
888
|
-
|
|
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:
|
|
892
|
-
|
|
891
|
+
leave: ({ action: g }) => {
|
|
892
|
+
rA.stop({ actionId: g.id });
|
|
893
893
|
},
|
|
894
|
-
stop: ({ action:
|
|
895
|
-
|
|
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:
|
|
904
|
-
const { src:
|
|
905
|
-
|
|
906
|
-
const
|
|
907
|
-
|
|
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:
|
|
910
|
-
const { src:
|
|
911
|
-
|
|
912
|
-
const
|
|
913
|
-
|
|
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:
|
|
916
|
-
const { src:
|
|
917
|
-
if (
|
|
918
|
-
const
|
|
919
|
-
|
|
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
|
-
|
|
923
|
+
G.pause(), G.unbindEngine(), G.setActive(!1);
|
|
924
924
|
},
|
|
925
925
|
stop: () => {
|
|
926
|
-
|
|
926
|
+
G.pause(), G.unbindEngine(), G.setActive(!1);
|
|
927
927
|
}
|
|
928
928
|
}
|
|
929
929
|
}
|
|
930
|
-
},
|
|
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:
|
|
971
|
-
autoScrollWhenPlay:
|
|
972
|
-
editorData:
|
|
973
|
-
selectedActionId:
|
|
974
|
-
onDeleteSelectedClip:
|
|
975
|
-
onSplitSelectedClip:
|
|
976
|
-
canUndo:
|
|
977
|
-
canRedo:
|
|
978
|
-
onUndo:
|
|
979
|
-
onRedo:
|
|
969
|
+
], ft = "", Qt = "", Et = "", Ct = "", wt = "", It = "", { Option: Dt } = Ye, ht = [0.2, 0.5, 1, 1.5, 2], mt = ({
|
|
970
|
+
timelineState: g,
|
|
971
|
+
autoScrollWhenPlay: s,
|
|
972
|
+
editorData: l,
|
|
973
|
+
selectedActionId: u,
|
|
974
|
+
onDeleteSelectedClip: f,
|
|
975
|
+
onSplitSelectedClip: I,
|
|
976
|
+
canUndo: h,
|
|
977
|
+
canRedo: v,
|
|
978
|
+
onUndo: m,
|
|
979
|
+
onRedo: b
|
|
980
980
|
}) => {
|
|
981
|
-
const [
|
|
982
|
-
if (!
|
|
983
|
-
const
|
|
984
|
-
for (const
|
|
985
|
-
const
|
|
986
|
-
if (Array.isArray(
|
|
987
|
-
for (const
|
|
988
|
-
if (String(
|
|
989
|
-
const
|
|
990
|
-
return !Number.isFinite(
|
|
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
|
-
})(),
|
|
995
|
-
const
|
|
996
|
-
for (const
|
|
997
|
-
const
|
|
998
|
-
if (Array.isArray(
|
|
999
|
-
for (const
|
|
1000
|
-
if (
|
|
1001
|
-
const
|
|
1002
|
-
if (!(!Number.isFinite(
|
|
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
|
-
},
|
|
1008
|
-
|
|
1007
|
+
}, qA = (w) => {
|
|
1008
|
+
JA(w) || (G.pause(), G.unbindEngine(), G.setActive(!1));
|
|
1009
1009
|
};
|
|
1010
|
-
|
|
1011
|
-
if (!
|
|
1012
|
-
const
|
|
1013
|
-
|
|
1014
|
-
},
|
|
1015
|
-
const
|
|
1016
|
-
if (!(
|
|
1017
|
-
const
|
|
1018
|
-
|
|
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
|
|
1022
|
-
|
|
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
|
-
}, [
|
|
1025
|
-
const
|
|
1026
|
-
|
|
1027
|
-
},
|
|
1028
|
-
|
|
1029
|
-
},
|
|
1030
|
-
const
|
|
1031
|
-
return /* @__PURE__ */
|
|
1032
|
-
},
|
|
1033
|
-
const
|
|
1034
|
-
for (const
|
|
1035
|
-
const
|
|
1036
|
-
if (Array.isArray(
|
|
1037
|
-
for (const
|
|
1038
|
-
const
|
|
1039
|
-
if (!
|
|
1040
|
-
const
|
|
1041
|
-
|
|
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
|
|
1045
|
-
},
|
|
1046
|
-
const
|
|
1047
|
-
|
|
1048
|
-
},
|
|
1049
|
-
if (!
|
|
1050
|
-
|
|
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
|
|
1053
|
-
|
|
1054
|
-
for (const
|
|
1055
|
-
const
|
|
1056
|
-
if (!
|
|
1057
|
-
const
|
|
1058
|
-
|
|
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
|
|
1060
|
+
const R = await fetch("/export", {
|
|
1061
1061
|
method: "POST",
|
|
1062
|
-
body:
|
|
1062
|
+
body: x
|
|
1063
1063
|
});
|
|
1064
|
-
if (!
|
|
1065
|
-
const
|
|
1066
|
-
throw new Error(
|
|
1064
|
+
if (!R.ok) {
|
|
1065
|
+
const H = await R.text().catch(() => "");
|
|
1066
|
+
throw new Error(H || `Export failed (${R.status})`);
|
|
1067
1067
|
}
|
|
1068
|
-
const
|
|
1069
|
-
|
|
1068
|
+
const P = await R.blob();
|
|
1069
|
+
UA(P, "export.mp4");
|
|
1070
1070
|
} finally {
|
|
1071
|
-
|
|
1071
|
+
K(!1);
|
|
1072
1072
|
}
|
|
1073
1073
|
}
|
|
1074
1074
|
};
|
|
1075
|
-
return /* @__PURE__ */
|
|
1076
|
-
/* @__PURE__ */
|
|
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":
|
|
1082
|
+
"aria-label": y ? "Pause" : "Play",
|
|
1083
1083
|
onClick: () => {
|
|
1084
|
-
Date.now() -
|
|
1084
|
+
Date.now() - Z.current < 450 || SA();
|
|
1085
1085
|
},
|
|
1086
|
-
onPointerUp: (
|
|
1087
|
-
|
|
1086
|
+
onPointerUp: (w) => {
|
|
1087
|
+
w.pointerType !== "mouse" && (Z.current = Date.now(), SA());
|
|
1088
1088
|
},
|
|
1089
|
-
children: /* @__PURE__ */
|
|
1089
|
+
children: /* @__PURE__ */ E.jsx(
|
|
1090
1090
|
"img",
|
|
1091
1091
|
{
|
|
1092
|
-
src:
|
|
1092
|
+
src: y ? Qt : ft,
|
|
1093
1093
|
alt: "",
|
|
1094
1094
|
draggable: !1
|
|
1095
1095
|
}
|
|
1096
1096
|
)
|
|
1097
1097
|
}
|
|
1098
1098
|
),
|
|
1099
|
-
/* @__PURE__ */
|
|
1100
|
-
/* @__PURE__ */
|
|
1101
|
-
/* @__PURE__ */
|
|
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: !
|
|
1106
|
+
disabled: !h,
|
|
1107
1107
|
"aria-label": "Undo",
|
|
1108
1108
|
onClick: () => {
|
|
1109
|
-
Date.now() -
|
|
1109
|
+
Date.now() - CA.current < 450 || h && m();
|
|
1110
1110
|
},
|
|
1111
|
-
onPointerUp: (
|
|
1112
|
-
|
|
1111
|
+
onPointerUp: (w) => {
|
|
1112
|
+
w.pointerType !== "mouse" && (CA.current = Date.now(), h && m());
|
|
1113
1113
|
},
|
|
1114
|
-
children: /* @__PURE__ */
|
|
1114
|
+
children: /* @__PURE__ */ E.jsx("img", { src: Et, alt: "", draggable: !1 })
|
|
1115
1115
|
}
|
|
1116
1116
|
),
|
|
1117
|
-
/* @__PURE__ */
|
|
1117
|
+
/* @__PURE__ */ E.jsx(
|
|
1118
1118
|
"button",
|
|
1119
1119
|
{
|
|
1120
1120
|
type: "button",
|
|
1121
1121
|
className: "history-tool",
|
|
1122
|
-
disabled: !
|
|
1122
|
+
disabled: !v,
|
|
1123
1123
|
"aria-label": "Redo",
|
|
1124
1124
|
onClick: () => {
|
|
1125
|
-
Date.now() -
|
|
1125
|
+
Date.now() - iA.current < 450 || v && b();
|
|
1126
1126
|
},
|
|
1127
|
-
onPointerUp: (
|
|
1128
|
-
|
|
1127
|
+
onPointerUp: (w) => {
|
|
1128
|
+
w.pointerType !== "mouse" && (iA.current = Date.now(), v && b());
|
|
1129
1129
|
},
|
|
1130
|
-
children: /* @__PURE__ */
|
|
1130
|
+
children: /* @__PURE__ */ E.jsx("img", { src: Ct, alt: "", draggable: !1 })
|
|
1131
1131
|
}
|
|
1132
1132
|
)
|
|
1133
1133
|
] }),
|
|
1134
|
-
/* @__PURE__ */
|
|
1135
|
-
/* @__PURE__ */
|
|
1136
|
-
/* @__PURE__ */
|
|
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: !
|
|
1141
|
+
disabled: !lA,
|
|
1142
1142
|
"aria-label": "Delete selected clip",
|
|
1143
1143
|
onClick: () => {
|
|
1144
|
-
Date.now() -
|
|
1144
|
+
Date.now() - S.current < 450 || lA && f();
|
|
1145
1145
|
},
|
|
1146
|
-
onPointerUp: (
|
|
1147
|
-
|
|
1146
|
+
onPointerUp: (w) => {
|
|
1147
|
+
w.pointerType !== "mouse" && (S.current = Date.now(), lA && f());
|
|
1148
1148
|
},
|
|
1149
|
-
children: /* @__PURE__ */
|
|
1149
|
+
children: /* @__PURE__ */ E.jsx("img", { src: wt, alt: "", draggable: !1 })
|
|
1150
1150
|
}
|
|
1151
1151
|
),
|
|
1152
|
-
/* @__PURE__ */
|
|
1152
|
+
/* @__PURE__ */ E.jsx(
|
|
1153
1153
|
"button",
|
|
1154
1154
|
{
|
|
1155
1155
|
type: "button",
|
|
1156
1156
|
className: "clip-tool clip-tool-split",
|
|
1157
|
-
disabled: !
|
|
1157
|
+
disabled: !yA,
|
|
1158
1158
|
"aria-label": "Split selected clip at cursor",
|
|
1159
1159
|
onClick: () => {
|
|
1160
|
-
Date.now() -
|
|
1160
|
+
Date.now() - BA.current < 450 || yA && I();
|
|
1161
1161
|
},
|
|
1162
|
-
onPointerUp: (
|
|
1163
|
-
|
|
1162
|
+
onPointerUp: (w) => {
|
|
1163
|
+
w.pointerType !== "mouse" && (BA.current = Date.now(), yA && I());
|
|
1164
1164
|
},
|
|
1165
|
-
children: /* @__PURE__ */
|
|
1165
|
+
children: /* @__PURE__ */ E.jsx("img", { src: It, alt: "", draggable: !1 })
|
|
1166
1166
|
}
|
|
1167
1167
|
)
|
|
1168
1168
|
] }),
|
|
1169
|
-
/* @__PURE__ */
|
|
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
|
|
1173
|
-
const
|
|
1174
|
-
(navigator.maxTouchPoints ?? 0) > 0, [
|
|
1175
|
-
return
|
|
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
|
|
1178
|
-
return
|
|
1179
|
-
}, []),
|
|
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
|
|
1182
|
-
/* @__PURE__ */
|
|
1183
|
-
|
|
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:
|
|
1187
|
+
src: g.src,
|
|
1188
1188
|
muted: !0,
|
|
1189
1189
|
preload: "metadata",
|
|
1190
1190
|
draggable: !1,
|
|
1191
|
-
onDragStart: (
|
|
1191
|
+
onDragStart: (u) => u.preventDefault(),
|
|
1192
1192
|
playsInline: !0
|
|
1193
1193
|
}
|
|
1194
|
-
) : /* @__PURE__ */
|
|
1194
|
+
) : /* @__PURE__ */ E.jsx(
|
|
1195
1195
|
"audio",
|
|
1196
1196
|
{
|
|
1197
1197
|
className: "footage-audio",
|
|
1198
|
-
src:
|
|
1198
|
+
src: g.src,
|
|
1199
1199
|
controls: !0,
|
|
1200
1200
|
preload: "metadata",
|
|
1201
1201
|
draggable: !1,
|
|
1202
|
-
onDragStart: (
|
|
1202
|
+
onDragStart: (u) => u.preventDefault()
|
|
1203
1203
|
}
|
|
1204
1204
|
),
|
|
1205
|
-
/* @__PURE__ */
|
|
1206
|
-
] }),
|
|
1207
|
-
const { attributes:
|
|
1208
|
-
id: `footage-${
|
|
1209
|
-
data: { item:
|
|
1210
|
-
}),
|
|
1211
|
-
transform: `translate3d(${
|
|
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__ */
|
|
1214
|
-
},
|
|
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
|
|
1217
|
-
return decodeURIComponent(
|
|
1216
|
+
const l = String(g ?? "").split("/").pop() || "";
|
|
1217
|
+
return decodeURIComponent(l.split("?")[0].split("#")[0]) || `Footage ${s + 1}`;
|
|
1218
1218
|
} catch {
|
|
1219
|
-
return `Footage ${
|
|
1219
|
+
return `Footage ${s + 1}`;
|
|
1220
1220
|
}
|
|
1221
|
-
},
|
|
1222
|
-
const [
|
|
1223
|
-
const
|
|
1224
|
-
return
|
|
1225
|
-
id: `url-${
|
|
1226
|
-
kind:
|
|
1227
|
-
name:
|
|
1228
|
-
src:
|
|
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
|
-
}, [
|
|
1232
|
-
if (
|
|
1233
|
-
if (
|
|
1234
|
-
let
|
|
1235
|
-
for (const
|
|
1236
|
-
const
|
|
1237
|
-
|
|
1238
|
-
}
|
|
1239
|
-
return
|
|
1240
|
-
},
|
|
1241
|
-
|
|
1242
|
-
|
|
1243
|
-
}, [
|
|
1244
|
-
|
|
1245
|
-
}, [
|
|
1246
|
-
const
|
|
1247
|
-
if (!
|
|
1248
|
-
const
|
|
1249
|
-
const
|
|
1250
|
-
if (!
|
|
1251
|
-
const
|
|
1252
|
-
|
|
1253
|
-
},
|
|
1254
|
-
return window.addEventListener("resize",
|
|
1255
|
-
cancelAnimationFrame(
|
|
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
|
-
}, [
|
|
1258
|
-
const
|
|
1259
|
-
const
|
|
1260
|
-
if (!
|
|
1261
|
-
const
|
|
1262
|
-
return
|
|
1263
|
-
},
|
|
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
|
-
}),
|
|
1273
|
-
const
|
|
1274
|
-
return `${String(
|
|
1275
|
-
}).join("||"),
|
|
1276
|
-
const
|
|
1277
|
-
|
|
1278
|
-
const
|
|
1279
|
-
return
|
|
1280
|
-
}),
|
|
1281
|
-
},
|
|
1282
|
-
const
|
|
1283
|
-
for (const
|
|
1284
|
-
if (!(!
|
|
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
|
-
},
|
|
1288
|
-
for (let
|
|
1289
|
-
const
|
|
1290
|
-
for (let
|
|
1291
|
-
const
|
|
1292
|
-
if (String(
|
|
1293
|
-
return { rowIndex:
|
|
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
|
-
},
|
|
1298
|
-
const
|
|
1299
|
-
if (!
|
|
1300
|
-
for (let
|
|
1301
|
-
const
|
|
1302
|
-
for (let
|
|
1303
|
-
const
|
|
1304
|
-
if (
|
|
1305
|
-
return { rowIndex:
|
|
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
|
-
},
|
|
1310
|
-
const
|
|
1311
|
-
if (!
|
|
1312
|
-
const
|
|
1313
|
-
if (!
|
|
1314
|
-
const
|
|
1315
|
-
if (!Number.isFinite(
|
|
1316
|
-
const
|
|
1317
|
-
return
|
|
1318
|
-
},
|
|
1319
|
-
if (!Number.isFinite(
|
|
1320
|
-
const
|
|
1321
|
-
if (!
|
|
1322
|
-
const
|
|
1323
|
-
if (!
|
|
1324
|
-
const
|
|
1325
|
-
|
|
1326
|
-
const
|
|
1327
|
-
return
|
|
1328
|
-
},
|
|
1329
|
-
if (!Number.isFinite(
|
|
1330
|
-
const
|
|
1331
|
-
if (!
|
|
1332
|
-
const
|
|
1333
|
-
if (
|
|
1334
|
-
const
|
|
1335
|
-
return
|
|
1336
|
-
},
|
|
1337
|
-
const
|
|
1338
|
-
return Number.isFinite(
|
|
1339
|
-
},
|
|
1340
|
-
const
|
|
1341
|
-
if (!Number.isFinite(
|
|
1342
|
-
return { start:
|
|
1343
|
-
const
|
|
1344
|
-
if (
|
|
1345
|
-
if ((
|
|
1346
|
-
return
|
|
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 (
|
|
1349
|
-
return { start:
|
|
1350
|
-
|
|
1351
|
-
}
|
|
1352
|
-
const
|
|
1353
|
-
if (
|
|
1354
|
-
const
|
|
1355
|
-
return { start: Math.max(0,
|
|
1356
|
-
}
|
|
1357
|
-
const
|
|
1358
|
-
return { start: Math.max(0,
|
|
1359
|
-
},
|
|
1360
|
-
const
|
|
1361
|
-
if (
|
|
1362
|
-
if (
|
|
1363
|
-
return
|
|
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 (
|
|
1366
|
-
return { start:
|
|
1367
|
-
|
|
1368
|
-
}
|
|
1369
|
-
if (
|
|
1370
|
-
const
|
|
1371
|
-
return { start:
|
|
1372
|
-
}
|
|
1373
|
-
const
|
|
1374
|
-
return { start: Math.max(0,
|
|
1375
|
-
},
|
|
1376
|
-
const
|
|
1377
|
-
let
|
|
1378
|
-
const
|
|
1379
|
-
|
|
1380
|
-
|
|
1381
|
-
const
|
|
1382
|
-
for (;
|
|
1383
|
-
const
|
|
1384
|
-
const
|
|
1385
|
-
for (const
|
|
1386
|
-
const
|
|
1387
|
-
for (const
|
|
1388
|
-
const
|
|
1389
|
-
!Number.isFinite(
|
|
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
|
-
|
|
1393
|
-
for (const
|
|
1394
|
-
|
|
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 (
|
|
1397
|
-
const
|
|
1398
|
-
|
|
1399
|
-
const
|
|
1400
|
-
|
|
1401
|
-
...
|
|
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:
|
|
1405
|
-
end:
|
|
1403
|
+
id: Y,
|
|
1404
|
+
start: r,
|
|
1405
|
+
end: i,
|
|
1406
1406
|
effectId: "effect1",
|
|
1407
|
-
data: { src:
|
|
1407
|
+
data: { src: A.src, previewSrc: A.previewSrc, name: A.name, linkId: M }
|
|
1408
1408
|
}
|
|
1409
|
-
],
|
|
1410
|
-
...
|
|
1409
|
+
], d[O].actions = [
|
|
1410
|
+
...d[O].actions ?? [],
|
|
1411
1411
|
{
|
|
1412
|
-
id:
|
|
1413
|
-
start:
|
|
1414
|
-
end:
|
|
1412
|
+
id: $,
|
|
1413
|
+
start: r,
|
|
1414
|
+
end: i,
|
|
1415
1415
|
effectId: "effect2",
|
|
1416
|
-
data: { src:
|
|
1416
|
+
data: { src: A.src, name: A.name, linkId: M }
|
|
1417
1417
|
}
|
|
1418
1418
|
];
|
|
1419
1419
|
} else {
|
|
1420
|
-
const
|
|
1421
|
-
|
|
1422
|
-
...
|
|
1420
|
+
const N = F;
|
|
1421
|
+
D([N]), d[N].actions = [
|
|
1422
|
+
...d[N].actions ?? [],
|
|
1423
1423
|
{
|
|
1424
|
-
id: `audio-${
|
|
1425
|
-
start:
|
|
1426
|
-
end:
|
|
1424
|
+
id: `audio-${fA()}`,
|
|
1425
|
+
start: r,
|
|
1426
|
+
end: i,
|
|
1427
1427
|
effectId: "effect0",
|
|
1428
|
-
data: { src:
|
|
1428
|
+
data: { src: A.src, name: A.name }
|
|
1429
1429
|
}
|
|
1430
1430
|
];
|
|
1431
1431
|
}
|
|
1432
|
-
return
|
|
1432
|
+
return d;
|
|
1433
1433
|
});
|
|
1434
|
-
},
|
|
1435
|
-
const
|
|
1436
|
-
return
|
|
1437
|
-
},
|
|
1438
|
-
const
|
|
1439
|
-
if (!
|
|
1440
|
-
const
|
|
1441
|
-
return Math.max(0,
|
|
1442
|
-
},
|
|
1443
|
-
const
|
|
1444
|
-
return Number.isFinite(
|
|
1445
|
-
},
|
|
1446
|
-
const
|
|
1447
|
-
let
|
|
1448
|
-
const
|
|
1449
|
-
if (
|
|
1450
|
-
const
|
|
1451
|
-
|
|
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
|
-
|
|
1454
|
-
const
|
|
1455
|
-
for (const
|
|
1456
|
-
const
|
|
1457
|
-
for (const
|
|
1458
|
-
const
|
|
1459
|
-
!Number.isFinite(
|
|
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
|
-
|
|
1463
|
-
for (const
|
|
1464
|
-
|
|
1465
|
-
return Math.max(0,
|
|
1466
|
-
},
|
|
1467
|
-
const
|
|
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
|
|
1470
|
-
if (
|
|
1471
|
-
const
|
|
1472
|
-
if (
|
|
1473
|
-
const
|
|
1474
|
-
|
|
1475
|
-
|
|
1476
|
-
|
|
1477
|
-
|
|
1478
|
-
|
|
1479
|
-
|
|
1480
|
-
|
|
1481
|
-
|
|
1482
|
-
|
|
1483
|
-
|
|
1484
|
-
|
|
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
|
-
},
|
|
1490
|
-
if (
|
|
1491
|
-
|
|
1492
|
-
const
|
|
1493
|
-
const
|
|
1494
|
-
if (!
|
|
1495
|
-
const
|
|
1496
|
-
|
|
1497
|
-
},
|
|
1498
|
-
|
|
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
|
-
},
|
|
1507
|
+
}, _.current = { actionId: null, edge: null };
|
|
1508
1508
|
};
|
|
1509
|
-
window.addEventListener("pointermove",
|
|
1510
|
-
window.removeEventListener("pointermove",
|
|
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
|
-
},
|
|
1513
|
-
const
|
|
1514
|
-
|
|
1515
|
-
},
|
|
1516
|
-
...
|
|
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: (
|
|
1519
|
-
})),
|
|
1520
|
-
const
|
|
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
|
-
...
|
|
1523
|
-
classNames:
|
|
1524
|
-
selected:
|
|
1525
|
-
actions: (
|
|
1526
|
-
...
|
|
1527
|
-
selected:
|
|
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
|
-
}), [
|
|
1531
|
-
if (!
|
|
1532
|
-
const
|
|
1533
|
-
|
|
1534
|
-
|
|
1535
|
-
let
|
|
1536
|
-
for (const
|
|
1537
|
-
const
|
|
1538
|
-
for (const
|
|
1539
|
-
if (String(
|
|
1540
|
-
const
|
|
1541
|
-
|
|
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 (
|
|
1544
|
+
if (n != null) break;
|
|
1545
1545
|
}
|
|
1546
|
-
return
|
|
1547
|
-
...
|
|
1548
|
-
actions: (
|
|
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
|
-
}),
|
|
1551
|
-
},
|
|
1552
|
-
if (!
|
|
1553
|
-
const
|
|
1554
|
-
if (
|
|
1555
|
-
const
|
|
1556
|
-
Number.isFinite(
|
|
1557
|
-
let
|
|
1558
|
-
for (let
|
|
1559
|
-
const
|
|
1560
|
-
for (let
|
|
1561
|
-
const
|
|
1562
|
-
if (String(
|
|
1563
|
-
|
|
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 (
|
|
1567
|
+
if (a) break;
|
|
1568
1568
|
}
|
|
1569
|
-
if (!
|
|
1570
|
-
const
|
|
1571
|
-
let
|
|
1572
|
-
if (
|
|
1573
|
-
for (let
|
|
1574
|
-
const
|
|
1575
|
-
for (let
|
|
1576
|
-
const
|
|
1577
|
-
if (String(
|
|
1578
|
-
|
|
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 (
|
|
1582
|
+
if (C) break;
|
|
1583
1583
|
}
|
|
1584
|
-
const
|
|
1585
|
-
if (!Number.isFinite(
|
|
1586
|
-
|
|
1587
|
-
const
|
|
1588
|
-
...
|
|
1589
|
-
start:
|
|
1590
|
-
end:
|
|
1591
|
-
id:
|
|
1592
|
-
data: { ...
|
|
1593
|
-
},
|
|
1594
|
-
...
|
|
1595
|
-
start:
|
|
1596
|
-
end:
|
|
1597
|
-
id:
|
|
1598
|
-
data: { ...
|
|
1599
|
-
},
|
|
1600
|
-
if (
|
|
1601
|
-
const
|
|
1602
|
-
if (Number.isFinite(
|
|
1603
|
-
const
|
|
1604
|
-
...
|
|
1605
|
-
start:
|
|
1606
|
-
end:
|
|
1607
|
-
id:
|
|
1608
|
-
data: { ...
|
|
1609
|
-
},
|
|
1610
|
-
...
|
|
1611
|
-
start:
|
|
1612
|
-
end:
|
|
1613
|
-
id:
|
|
1614
|
-
data: { ...
|
|
1615
|
-
},
|
|
1616
|
-
|
|
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
|
|
1619
|
+
return bA;
|
|
1620
1620
|
}));
|
|
1621
|
-
},
|
|
1622
|
-
const
|
|
1623
|
-
|
|
1624
|
-
if (
|
|
1625
|
-
const
|
|
1626
|
-
return
|
|
1627
|
-
}),
|
|
1628
|
-
const
|
|
1629
|
-
|
|
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
|
-
},
|
|
1632
|
-
const
|
|
1633
|
-
|
|
1634
|
-
if (
|
|
1635
|
-
const
|
|
1636
|
-
return
|
|
1637
|
-
const
|
|
1638
|
-
return
|
|
1639
|
-
}),
|
|
1640
|
-
}),
|
|
1641
|
-
const
|
|
1642
|
-
|
|
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
|
-
},
|
|
1645
|
-
|
|
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
|
-
|
|
1648
|
-
), { setNodeRef:
|
|
1649
|
-
const
|
|
1650
|
-
|
|
1651
|
-
const
|
|
1652
|
-
if (
|
|
1653
|
-
const
|
|
1654
|
-
|
|
1655
|
-
const
|
|
1656
|
-
|
|
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
|
-
|
|
1659
|
-
const
|
|
1660
|
-
|
|
1661
|
-
},
|
|
1662
|
-
const
|
|
1663
|
-
!
|
|
1664
|
-
const
|
|
1665
|
-
if (!
|
|
1666
|
-
|
|
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
|
|
1670
|
-
|
|
1671
|
-
const
|
|
1672
|
-
|
|
1673
|
-
const
|
|
1674
|
-
|
|
1675
|
-
},
|
|
1676
|
-
const
|
|
1677
|
-
|
|
1678
|
-
const
|
|
1679
|
-
if (
|
|
1680
|
-
const
|
|
1681
|
-
|
|
1682
|
-
}
|
|
1683
|
-
|
|
1684
|
-
},
|
|
1685
|
-
|
|
1686
|
-
},
|
|
1687
|
-
if (!
|
|
1688
|
-
const
|
|
1689
|
-
if (!
|
|
1690
|
-
const
|
|
1691
|
-
if (
|
|
1692
|
-
const
|
|
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:
|
|
1695
|
-
desiredStart:
|
|
1696
|
-
start:
|
|
1697
|
-
end:
|
|
1698
|
-
duration:
|
|
1699
|
-
kind:
|
|
1694
|
+
laneRow: n,
|
|
1695
|
+
desiredStart: o,
|
|
1696
|
+
start: r,
|
|
1697
|
+
end: r + i,
|
|
1698
|
+
duration: i,
|
|
1699
|
+
kind: L.kind
|
|
1700
1700
|
};
|
|
1701
|
-
}, [
|
|
1702
|
-
if (!
|
|
1703
|
-
if (!!
|
|
1704
|
-
|
|
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
|
-
|
|
1706
|
+
A.currentTarget.setPointerCapture(A.pointerId);
|
|
1707
1707
|
} catch {
|
|
1708
1708
|
}
|
|
1709
|
-
|
|
1709
|
+
A.preventDefault();
|
|
1710
1710
|
return;
|
|
1711
1711
|
}
|
|
1712
|
-
|
|
1713
|
-
},
|
|
1714
|
-
if (!
|
|
1715
|
-
const
|
|
1716
|
-
|
|
1717
|
-
},
|
|
1718
|
-
if (!
|
|
1719
|
-
if (
|
|
1720
|
-
|
|
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
|
-
|
|
1722
|
+
A.currentTarget.releasePointerCapture(A.pointerId);
|
|
1723
1723
|
} catch {
|
|
1724
1724
|
}
|
|
1725
|
-
|
|
1725
|
+
A.preventDefault();
|
|
1726
1726
|
return;
|
|
1727
1727
|
}
|
|
1728
|
-
const
|
|
1729
|
-
|
|
1730
|
-
const
|
|
1731
|
-
if (
|
|
1732
|
-
const
|
|
1733
|
-
if (
|
|
1734
|
-
|
|
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
|
|
1738
|
-
|
|
1737
|
+
const d = kA(A.clientX);
|
|
1738
|
+
f(null), p.current && p.current.setTime(d);
|
|
1739
1739
|
};
|
|
1740
|
-
return /* @__PURE__ */
|
|
1741
|
-
|
|
1740
|
+
return /* @__PURE__ */ E.jsx(
|
|
1741
|
+
_e,
|
|
1742
1742
|
{
|
|
1743
|
-
sensors:
|
|
1744
|
-
collisionDetection:
|
|
1745
|
-
onDragStart:
|
|
1746
|
-
onDragMove:
|
|
1747
|
-
onDragEnd:
|
|
1748
|
-
onDragCancel:
|
|
1749
|
-
children: /* @__PURE__ */
|
|
1750
|
-
/* @__PURE__ */
|
|
1751
|
-
|
|
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:
|
|
1754
|
-
hint:
|
|
1753
|
+
item: A,
|
|
1754
|
+
hint: y ? "Press-hold, then drag into timeline" : "Drag into timeline"
|
|
1755
1755
|
},
|
|
1756
|
-
|
|
1756
|
+
A.id
|
|
1757
1757
|
)) }) }),
|
|
1758
|
-
/* @__PURE__ */
|
|
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: (
|
|
1771
|
-
ref: (
|
|
1770
|
+
onContextMenu: (A) => A.preventDefault(),
|
|
1771
|
+
ref: (A) => G.attach(A)
|
|
1772
1772
|
}
|
|
1773
1773
|
) }),
|
|
1774
|
-
/* @__PURE__ */
|
|
1775
|
-
|
|
1774
|
+
/* @__PURE__ */ E.jsx(
|
|
1775
|
+
mt,
|
|
1776
1776
|
{
|
|
1777
|
-
timelineState:
|
|
1778
|
-
autoScrollWhenPlay:
|
|
1779
|
-
editorData:
|
|
1780
|
-
selectedActionId:
|
|
1781
|
-
onDeleteSelectedClip:
|
|
1782
|
-
onSplitSelectedClip:
|
|
1783
|
-
canUndo:
|
|
1784
|
-
canRedo:
|
|
1785
|
-
onUndo:
|
|
1786
|
-
onRedo:
|
|
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__ */
|
|
1789
|
+
/* @__PURE__ */ E.jsxs(
|
|
1790
1790
|
"div",
|
|
1791
1791
|
{
|
|
1792
|
-
className: `timeline-drop${
|
|
1793
|
-
ref: (
|
|
1794
|
-
|
|
1792
|
+
className: `timeline-drop${Fe ? " is-over" : ""}`,
|
|
1793
|
+
ref: (A) => {
|
|
1794
|
+
W.current = A, pe(A);
|
|
1795
1795
|
},
|
|
1796
|
-
onPointerDown:
|
|
1797
|
-
onPointerMove:
|
|
1798
|
-
onPointerUp:
|
|
1796
|
+
onPointerDown: Me,
|
|
1797
|
+
onPointerMove: e,
|
|
1798
|
+
onPointerUp: c,
|
|
1799
1799
|
children: [
|
|
1800
|
-
/* @__PURE__ */
|
|
1800
|
+
/* @__PURE__ */ E.jsx(
|
|
1801
1801
|
"div",
|
|
1802
1802
|
{
|
|
1803
1803
|
className: "timeline-lane-labels",
|
|
1804
1804
|
style: {
|
|
1805
|
-
top:
|
|
1806
|
-
transform: `translateY(${-
|
|
1807
|
-
height:
|
|
1805
|
+
top: JA,
|
|
1806
|
+
transform: `translateY(${-lA}px)`,
|
|
1807
|
+
height: H * IA.length
|
|
1808
1808
|
},
|
|
1809
|
-
children:
|
|
1809
|
+
children: IA.map((A, t) => /* @__PURE__ */ E.jsx(
|
|
1810
1810
|
"div",
|
|
1811
1811
|
{
|
|
1812
|
-
className: `timeline-lane-label${
|
|
1813
|
-
style: { height:
|
|
1814
|
-
children:
|
|
1812
|
+
className: `timeline-lane-label${CA === t ? " is-hover" : ""}`,
|
|
1813
|
+
style: { height: H },
|
|
1814
|
+
children: A
|
|
1815
1815
|
},
|
|
1816
|
-
|
|
1816
|
+
A
|
|
1817
1817
|
))
|
|
1818
1818
|
}
|
|
1819
1819
|
),
|
|
1820
|
-
|
|
1821
|
-
const
|
|
1822
|
-
return
|
|
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${
|
|
1825
|
+
className: `timeline-ghost-clip${r.kind === "video" ? " is-video" : " is-audio"}`,
|
|
1826
1826
|
style: {
|
|
1827
|
-
left:
|
|
1828
|
-
top:
|
|
1829
|
-
width:
|
|
1830
|
-
height:
|
|
1827
|
+
left: n,
|
|
1828
|
+
top: r.row * H - lA,
|
|
1829
|
+
width: t,
|
|
1830
|
+
height: H
|
|
1831
1831
|
}
|
|
1832
1832
|
},
|
|
1833
|
-
`${
|
|
1833
|
+
`${r.kind}-${r.row}`
|
|
1834
1834
|
));
|
|
1835
1835
|
})() }) : null,
|
|
1836
|
-
/* @__PURE__ */
|
|
1837
|
-
|
|
1836
|
+
/* @__PURE__ */ E.jsx(
|
|
1837
|
+
ke,
|
|
1838
1838
|
{
|
|
1839
|
-
scale:
|
|
1840
|
-
scaleWidth:
|
|
1841
|
-
startLeft:
|
|
1842
|
-
rowHeight:
|
|
1839
|
+
scale: ne,
|
|
1840
|
+
scaleWidth: te,
|
|
1841
|
+
startLeft: Ee,
|
|
1842
|
+
rowHeight: H,
|
|
1843
1843
|
autoScroll: !0,
|
|
1844
|
-
ref:
|
|
1845
|
-
editorData:
|
|
1846
|
-
effects:
|
|
1847
|
-
onScroll: (
|
|
1848
|
-
const
|
|
1849
|
-
Number.isFinite(
|
|
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: (
|
|
1852
|
-
|
|
1851
|
+
onClickTimeArea: (A, t) => {
|
|
1852
|
+
f(null);
|
|
1853
1853
|
},
|
|
1854
|
-
onClickRow: (
|
|
1855
|
-
|
|
1854
|
+
onClickRow: (A) => {
|
|
1855
|
+
A.target?.closest?.(".timeline-editor-action") || f(null);
|
|
1856
1856
|
},
|
|
1857
|
-
onClickActionOnly: (
|
|
1858
|
-
const
|
|
1859
|
-
|
|
1857
|
+
onClickActionOnly: (A, { action: t }) => {
|
|
1858
|
+
const n = t;
|
|
1859
|
+
n?.id && f(String(n.id));
|
|
1860
1860
|
},
|
|
1861
|
-
onActionMoveStart: ({ action:
|
|
1862
|
-
|
|
1863
|
-
const
|
|
1864
|
-
|
|
1865
|
-
actionId: String(
|
|
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(
|
|
1871
|
-
initialEnd: Number.isFinite(
|
|
1870
|
+
initialStart: Number.isFinite(t) ? t : 0,
|
|
1871
|
+
initialEnd: Number.isFinite(n) ? n : 0,
|
|
1872
1872
|
takeover: !1
|
|
1873
|
-
},
|
|
1873
|
+
}, cA(), !V.current && (V.current = structuredClone(s), tA.current = LA(s));
|
|
1874
1874
|
},
|
|
1875
1875
|
onActionMoveEnd: () => {
|
|
1876
|
-
const
|
|
1877
|
-
|
|
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
|
-
},
|
|
1886
|
+
}, VA();
|
|
1887
1887
|
},
|
|
1888
|
-
onActionResizeStart: ({ action:
|
|
1889
|
-
|
|
1890
|
-
const
|
|
1891
|
-
|
|
1892
|
-
actionId: String(
|
|
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(
|
|
1898
|
-
initialEnd: Number.isFinite(
|
|
1897
|
+
initialStart: Number.isFinite(t) ? t : 0,
|
|
1898
|
+
initialEnd: Number.isFinite(n) ? n : 0,
|
|
1899
1899
|
takeover: !1
|
|
1900
|
-
},
|
|
1900
|
+
}, cA(), !V.current && (V.current = structuredClone(s), tA.current = LA(s));
|
|
1901
1901
|
},
|
|
1902
1902
|
onActionResizeEnd: () => {
|
|
1903
|
-
const
|
|
1904
|
-
|
|
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
|
-
},
|
|
1913
|
+
}, VA();
|
|
1914
1914
|
},
|
|
1915
|
-
onActionMoving: ({ action:
|
|
1916
|
-
const
|
|
1917
|
-
if (
|
|
1918
|
-
const
|
|
1919
|
-
if (
|
|
1920
|
-
const
|
|
1921
|
-
if (
|
|
1922
|
-
const
|
|
1923
|
-
if (
|
|
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
|
|
1926
|
-
const
|
|
1927
|
-
return
|
|
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
|
|
1931
|
-
if (!Number.isFinite(
|
|
1932
|
-
const
|
|
1933
|
-
if (!Number.isFinite(
|
|
1934
|
-
const
|
|
1935
|
-
if (
|
|
1936
|
-
const
|
|
1937
|
-
if (
|
|
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 ((
|
|
1940
|
-
const
|
|
1941
|
-
return
|
|
1942
|
-
}),
|
|
1943
|
-
const
|
|
1944
|
-
return
|
|
1945
|
-
actionId:
|
|
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:
|
|
1950
|
-
initialStart:
|
|
1951
|
-
initialEnd:
|
|
1948
|
+
basePointerTime: O,
|
|
1949
|
+
lastPointerTime: X.current.lastPointerTime,
|
|
1950
|
+
initialStart: a,
|
|
1951
|
+
initialEnd: B,
|
|
1952
1952
|
takeover: !0
|
|
1953
|
-
},
|
|
1953
|
+
}, cA(), !1;
|
|
1954
1954
|
}
|
|
1955
1955
|
},
|
|
1956
|
-
onActionResizing: ({ action:
|
|
1957
|
-
const
|
|
1958
|
-
if (
|
|
1959
|
-
const
|
|
1960
|
-
if (
|
|
1961
|
-
const
|
|
1962
|
-
if (
|
|
1963
|
-
const
|
|
1964
|
-
if (
|
|
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
|
|
1967
|
-
const
|
|
1968
|
-
return
|
|
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
|
|
1972
|
-
if (!Number.isFinite(
|
|
1973
|
-
const
|
|
1974
|
-
if (!Number.isFinite(
|
|
1975
|
-
const
|
|
1976
|
-
if (
|
|
1977
|
-
const
|
|
1978
|
-
if (
|
|
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 ((
|
|
1981
|
-
const
|
|
1982
|
-
return
|
|
1983
|
-
}),
|
|
1984
|
-
const
|
|
1985
|
-
return
|
|
1986
|
-
actionId:
|
|
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:
|
|
1989
|
-
basePointerTime:
|
|
1990
|
-
lastPointerTime:
|
|
1991
|
-
initialStart:
|
|
1992
|
-
initialEnd:
|
|
1988
|
+
dir: B,
|
|
1989
|
+
basePointerTime: Y,
|
|
1990
|
+
lastPointerTime: X.current.lastPointerTime,
|
|
1991
|
+
initialStart: d,
|
|
1992
|
+
initialEnd: Q,
|
|
1993
1993
|
takeover: !0
|
|
1994
|
-
},
|
|
1994
|
+
}, cA(), !1;
|
|
1995
1995
|
}
|
|
1996
1996
|
},
|
|
1997
|
-
onChange: (
|
|
1998
|
-
const
|
|
1999
|
-
|
|
2000
|
-
const
|
|
2001
|
-
|
|
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: (
|
|
2004
|
-
if (
|
|
2005
|
-
return /* @__PURE__ */
|
|
2006
|
-
if (
|
|
2007
|
-
return /* @__PURE__ */
|
|
2008
|
-
if (
|
|
2009
|
-
return /* @__PURE__ */
|
|
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__ */
|
|
2016
|
+
/* @__PURE__ */ E.jsx(At, { children: L ? /* @__PURE__ */ E.jsx(
|
|
2017
2017
|
"div",
|
|
2018
2018
|
{
|
|
2019
2019
|
className: "footage-overlay",
|
|
2020
|
-
style:
|
|
2021
|
-
width:
|
|
2022
|
-
height:
|
|
2020
|
+
style: S ? {
|
|
2021
|
+
width: S.width,
|
|
2022
|
+
height: S.height
|
|
2023
2023
|
} : void 0,
|
|
2024
|
-
children: /* @__PURE__ */
|
|
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
|
-
|
|
2032
|
+
xt as MeliesVideoEditor
|
|
2033
2033
|
};
|