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