remotion 4.0.379 → 4.0.381
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/cjs/Composition.js +8 -2
- package/dist/cjs/audio/shared-audio-tags.js +0 -24
- package/dist/cjs/calculate-loop.d.ts +6 -0
- package/dist/cjs/calculate-loop.js +17 -0
- package/dist/cjs/version.d.ts +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/video/use-audio-channel-index.d.ts +4 -0
- package/dist/cjs/video/use-audio-channel-index.js +13 -0
- package/dist/esm/index.mjs +41 -54
- package/dist/esm/index.mjs.map +137 -0
- package/dist/esm/version.mjs +1 -1
- package/package.json +2 -2
package/dist/cjs/Composition.js
CHANGED
|
@@ -101,7 +101,10 @@ const InnerComposition = ({ width, height, fps, durationInFrames, id, defaultPro
|
|
|
101
101
|
}));
|
|
102
102
|
}, [defaultProps, id]);
|
|
103
103
|
const resolved = (0, ResolveCompositionConfig_js_1.useResolvedVideoConfig)(id);
|
|
104
|
-
if (environment.isStudio &&
|
|
104
|
+
if (environment.isStudio &&
|
|
105
|
+
video &&
|
|
106
|
+
video.component === lazy &&
|
|
107
|
+
video.id === id) {
|
|
105
108
|
const Comp = lazy;
|
|
106
109
|
if (resolved === null ||
|
|
107
110
|
(resolved.type !== 'success' &&
|
|
@@ -110,7 +113,10 @@ const InnerComposition = ({ width, height, fps, durationInFrames, id, defaultPro
|
|
|
110
113
|
}
|
|
111
114
|
return (0, react_dom_1.createPortal)((0, jsx_runtime_1.jsx)(CanUseRemotionHooks_js_1.CanUseRemotionHooksProvider, { children: (0, jsx_runtime_1.jsx)(react_1.Suspense, { fallback: (0, jsx_runtime_1.jsx)(loading_indicator_js_1.Loading, {}), children: (0, jsx_runtime_1.jsx)(Comp, { ...((_b = resolved.result.props) !== null && _b !== void 0 ? _b : {}) }) }) }), (0, portal_node_js_1.portalNode)());
|
|
112
115
|
}
|
|
113
|
-
if (environment.isRendering &&
|
|
116
|
+
if (environment.isRendering &&
|
|
117
|
+
video &&
|
|
118
|
+
video.component === lazy &&
|
|
119
|
+
video.id === id) {
|
|
114
120
|
const Comp = lazy;
|
|
115
121
|
if (resolved === null ||
|
|
116
122
|
(resolved.type !== 'success' &&
|
|
@@ -36,7 +36,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
36
36
|
exports.useSharedAudio = exports.SharedAudioContextProvider = exports.SharedAudioContext = void 0;
|
|
37
37
|
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
38
38
|
const react_1 = __importStar(require("react"));
|
|
39
|
-
const CompositionManagerContext_js_1 = require("../CompositionManagerContext.js");
|
|
40
39
|
const log_level_context_js_1 = require("../log-level-context.js");
|
|
41
40
|
const play_and_handle_not_allowed_error_js_1 = require("../play-and-handle-not-allowed-error.js");
|
|
42
41
|
const use_remotion_environment_js_1 = require("../use-remotion-environment.js");
|
|
@@ -81,13 +80,6 @@ const SharedAudioContextProvider = ({ children, numberOfAudioTags, audioLatencyH
|
|
|
81
80
|
if (numberOfAudioTags !== initialNumberOfAudioTags) {
|
|
82
81
|
throw new Error('The number of shared audio tags has changed dynamically. Once you have set this property, you cannot change it afterwards.');
|
|
83
82
|
}
|
|
84
|
-
const compositionManager = (0, react_1.useContext)(CompositionManagerContext_js_1.CompositionManager);
|
|
85
|
-
const component = compositionManager.compositions.find((c) => {
|
|
86
|
-
var _a;
|
|
87
|
-
return ((_a = compositionManager.canvasContent) === null || _a === void 0 ? void 0 : _a.type) === 'composition'
|
|
88
|
-
? c.id === compositionManager.canvasContent.compositionId
|
|
89
|
-
: null;
|
|
90
|
-
});
|
|
91
83
|
const logLevel = (0, log_level_context_js_1.useLogLevel)();
|
|
92
84
|
const audioContext = (0, use_audio_context_js_1.useSingletonAudioContext)(logLevel, audioLatencyHint);
|
|
93
85
|
const refs = (0, react_1.useMemo)(() => {
|
|
@@ -231,22 +223,6 @@ const SharedAudioContextProvider = ({ children, numberOfAudioTags, audioLatencyH
|
|
|
231
223
|
updateAudio,
|
|
232
224
|
audioContext,
|
|
233
225
|
]);
|
|
234
|
-
// Fixing a bug: In React, if a component is unmounted using useInsertionEffect, then
|
|
235
|
-
// the cleanup function does sometimes not work properly. That is why when we
|
|
236
|
-
// are changing the composition, we reset the audio state.
|
|
237
|
-
// TODO: Possibly this does not save the problem completely, since the
|
|
238
|
-
// if an audio tag that is inside a sequence will also not be removed
|
|
239
|
-
// from the shared audios.
|
|
240
|
-
const resetAudio = (0, react_1.useCallback)(() => {
|
|
241
|
-
takenAudios.current = new Array(numberOfAudioTags).fill(false);
|
|
242
|
-
audios.current = [];
|
|
243
|
-
rerenderAudios();
|
|
244
|
-
}, [numberOfAudioTags, rerenderAudios]);
|
|
245
|
-
(0, react_1.useEffect)(() => {
|
|
246
|
-
return () => {
|
|
247
|
-
resetAudio();
|
|
248
|
-
};
|
|
249
|
-
}, [component, resetAudio]);
|
|
250
226
|
return ((0, jsx_runtime_1.jsxs)(exports.SharedAudioContext.Provider, { value: value, children: [refs.map(({ id, ref }) => {
|
|
251
227
|
return (
|
|
252
228
|
// Without preload="metadata", iOS will seek the time internally
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateLoopDuration = void 0;
|
|
4
|
+
const calculateLoopDuration = ({ endAt, mediaDuration, playbackRate, startFrom, }) => {
|
|
5
|
+
let duration = mediaDuration;
|
|
6
|
+
// Account for endAt
|
|
7
|
+
if (typeof endAt !== 'undefined') {
|
|
8
|
+
duration = endAt;
|
|
9
|
+
}
|
|
10
|
+
// Account for startFrom
|
|
11
|
+
if (typeof startFrom !== 'undefined') {
|
|
12
|
+
duration -= startFrom;
|
|
13
|
+
}
|
|
14
|
+
const actualDuration = duration / playbackRate;
|
|
15
|
+
return Math.floor(actualDuration);
|
|
16
|
+
};
|
|
17
|
+
exports.calculateLoopDuration = calculateLoopDuration;
|
package/dist/cjs/version.d.ts
CHANGED
package/dist/cjs/version.js
CHANGED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useAudioChannelIndex = void 0;
|
|
4
|
+
const react_1 = require("react");
|
|
5
|
+
const useAudioChannelIndex = ({ ref, audioChannelIndex, }) => {
|
|
6
|
+
(0, react_1.useEffect)(() => {
|
|
7
|
+
var _a;
|
|
8
|
+
// @ts-expect-error
|
|
9
|
+
const audioChannels = (_a = ref === null || ref === void 0 ? void 0 : ref.current) === null || _a === void 0 ? void 0 : _a.audioTracks;
|
|
10
|
+
console.log({ audioChannels, audioChannelIndex });
|
|
11
|
+
}, [ref, audioChannelIndex]);
|
|
12
|
+
};
|
|
13
|
+
exports.useAudioChannelIndex = useAudioChannelIndex;
|
package/dist/esm/index.mjs
CHANGED
|
@@ -110,7 +110,7 @@ function truthy(value) {
|
|
|
110
110
|
}
|
|
111
111
|
|
|
112
112
|
// src/version.ts
|
|
113
|
-
var VERSION = "4.0.
|
|
113
|
+
var VERSION = "4.0.381";
|
|
114
114
|
|
|
115
115
|
// src/multiple-versions-warning.ts
|
|
116
116
|
var checkMultipleRemotionVersions = () => {
|
|
@@ -2974,7 +2974,7 @@ var DurationsContextProvider = ({ children }) => {
|
|
|
2974
2974
|
import {
|
|
2975
2975
|
forwardRef as forwardRef4,
|
|
2976
2976
|
useContext as useContext25,
|
|
2977
|
-
useEffect as
|
|
2977
|
+
useEffect as useEffect12,
|
|
2978
2978
|
useImperativeHandle as useImperativeHandle6,
|
|
2979
2979
|
useMemo as useMemo21,
|
|
2980
2980
|
useRef as useRef12,
|
|
@@ -3004,7 +3004,6 @@ import React15, {
|
|
|
3004
3004
|
createRef as createRef2,
|
|
3005
3005
|
useCallback as useCallback7,
|
|
3006
3006
|
useContext as useContext16,
|
|
3007
|
-
useEffect as useEffect6,
|
|
3008
3007
|
useMemo as useMemo15,
|
|
3009
3008
|
useRef as useRef5,
|
|
3010
3009
|
useState as useState11
|
|
@@ -3158,8 +3157,6 @@ var SharedAudioContextProvider = ({ children, numberOfAudioTags, audioLatencyHin
|
|
|
3158
3157
|
if (numberOfAudioTags !== initialNumberOfAudioTags) {
|
|
3159
3158
|
throw new Error("The number of shared audio tags has changed dynamically. Once you have set this property, you cannot change it afterwards.");
|
|
3160
3159
|
}
|
|
3161
|
-
const compositionManager = useContext16(CompositionManager);
|
|
3162
|
-
const component = compositionManager.compositions.find((c) => compositionManager.canvasContent?.type === "composition" ? c.id === compositionManager.canvasContent.compositionId : null);
|
|
3163
3160
|
const logLevel = useLogLevel();
|
|
3164
3161
|
const audioContext = useSingletonAudioContext(logLevel, audioLatencyHint);
|
|
3165
3162
|
const refs = useMemo15(() => {
|
|
@@ -3298,16 +3295,6 @@ var SharedAudioContextProvider = ({ children, numberOfAudioTags, audioLatencyHin
|
|
|
3298
3295
|
updateAudio,
|
|
3299
3296
|
audioContext
|
|
3300
3297
|
]);
|
|
3301
|
-
const resetAudio = useCallback7(() => {
|
|
3302
|
-
takenAudios.current = new Array(numberOfAudioTags).fill(false);
|
|
3303
|
-
audios.current = [];
|
|
3304
|
-
rerenderAudios();
|
|
3305
|
-
}, [numberOfAudioTags, rerenderAudios]);
|
|
3306
|
-
useEffect6(() => {
|
|
3307
|
-
return () => {
|
|
3308
|
-
resetAudio();
|
|
3309
|
-
};
|
|
3310
|
-
}, [component, resetAudio]);
|
|
3311
3298
|
return /* @__PURE__ */ jsxs(SharedAudioContext.Provider, {
|
|
3312
3299
|
value,
|
|
3313
3300
|
children: [
|
|
@@ -3558,7 +3545,7 @@ var useVolume = ({
|
|
|
3558
3545
|
};
|
|
3559
3546
|
|
|
3560
3547
|
// src/use-media-in-timeline.ts
|
|
3561
|
-
import { useContext as useContext19, useEffect as
|
|
3548
|
+
import { useContext as useContext19, useEffect as useEffect6, useMemo as useMemo16, useState as useState12 } from "react";
|
|
3562
3549
|
|
|
3563
3550
|
// src/audio/use-audio-frame.ts
|
|
3564
3551
|
import { useContext as useContext18 } from "react";
|
|
@@ -3656,7 +3643,7 @@ var useBasicMediaInTimeline = ({
|
|
|
3656
3643
|
});
|
|
3657
3644
|
}).join(",");
|
|
3658
3645
|
}, [duration, startsAt, volume, mediaVolume]);
|
|
3659
|
-
|
|
3646
|
+
useEffect6(() => {
|
|
3660
3647
|
if (typeof volume === "number" && volume !== initialVolume) {
|
|
3661
3648
|
warnOnce2(`Remotion: The ${mediaType} with src ${src} has changed it's volume. Prefer the callback syntax for setting volume to get better timeline display: https://www.remotion.dev/docs/audio/volume`);
|
|
3662
3649
|
}
|
|
@@ -3710,7 +3697,7 @@ var useMediaInTimeline = ({
|
|
|
3710
3697
|
trimBefore: undefined,
|
|
3711
3698
|
playbackRate
|
|
3712
3699
|
});
|
|
3713
|
-
|
|
3700
|
+
useEffect6(() => {
|
|
3714
3701
|
if (!src) {
|
|
3715
3702
|
throw new Error("No src passed");
|
|
3716
3703
|
}
|
|
@@ -3771,7 +3758,7 @@ var useMediaInTimeline = ({
|
|
|
3771
3758
|
import {
|
|
3772
3759
|
useCallback as useCallback10,
|
|
3773
3760
|
useContext as useContext22,
|
|
3774
|
-
useEffect as
|
|
3761
|
+
useEffect as useEffect10,
|
|
3775
3762
|
useLayoutEffect as useLayoutEffect7,
|
|
3776
3763
|
useRef as useRef11
|
|
3777
3764
|
} from "react";
|
|
@@ -3786,7 +3773,7 @@ import { useContext as useContext21, useMemo as useMemo18 } from "react";
|
|
|
3786
3773
|
import React16, {
|
|
3787
3774
|
useCallback as useCallback8,
|
|
3788
3775
|
useContext as useContext20,
|
|
3789
|
-
useEffect as
|
|
3776
|
+
useEffect as useEffect7,
|
|
3790
3777
|
useLayoutEffect as useLayoutEffect6,
|
|
3791
3778
|
useMemo as useMemo17,
|
|
3792
3779
|
useRef as useRef8,
|
|
@@ -3828,7 +3815,7 @@ var useBufferManager = (logLevel, mountTime) => {
|
|
|
3828
3815
|
}
|
|
3829
3816
|
};
|
|
3830
3817
|
}, []);
|
|
3831
|
-
|
|
3818
|
+
useEffect7(() => {
|
|
3832
3819
|
if (blocks.length > 0) {
|
|
3833
3820
|
onBufferingCallbacks.forEach((c) => c());
|
|
3834
3821
|
playbackLogging({
|
|
@@ -3867,7 +3854,7 @@ var BufferingProvider = ({ children }) => {
|
|
|
3867
3854
|
};
|
|
3868
3855
|
var useIsPlayerBuffering = (bufferManager) => {
|
|
3869
3856
|
const [isBuffering, setIsBuffering] = useState13(bufferManager.buffering.current);
|
|
3870
|
-
|
|
3857
|
+
useEffect7(() => {
|
|
3871
3858
|
const onBuffer = () => {
|
|
3872
3859
|
setIsBuffering(true);
|
|
3873
3860
|
};
|
|
@@ -4036,7 +4023,7 @@ var seek = ({
|
|
|
4036
4023
|
};
|
|
4037
4024
|
|
|
4038
4025
|
// src/use-media-buffering.ts
|
|
4039
|
-
import { useEffect as
|
|
4026
|
+
import { useEffect as useEffect8, useState as useState14 } from "react";
|
|
4040
4027
|
var useMediaBuffering = ({
|
|
4041
4028
|
element,
|
|
4042
4029
|
shouldBuffer,
|
|
@@ -4048,7 +4035,7 @@ var useMediaBuffering = ({
|
|
|
4048
4035
|
}) => {
|
|
4049
4036
|
const buffer = useBufferState();
|
|
4050
4037
|
const [isBuffering, setIsBuffering] = useState14(false);
|
|
4051
|
-
|
|
4038
|
+
useEffect8(() => {
|
|
4052
4039
|
let cleanupFns = [];
|
|
4053
4040
|
const { current } = element;
|
|
4054
4041
|
if (!current) {
|
|
@@ -4176,7 +4163,7 @@ var useMediaBuffering = ({
|
|
|
4176
4163
|
};
|
|
4177
4164
|
|
|
4178
4165
|
// src/use-request-video-callback-time.ts
|
|
4179
|
-
import { useEffect as
|
|
4166
|
+
import { useEffect as useEffect9, useRef as useRef10 } from "react";
|
|
4180
4167
|
var useRequestVideoCallbackTime = ({
|
|
4181
4168
|
mediaRef,
|
|
4182
4169
|
mediaType,
|
|
@@ -4184,7 +4171,7 @@ var useRequestVideoCallbackTime = ({
|
|
|
4184
4171
|
onVariableFpsVideoDetected
|
|
4185
4172
|
}) => {
|
|
4186
4173
|
const currentTime = useRef10(null);
|
|
4187
|
-
|
|
4174
|
+
useEffect9(() => {
|
|
4188
4175
|
const { current } = mediaRef;
|
|
4189
4176
|
if (current) {
|
|
4190
4177
|
currentTime.current = {
|
|
@@ -4478,7 +4465,7 @@ var useMediaPlayback = ({
|
|
|
4478
4465
|
return acceptableTimeshift ?? defaultAcceptableTimeshift;
|
|
4479
4466
|
})();
|
|
4480
4467
|
const isPlayerBuffering = useIsPlayerBuffering(buffering);
|
|
4481
|
-
|
|
4468
|
+
useEffect10(() => {
|
|
4482
4469
|
if (mediaRef.current?.paused) {
|
|
4483
4470
|
return;
|
|
4484
4471
|
}
|
|
@@ -4523,7 +4510,7 @@ var useMediaPlayback = ({
|
|
|
4523
4510
|
mediaRef.current.playbackRate = playbackRateToSet;
|
|
4524
4511
|
}
|
|
4525
4512
|
}, [mediaRef, playbackRate]);
|
|
4526
|
-
|
|
4513
|
+
useEffect10(() => {
|
|
4527
4514
|
const tagName = mediaType === "audio" ? "<Html5Audio>" : "<Html5Video>";
|
|
4528
4515
|
if (!mediaRef.current) {
|
|
4529
4516
|
throw new Error(`No ${mediaType} ref found`);
|
|
@@ -4642,7 +4629,7 @@ var useMediaPlayback = ({
|
|
|
4642
4629
|
};
|
|
4643
4630
|
|
|
4644
4631
|
// src/use-media-tag.ts
|
|
4645
|
-
import { useContext as useContext23, useEffect as
|
|
4632
|
+
import { useContext as useContext23, useEffect as useEffect11 } from "react";
|
|
4646
4633
|
var useMediaTag = ({
|
|
4647
4634
|
mediaRef,
|
|
4648
4635
|
id,
|
|
@@ -4655,7 +4642,7 @@ var useMediaTag = ({
|
|
|
4655
4642
|
const logLevel = useLogLevel();
|
|
4656
4643
|
const mountTime = useMountTime();
|
|
4657
4644
|
const env = useRemotionEnvironment();
|
|
4658
|
-
|
|
4645
|
+
useEffect11(() => {
|
|
4659
4646
|
const tag = {
|
|
4660
4647
|
id,
|
|
4661
4648
|
play: (reason) => {
|
|
@@ -4872,7 +4859,7 @@ var AudioForDevelopmentForwardRefFunction = (props, ref) => {
|
|
|
4872
4859
|
}, [audioRef]);
|
|
4873
4860
|
const currentOnDurationCallback = useRef12(onDuration);
|
|
4874
4861
|
currentOnDurationCallback.current = onDuration;
|
|
4875
|
-
|
|
4862
|
+
useEffect12(() => {
|
|
4876
4863
|
const { current } = audioRef;
|
|
4877
4864
|
if (!current) {
|
|
4878
4865
|
return;
|
|
@@ -4905,7 +4892,7 @@ var AudioForPreview = forwardRef4(AudioForDevelopmentForwardRefFunction);
|
|
|
4905
4892
|
import {
|
|
4906
4893
|
forwardRef as forwardRef5,
|
|
4907
4894
|
useContext as useContext26,
|
|
4908
|
-
useEffect as
|
|
4895
|
+
useEffect as useEffect13,
|
|
4909
4896
|
useImperativeHandle as useImperativeHandle7,
|
|
4910
4897
|
useLayoutEffect as useLayoutEffect8,
|
|
4911
4898
|
useMemo as useMemo22,
|
|
@@ -4953,7 +4940,7 @@ var AudioForRenderingRefForwardingFunction = (props, ref) => {
|
|
|
4953
4940
|
useImperativeHandle7(ref, () => {
|
|
4954
4941
|
return audioRef.current;
|
|
4955
4942
|
}, []);
|
|
4956
|
-
|
|
4943
|
+
useEffect13(() => {
|
|
4957
4944
|
if (!props.src) {
|
|
4958
4945
|
throw new Error("No src passed");
|
|
4959
4946
|
}
|
|
@@ -5160,11 +5147,11 @@ var Html5Audio = forwardRef6(AudioRefForwardingFunction);
|
|
|
5160
5147
|
addSequenceStackTraces(Html5Audio);
|
|
5161
5148
|
var Audio = Html5Audio;
|
|
5162
5149
|
// src/Composition.tsx
|
|
5163
|
-
import { Suspense, useContext as useContext29, useEffect as
|
|
5150
|
+
import { Suspense, useContext as useContext29, useEffect as useEffect15 } from "react";
|
|
5164
5151
|
import { createPortal } from "react-dom";
|
|
5165
5152
|
|
|
5166
5153
|
// src/Folder.tsx
|
|
5167
|
-
import { createContext as createContext18, useContext as useContext28, useEffect as
|
|
5154
|
+
import { createContext as createContext18, useContext as useContext28, useEffect as useEffect14, useMemo as useMemo23 } from "react";
|
|
5168
5155
|
|
|
5169
5156
|
// src/validation/validate-folder-name.ts
|
|
5170
5157
|
var getRegex = () => /^([a-zA-Z0-9-\u4E00-\u9FFF])+$/g;
|
|
@@ -5200,7 +5187,7 @@ var Folder = ({ name, children }) => {
|
|
|
5200
5187
|
parentName
|
|
5201
5188
|
};
|
|
5202
5189
|
}, [name, parentName]);
|
|
5203
|
-
|
|
5190
|
+
useEffect14(() => {
|
|
5204
5191
|
registerFolder(name, parentName);
|
|
5205
5192
|
return () => {
|
|
5206
5193
|
unregisterFolder(name, parentName);
|
|
@@ -5355,7 +5342,7 @@ var validateDefaultAndInputProps = (defaultProps, name, compositionId) => {
|
|
|
5355
5342
|
import { jsx as jsx23 } from "react/jsx-runtime";
|
|
5356
5343
|
var Fallback = () => {
|
|
5357
5344
|
const { continueRender: continueRender2, delayRender: delayRender2 } = useDelayRender();
|
|
5358
|
-
|
|
5345
|
+
useEffect15(() => {
|
|
5359
5346
|
const fallback = delayRender2("Waiting for Root component to unsuspend");
|
|
5360
5347
|
return () => continueRender2(fallback);
|
|
5361
5348
|
}, [continueRender2, delayRender2]);
|
|
@@ -5393,7 +5380,7 @@ var InnerComposition = ({
|
|
|
5393
5380
|
throw new Error("<Composition> mounted inside another composition. See https://remotion.dev/docs/wrong-composition-mount for help.");
|
|
5394
5381
|
}
|
|
5395
5382
|
const { folderName, parentName } = useContext29(FolderContext);
|
|
5396
|
-
|
|
5383
|
+
useEffect15(() => {
|
|
5397
5384
|
if (!id) {
|
|
5398
5385
|
throw new Error("No id for composition passed.");
|
|
5399
5386
|
}
|
|
@@ -5432,7 +5419,7 @@ var InnerComposition = ({
|
|
|
5432
5419
|
registerComposition,
|
|
5433
5420
|
unregisterComposition
|
|
5434
5421
|
]);
|
|
5435
|
-
|
|
5422
|
+
useEffect15(() => {
|
|
5436
5423
|
window.dispatchEvent(new CustomEvent(PROPS_UPDATED_EXTERNALLY, {
|
|
5437
5424
|
detail: {
|
|
5438
5425
|
resetUnsaved: id
|
|
@@ -5440,7 +5427,7 @@ var InnerComposition = ({
|
|
|
5440
5427
|
}));
|
|
5441
5428
|
}, [defaultProps, id]);
|
|
5442
5429
|
const resolved = useResolvedVideoConfig(id);
|
|
5443
|
-
if (environment.isStudio && video && video.component === lazy) {
|
|
5430
|
+
if (environment.isStudio && video && video.component === lazy && video.id === id) {
|
|
5444
5431
|
const Comp = lazy;
|
|
5445
5432
|
if (resolved === null || resolved.type !== "success" && resolved.type !== "success-and-refreshing") {
|
|
5446
5433
|
return null;
|
|
@@ -5454,7 +5441,7 @@ var InnerComposition = ({
|
|
|
5454
5441
|
})
|
|
5455
5442
|
}), portalNode());
|
|
5456
5443
|
}
|
|
5457
|
-
if (environment.isRendering && video && video.component === lazy) {
|
|
5444
|
+
if (environment.isRendering && video && video.component === lazy && video.id === id) {
|
|
5458
5445
|
const Comp = lazy;
|
|
5459
5446
|
if (resolved === null || resolved.type !== "success" && resolved.type !== "success-and-refreshing") {
|
|
5460
5447
|
return null;
|
|
@@ -6095,7 +6082,7 @@ var waitForRoot = (fn) => {
|
|
|
6095
6082
|
};
|
|
6096
6083
|
|
|
6097
6084
|
// src/RemotionRoot.tsx
|
|
6098
|
-
import { useEffect as
|
|
6085
|
+
import { useEffect as useEffect16, useMemo as useMemo27, useState as useState18 } from "react";
|
|
6099
6086
|
|
|
6100
6087
|
// src/use-media-enabled.tsx
|
|
6101
6088
|
import { createContext as createContext19, useContext as useContext31, useMemo as useMemo26 } from "react";
|
|
@@ -6161,7 +6148,7 @@ var RemotionRootContexts = ({
|
|
|
6161
6148
|
}
|
|
6162
6149
|
};
|
|
6163
6150
|
}, []);
|
|
6164
|
-
|
|
6151
|
+
useEffect16(() => {
|
|
6165
6152
|
if (typeof __webpack_module__ !== "undefined") {
|
|
6166
6153
|
if (__webpack_module__.hot) {
|
|
6167
6154
|
__webpack_module__.hot.addStatusHandler((status) => {
|
|
@@ -6299,7 +6286,7 @@ import { useCallback as useCallback16 } from "react";
|
|
|
6299
6286
|
import {
|
|
6300
6287
|
useCallback as useCallback15,
|
|
6301
6288
|
useContext as useContext32,
|
|
6302
|
-
useEffect as
|
|
6289
|
+
useEffect as useEffect17,
|
|
6303
6290
|
useLayoutEffect as useLayoutEffect10,
|
|
6304
6291
|
useMemo as useMemo28,
|
|
6305
6292
|
useState as useState19
|
|
@@ -6361,7 +6348,7 @@ var OffthreadVideoForRendering = ({
|
|
|
6361
6348
|
mediaVolume: 1
|
|
6362
6349
|
});
|
|
6363
6350
|
warnAboutTooHighVolume(volume);
|
|
6364
|
-
|
|
6351
|
+
useEffect17(() => {
|
|
6365
6352
|
if (!src) {
|
|
6366
6353
|
throw new Error("No src passed");
|
|
6367
6354
|
}
|
|
@@ -6523,7 +6510,7 @@ var OffthreadVideoForRendering = ({
|
|
|
6523
6510
|
import {
|
|
6524
6511
|
forwardRef as forwardRef9,
|
|
6525
6512
|
useContext as useContext33,
|
|
6526
|
-
useEffect as
|
|
6513
|
+
useEffect as useEffect19,
|
|
6527
6514
|
useImperativeHandle as useImperativeHandle10,
|
|
6528
6515
|
useMemo as useMemo29,
|
|
6529
6516
|
useRef as useRef16,
|
|
@@ -6531,12 +6518,12 @@ import {
|
|
|
6531
6518
|
} from "react";
|
|
6532
6519
|
|
|
6533
6520
|
// src/video/emit-video-frame.ts
|
|
6534
|
-
import { useEffect as
|
|
6521
|
+
import { useEffect as useEffect18 } from "react";
|
|
6535
6522
|
var useEmitVideoFrame = ({
|
|
6536
6523
|
ref,
|
|
6537
6524
|
onVideoFrame
|
|
6538
6525
|
}) => {
|
|
6539
|
-
|
|
6526
|
+
useEffect18(() => {
|
|
6540
6527
|
const { current } = ref;
|
|
6541
6528
|
if (!current) {
|
|
6542
6529
|
return;
|
|
@@ -6686,7 +6673,7 @@ var VideoForDevelopmentRefForwardingFunction = (props2, ref) => {
|
|
|
6686
6673
|
tag: "video",
|
|
6687
6674
|
mountTime
|
|
6688
6675
|
}));
|
|
6689
|
-
|
|
6676
|
+
useEffect19(() => {
|
|
6690
6677
|
const { current } = videoRef;
|
|
6691
6678
|
if (!current) {
|
|
6692
6679
|
return;
|
|
@@ -6717,7 +6704,7 @@ var VideoForDevelopmentRefForwardingFunction = (props2, ref) => {
|
|
|
6717
6704
|
const currentOnDurationCallback = useRef16(onDuration);
|
|
6718
6705
|
currentOnDurationCallback.current = onDuration;
|
|
6719
6706
|
useEmitVideoFrame({ ref: videoRef, onVideoFrame });
|
|
6720
|
-
|
|
6707
|
+
useEffect19(() => {
|
|
6721
6708
|
const { current } = videoRef;
|
|
6722
6709
|
if (!current) {
|
|
6723
6710
|
return;
|
|
@@ -6734,7 +6721,7 @@ var VideoForDevelopmentRefForwardingFunction = (props2, ref) => {
|
|
|
6734
6721
|
current.removeEventListener("loadedmetadata", onLoadedMetadata);
|
|
6735
6722
|
};
|
|
6736
6723
|
}, [src]);
|
|
6737
|
-
|
|
6724
|
+
useEffect19(() => {
|
|
6738
6725
|
const { current } = videoRef;
|
|
6739
6726
|
if (!current) {
|
|
6740
6727
|
return;
|
|
@@ -7973,7 +7960,7 @@ import { forwardRef as forwardRef12, useCallback as useCallback17, useContext as
|
|
|
7973
7960
|
import {
|
|
7974
7961
|
forwardRef as forwardRef11,
|
|
7975
7962
|
useContext as useContext34,
|
|
7976
|
-
useEffect as
|
|
7963
|
+
useEffect as useEffect20,
|
|
7977
7964
|
useImperativeHandle as useImperativeHandle11,
|
|
7978
7965
|
useLayoutEffect as useLayoutEffect11,
|
|
7979
7966
|
useMemo as useMemo32,
|
|
@@ -8148,7 +8135,7 @@ var VideoForRenderingForwardFunction = ({
|
|
|
8148
8135
|
mediaVolume: 1
|
|
8149
8136
|
});
|
|
8150
8137
|
warnAboutTooHighVolume(volume);
|
|
8151
|
-
|
|
8138
|
+
useEffect20(() => {
|
|
8152
8139
|
if (!props2.src) {
|
|
8153
8140
|
throw new Error("No src passed");
|
|
8154
8141
|
}
|
|
@@ -8191,7 +8178,7 @@ var VideoForRenderingForwardFunction = ({
|
|
|
8191
8178
|
useImperativeHandle11(ref, () => {
|
|
8192
8179
|
return videoRef.current;
|
|
8193
8180
|
}, []);
|
|
8194
|
-
|
|
8181
|
+
useEffect20(() => {
|
|
8195
8182
|
if (!window.remotion_videoEnabled) {
|
|
8196
8183
|
return;
|
|
8197
8184
|
}
|