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