remotion 3.3.44 → 3.3.51
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/{Clipper.js → cjs/Clipper.js} +2 -2
- package/dist/{Composition.js → cjs/Composition.js} +38 -38
- package/dist/{CompositionManager.d.ts → cjs/CompositionManager.d.ts} +1 -1
- package/dist/{CompositionManager.js → cjs/CompositionManager.js} +14 -4
- package/dist/{Folder.js → cjs/Folder.js} +6 -6
- package/dist/{IFrame.js → cjs/IFrame.js} +4 -4
- package/dist/{Img.js → cjs/Img.js} +9 -9
- package/dist/{Null.js → cjs/Null.js} +2 -2
- package/dist/{RemotionRoot.js → cjs/RemotionRoot.js} +13 -13
- package/dist/{Sequence.d.ts → cjs/Sequence.d.ts} +1 -0
- package/dist/{Sequence.js → cjs/Sequence.js} +15 -15
- package/dist/{Still.d.ts → cjs/Still.d.ts} +1 -1
- package/dist/{Still.js → cjs/Still.js} +2 -2
- package/dist/{audio → cjs/audio}/Audio.d.ts +2 -2
- package/dist/{audio → cjs/audio}/Audio.js +18 -18
- package/dist/{audio → cjs/audio}/AudioForDevelopment.d.ts +1 -1
- package/dist/{audio → cjs/audio}/AudioForDevelopment.js +22 -22
- package/dist/{audio → cjs/audio}/AudioForRendering.d.ts +1 -1
- package/dist/{audio → cjs/audio}/AudioForRendering.js +23 -23
- package/dist/cjs/audio/index.d.ts +2 -0
- package/dist/{audio → cjs/audio}/index.js +2 -2
- package/dist/{audio → cjs/audio}/props.d.ts +1 -1
- package/dist/{audio → cjs/audio}/shared-audio-tags.d.ts +1 -1
- package/dist/{audio → cjs/audio}/use-audio-frame.js +4 -4
- package/dist/{config → cjs/config}/input-props.js +3 -3
- package/dist/cjs/config.d.ts +285 -0
- package/dist/{delay-render.js → cjs/delay-render.js} +5 -5
- package/dist/{easing.js → cjs/easing.js} +2 -2
- package/dist/{freeze.js → cjs/freeze.js} +4 -4
- package/dist/{get-environment.js → cjs/get-environment.js} +2 -2
- package/dist/{index.d.ts → cjs/index.d.ts} +32 -31
- package/dist/{index.js → cjs/index.js} +45 -45
- package/dist/{internals.d.ts → cjs/internals.d.ts} +13 -15
- package/dist/cjs/internals.js +101 -0
- package/dist/{interpolate-colors.js → cjs/interpolate-colors.js} +2 -2
- package/dist/{loading-indicator.js → cjs/loading-indicator.js} +2 -2
- package/dist/{loop → cjs/loop}/index.d.ts +1 -1
- package/dist/{loop → cjs/loop}/index.js +6 -6
- package/dist/{multiple-versions-warning.js → cjs/multiple-versions-warning.js} +7 -7
- package/dist/{prefetch.js → cjs/prefetch.js} +6 -6
- package/dist/{random.js → cjs/random.js} +1 -0
- package/dist/{series → cjs/series}/index.d.ts +1 -1
- package/dist/{series → cjs/series}/index.js +6 -6
- package/dist/{setup-env-variables.js → cjs/setup-env-variables.js} +3 -3
- package/dist/{spring → cjs/spring}/index.d.ts +3 -3
- package/dist/{spring → cjs/spring}/index.js +12 -8
- package/dist/{spring → cjs/spring}/measure-spring.d.ts +1 -1
- package/dist/{spring → cjs/spring}/measure-spring.js +4 -4
- package/dist/cjs/test/Img.test.d.ts +1 -0
- package/dist/cjs/test/Img.test.js +25 -0
- package/dist/cjs/test/absolute-src.test.d.ts +1 -0
- package/dist/cjs/test/absolute-src.test.js +18 -0
- package/dist/cjs/test/audio-for-rendering.test.d.ts +1 -0
- package/dist/cjs/test/audio-for-rendering.test.js +88 -0
- package/dist/cjs/test/audio.test.d.ts +1 -0
- package/dist/cjs/test/audio.test.js +76 -0
- package/dist/cjs/test/bezier.test.d.ts +1 -0
- package/dist/cjs/test/bezier.test.js +52 -0
- package/dist/cjs/test/composition-rules.test.d.ts +1 -0
- package/dist/cjs/test/composition-rules.test.js +30 -0
- package/dist/cjs/test/composition-validation.test.d.ts +1 -0
- package/dist/cjs/test/composition-validation.test.js +99 -0
- package/dist/cjs/test/easing.test.d.ts +1 -0
- package/dist/cjs/test/easing.test.js +191 -0
- package/dist/cjs/test/expect-to-throw.d.ts +1 -0
- package/dist/cjs/test/expect-to-throw.js +15 -0
- package/dist/cjs/test/freeze.test.d.ts +1 -0
- package/dist/cjs/test/freeze.test.js +65 -0
- package/dist/cjs/test/get-asset-file-name.test.d.ts +1 -0
- package/dist/cjs/test/get-asset-file-name.test.js +14 -0
- package/dist/cjs/test/get-current-time.test.d.ts +1 -0
- package/dist/cjs/test/get-current-time.test.js +74 -0
- package/dist/cjs/test/input-props.test.d.ts +1 -0
- package/dist/cjs/test/input-props.test.js +31 -0
- package/dist/cjs/test/interpolate.test.d.ts +1 -0
- package/dist/cjs/test/interpolate.test.js +138 -0
- package/dist/cjs/test/interpolateColors.test.d.ts +1 -0
- package/dist/cjs/test/interpolateColors.test.js +63 -0
- package/dist/cjs/test/loop-validation.test.d.ts +1 -0
- package/dist/cjs/test/loop-validation.test.js +93 -0
- package/dist/cjs/test/measure-spring.test.d.ts +1 -0
- package/dist/cjs/test/measure-spring.test.js +45 -0
- package/dist/cjs/test/media-validation.test.d.ts +1 -0
- package/dist/cjs/test/media-validation.test.js +47 -0
- package/dist/cjs/test/nested-sequences.test.d.ts +1 -0
- package/dist/cjs/test/nested-sequences.test.js +132 -0
- package/dist/cjs/test/not-all-props-in-media-tags.test.d.ts +1 -0
- package/dist/cjs/test/not-all-props-in-media-tags.test.js +33 -0
- package/dist/cjs/test/random.test.d.ts +1 -0
- package/dist/cjs/test/random.test.js +60 -0
- package/dist/cjs/test/ready-manager.test.d.ts +1 -0
- package/dist/cjs/test/ready-manager.test.js +29 -0
- package/dist/cjs/test/render-hook.d.ts +23 -0
- package/dist/cjs/test/render-hook.js +27 -0
- package/dist/cjs/test/sequence-from-initial-offset.test.d.ts +4 -0
- package/dist/cjs/test/sequence-from-initial-offset.test.js +35 -0
- package/dist/cjs/test/sequence-validation.test.d.ts +1 -0
- package/dist/cjs/test/sequence-validation.test.js +47 -0
- package/dist/cjs/test/series.test.d.ts +1 -0
- package/dist/cjs/test/series.test.js +110 -0
- package/dist/cjs/test/spring.test.d.ts +1 -0
- package/dist/cjs/test/spring.test.js +38 -0
- package/dist/cjs/test/truthy.test.d.ts +1 -0
- package/dist/cjs/test/truthy.test.js +24 -0
- package/dist/cjs/test/use-audio-frame.test.d.ts +1 -0
- package/dist/cjs/test/use-audio-frame.test.js +78 -0
- package/dist/cjs/test/use-media-in-timeline.test.d.ts +1 -0
- package/dist/cjs/test/use-media-in-timeline.test.js +74 -0
- package/dist/cjs/test/use-media-tag-volume.test.d.ts +1 -0
- package/dist/cjs/test/use-media-tag-volume.test.js +49 -0
- package/dist/cjs/test/use-sync-volume-with-media-tag.test.d.ts +1 -0
- package/dist/cjs/test/use-sync-volume-with-media-tag.test.js +55 -0
- package/dist/cjs/test/validate-start-from-props.test.d.ts +1 -0
- package/dist/cjs/test/validate-start-from-props.test.js +39 -0
- package/dist/cjs/test/video.test.d.ts +1 -0
- package/dist/cjs/test/video.test.js +80 -0
- package/dist/cjs/test/volume-prop.test.d.ts +1 -0
- package/dist/cjs/test/volume-prop.test.js +95 -0
- package/dist/cjs/test/wrap-sequence-context.d.ts +6 -0
- package/dist/cjs/test/wrap-sequence-context.js +41 -0
- package/dist/{use-current-frame.js → cjs/use-current-frame.js} +6 -6
- package/dist/{use-lazy-component.d.ts → cjs/use-lazy-component.d.ts} +1 -1
- package/dist/{use-media-in-timeline.d.ts → cjs/use-media-in-timeline.d.ts} +1 -1
- package/dist/{use-media-in-timeline.js → cjs/use-media-in-timeline.js} +21 -21
- package/dist/{use-media-playback.js → cjs/use-media-playback.js} +16 -16
- package/dist/{use-sync-volume-with-media-tag.d.ts → cjs/use-sync-volume-with-media-tag.d.ts} +1 -1
- package/dist/{use-sync-volume-with-media-tag.js → cjs/use-sync-volume-with-media-tag.js} +4 -4
- package/dist/{use-unsafe-video-config.d.ts → cjs/use-unsafe-video-config.d.ts} +1 -1
- package/dist/{use-unsafe-video-config.js → cjs/use-unsafe-video-config.js} +4 -4
- package/dist/{use-video-config.d.ts → cjs/use-video-config.d.ts} +1 -1
- package/dist/{use-video-config.js → cjs/use-video-config.js} +6 -6
- package/dist/{use-video.js → cjs/use-video.js} +2 -2
- package/dist/cjs/validate-frame.d.ts +1 -0
- package/dist/cjs/validate-frame.js +24 -0
- package/dist/{validate-media-props.d.ts → cjs/validate-media-props.d.ts} +1 -1
- package/dist/cjs/version.d.ts +1 -0
- package/dist/{version.js → cjs/version.js} +1 -1
- package/dist/{video → cjs/video}/OffthreadVideo.d.ts +1 -1
- package/dist/cjs/video/OffthreadVideo.js +33 -0
- package/dist/{video → cjs/video}/OffthreadVideoForRendering.d.ts +1 -1
- package/dist/{video → cjs/video}/OffthreadVideoForRendering.js +28 -28
- package/dist/{video → cjs/video}/Video.d.ts +2 -2
- package/dist/{video → cjs/video}/Video.js +16 -16
- package/dist/{video → cjs/video}/VideoForDevelopment.d.ts +1 -1
- package/dist/{video → cjs/video}/VideoForDevelopment.js +22 -22
- package/dist/{video → cjs/video}/VideoForRendering.d.ts +1 -1
- package/dist/{video → cjs/video}/VideoForRendering.js +40 -40
- package/dist/{video → cjs/video}/get-current-time.js +2 -2
- package/dist/{video → cjs/video}/index.d.ts +3 -3
- package/dist/{video → cjs/video}/index.js +4 -4
- package/dist/{video → cjs/video}/props.d.ts +1 -1
- package/dist/cjs/wrap-remotion-context.d.ts +18 -0
- package/dist/{wrap-remotion-context.js → cjs/wrap-remotion-context.js} +16 -16
- package/dist/esm/AbsoluteFill.d.ts +6 -0
- package/dist/esm/AbsoluteFill.js +25 -0
- package/dist/esm/CanUseRemotionHooks.d.ts +5 -0
- package/dist/esm/CanUseRemotionHooks.js +6 -0
- package/dist/esm/Clipper.d.ts +7 -0
- package/dist/esm/Clipper.js +20 -0
- package/dist/esm/Composition.d.ts +23 -0
- package/dist/esm/Composition.js +108 -0
- package/dist/esm/CompositionManager.d.ts +82 -0
- package/dist/esm/CompositionManager.js +137 -0
- package/dist/esm/Folder.d.ts +15 -0
- package/dist/esm/Folder.js +29 -0
- package/dist/esm/IFrame.d.ts +2 -0
- package/dist/esm/IFrame.js +21 -0
- package/dist/esm/Img.d.ts +2 -0
- package/dist/esm/Img.js +49 -0
- package/dist/esm/NativeLayers.d.ts +13 -0
- package/dist/esm/NativeLayers.js +25 -0
- package/dist/esm/Null.d.ts +2 -0
- package/dist/esm/Null.js +21 -0
- package/dist/esm/RemotionRoot.d.ts +5 -0
- package/dist/esm/RemotionRoot.js +69 -0
- package/dist/esm/Sequence.d.ts +29 -0
- package/dist/esm/Sequence.js +128 -0
- package/dist/esm/Still.d.ts +3 -0
- package/dist/esm/Still.js +5 -0
- package/dist/esm/absolute-src.d.ts +1 -0
- package/dist/esm/absolute-src.js +3 -0
- package/dist/esm/asset-types.d.ts +50 -0
- package/dist/esm/asset-types.js +1 -0
- package/dist/esm/audio/Audio.d.ts +8 -0
- package/dist/esm/audio/Audio.js +49 -0
- package/dist/esm/audio/AudioForDevelopment.d.ts +11 -0
- package/dist/esm/audio/AudioForDevelopment.js +91 -0
- package/dist/esm/audio/AudioForRendering.d.ts +10 -0
- package/dist/esm/audio/AudioForRendering.js +108 -0
- package/dist/esm/audio/index.d.ts +2 -0
- package/dist/esm/audio/index.js +2 -0
- package/dist/esm/audio/props.d.ts +12 -0
- package/dist/esm/audio/props.js +1 -0
- package/dist/esm/audio/shared-audio-tags.d.ts +37 -0
- package/dist/esm/audio/shared-audio-tags.js +194 -0
- package/dist/esm/audio/use-audio-frame.d.ts +6 -0
- package/dist/esm/audio/use-audio-frame.js +18 -0
- package/dist/esm/bezier.d.ts +1 -0
- package/dist/esm/bezier.js +110 -0
- package/dist/esm/cancel-render.d.ts +1 -0
- package/dist/esm/cancel-render.js +39 -0
- package/dist/esm/config/input-props.d.ts +1 -0
- package/dist/esm/config/input-props.js +27 -0
- package/dist/esm/config.d.ts +285 -0
- package/dist/esm/config.js +17 -0
- package/dist/esm/default-css.d.ts +3 -0
- package/dist/esm/default-css.js +44 -0
- package/dist/esm/delay-render.d.ts +14 -0
- package/dist/esm/delay-render.js +72 -0
- package/dist/esm/easing.d.ts +19 -0
- package/dist/esm/easing.js +73 -0
- package/dist/esm/freeze.d.ts +7 -0
- package/dist/esm/freeze.js +30 -0
- package/dist/esm/get-asset-file-name.d.ts +1 -0
- package/dist/esm/get-asset-file-name.js +10 -0
- package/dist/esm/get-environment.d.ts +3 -0
- package/dist/esm/get-environment.js +29 -0
- package/dist/esm/get-preview-dom-element.d.ts +1 -0
- package/dist/esm/get-preview-dom-element.js +3 -0
- package/dist/esm/get-static-files.d.ts +17 -0
- package/dist/esm/get-static-files.js +27 -0
- package/dist/esm/get-timeline-clip-name.d.ts +1 -0
- package/dist/esm/get-timeline-clip-name.js +21 -0
- package/dist/esm/index.d.ts +92 -0
- package/dist/esm/index.js +41 -0
- package/dist/esm/internals.d.ts +99 -0
- package/dist/esm/internals.js +75 -0
- package/dist/esm/interpolate-colors.d.ts +5 -0
- package/dist/esm/interpolate-colors.js +397 -0
- package/dist/esm/interpolate.d.ts +18 -0
- package/dist/esm/interpolate.js +119 -0
- package/dist/esm/is-approximately-the-same.d.ts +1 -0
- package/dist/esm/is-approximately-the-same.js +4 -0
- package/dist/esm/is-player.d.ts +3 -0
- package/dist/esm/is-player.js +9 -0
- package/dist/esm/loading-indicator.d.ts +2 -0
- package/dist/esm/loading-indicator.js +31 -0
- package/dist/esm/loop/index.d.ts +9 -0
- package/dist/esm/loop/index.js +25 -0
- package/dist/esm/multiple-versions-warning.d.ts +1 -0
- package/dist/esm/multiple-versions-warning.js +28 -0
- package/dist/esm/nonce.d.ts +7 -0
- package/dist/esm/nonce.js +13 -0
- package/dist/esm/play-and-handle-not-allowed-error.d.ts +2 -0
- package/dist/esm/play-and-handle-not-allowed-error.js +40 -0
- package/dist/esm/portal-node.d.ts +1 -0
- package/dist/esm/portal-node.js +19 -0
- package/dist/esm/prefetch-state.d.ts +8 -0
- package/dist/esm/prefetch-state.js +22 -0
- package/dist/esm/prefetch.d.ts +9 -0
- package/dist/esm/prefetch.js +103 -0
- package/dist/esm/random.d.ts +7 -0
- package/dist/esm/random.js +38 -0
- package/dist/esm/register-root.d.ts +4 -0
- package/dist/esm/register-root.js +27 -0
- package/dist/esm/series/flatten-children.d.ts +2 -0
- package/dist/esm/series/flatten-children.js +12 -0
- package/dist/esm/series/index.d.ts +13 -0
- package/dist/esm/series/index.js +54 -0
- package/dist/esm/setup-env-variables.d.ts +2 -0
- package/dist/esm/setup-env-variables.js +32 -0
- package/dist/esm/spring/index.d.ts +27 -0
- package/dist/esm/spring/index.js +50 -0
- package/dist/esm/spring/measure-spring.d.ts +8 -0
- package/dist/esm/spring/measure-spring.js +60 -0
- package/dist/esm/spring/spring-utils.d.ts +21 -0
- package/dist/esm/spring/spring-utils.js +99 -0
- package/dist/esm/static-file.d.ts +5 -0
- package/dist/esm/static-file.js +29 -0
- package/dist/esm/test/Img.test.d.ts +1 -0
- package/dist/esm/test/Img.test.js +20 -0
- package/dist/esm/test/absolute-src.test.d.ts +1 -0
- package/dist/esm/test/absolute-src.test.js +16 -0
- package/dist/esm/test/audio-for-rendering.test.d.ts +1 -0
- package/dist/esm/test/audio-for-rendering.test.js +83 -0
- package/dist/esm/test/audio.test.d.ts +1 -0
- package/dist/esm/test/audio.test.js +51 -0
- package/dist/esm/test/bezier.test.d.ts +1 -0
- package/dist/esm/test/bezier.test.js +50 -0
- package/dist/esm/test/composition-rules.test.d.ts +1 -0
- package/dist/esm/test/composition-rules.test.js +28 -0
- package/dist/esm/test/composition-validation.test.d.ts +1 -0
- package/dist/esm/test/composition-validation.test.js +97 -0
- package/dist/esm/test/easing.test.d.ts +1 -0
- package/dist/esm/test/easing.test.js +189 -0
- package/dist/esm/test/expect-to-throw.d.ts +1 -0
- package/dist/esm/test/expect-to-throw.js +11 -0
- package/dist/esm/test/freeze.test.d.ts +1 -0
- package/dist/esm/test/freeze.test.js +63 -0
- package/dist/esm/test/get-asset-file-name.test.d.ts +1 -0
- package/dist/esm/test/get-asset-file-name.test.js +12 -0
- package/dist/esm/test/get-current-time.test.d.ts +1 -0
- package/dist/esm/test/get-current-time.test.js +72 -0
- package/dist/esm/test/input-props.test.d.ts +1 -0
- package/dist/esm/test/input-props.test.js +29 -0
- package/dist/esm/test/interpolate.test.d.ts +1 -0
- package/dist/esm/test/interpolate.test.js +136 -0
- package/dist/esm/test/interpolateColors.test.d.ts +1 -0
- package/dist/esm/test/interpolateColors.test.js +61 -0
- package/dist/esm/test/loop-validation.test.d.ts +1 -0
- package/dist/esm/test/loop-validation.test.js +68 -0
- package/dist/esm/test/measure-spring.test.d.ts +1 -0
- package/dist/esm/test/measure-spring.test.js +43 -0
- package/dist/esm/test/media-validation.test.d.ts +1 -0
- package/dist/esm/test/media-validation.test.js +45 -0
- package/dist/esm/test/nested-sequences.test.d.ts +1 -0
- package/dist/esm/test/nested-sequences.test.js +130 -0
- package/dist/esm/test/not-all-props-in-media-tags.test.d.ts +1 -0
- package/dist/esm/test/not-all-props-in-media-tags.test.js +28 -0
- package/dist/esm/test/random.test.d.ts +1 -0
- package/dist/esm/test/random.test.js +58 -0
- package/dist/esm/test/ready-manager.test.d.ts +1 -0
- package/dist/esm/test/ready-manager.test.js +27 -0
- package/dist/esm/test/render-hook.d.ts +23 -0
- package/dist/esm/test/render-hook.js +20 -0
- package/dist/esm/test/sequence-from-initial-offset.test.d.ts +4 -0
- package/dist/esm/test/sequence-from-initial-offset.test.js +33 -0
- package/dist/esm/test/sequence-validation.test.d.ts +1 -0
- package/dist/esm/test/sequence-validation.test.js +45 -0
- package/dist/esm/test/series.test.d.ts +1 -0
- package/dist/esm/test/series.test.js +108 -0
- package/dist/esm/test/spring.test.d.ts +1 -0
- package/dist/esm/test/spring.test.js +36 -0
- package/dist/esm/test/truthy.test.d.ts +1 -0
- package/dist/esm/test/truthy.test.js +22 -0
- package/dist/esm/test/use-audio-frame.test.d.ts +1 -0
- package/dist/esm/test/use-audio-frame.test.js +53 -0
- package/dist/esm/test/use-media-in-timeline.test.d.ts +1 -0
- package/dist/esm/test/use-media-in-timeline.test.js +49 -0
- package/dist/esm/test/use-media-tag-volume.test.d.ts +1 -0
- package/dist/esm/test/use-media-tag-volume.test.js +44 -0
- package/dist/esm/test/use-sync-volume-with-media-tag.test.d.ts +1 -0
- package/dist/esm/test/use-sync-volume-with-media-tag.test.js +53 -0
- package/dist/esm/test/validate-start-from-props.test.d.ts +1 -0
- package/dist/esm/test/validate-start-from-props.test.js +37 -0
- package/dist/esm/test/video.test.d.ts +1 -0
- package/dist/esm/test/video.test.js +55 -0
- package/dist/esm/test/volume-prop.test.d.ts +1 -0
- package/dist/esm/test/volume-prop.test.js +93 -0
- package/dist/esm/test/wrap-sequence-context.d.ts +6 -0
- package/dist/esm/test/wrap-sequence-context.js +37 -0
- package/dist/esm/timeline-position-state.d.ts +29 -0
- package/dist/esm/timeline-position-state.js +35 -0
- package/dist/esm/truthy.d.ts +3 -0
- package/dist/esm/truthy.js +3 -0
- package/dist/esm/use-current-frame.d.ts +6 -0
- package/dist/esm/use-current-frame.js +24 -0
- package/dist/esm/use-lazy-component.d.ts +7 -0
- package/dist/esm/use-lazy-component.js +22 -0
- package/dist/esm/use-media-in-timeline.d.ts +10 -0
- package/dist/esm/use-media-in-timeline.js +125 -0
- package/dist/esm/use-media-playback.d.ts +10 -0
- package/dist/esm/use-media-playback.js +73 -0
- package/dist/esm/use-media-tag-volume.d.ts +2 -0
- package/dist/esm/use-media-tag-volume.js +27 -0
- package/dist/esm/use-sync-volume-with-media-tag.d.ts +10 -0
- package/dist/esm/use-sync-volume-with-media-tag.js +17 -0
- package/dist/esm/use-unsafe-video-config.d.ts +2 -0
- package/dist/esm/use-unsafe-video-config.js +23 -0
- package/dist/esm/use-video-config.d.ts +7 -0
- package/dist/esm/use-video-config.js +25 -0
- package/dist/esm/use-video.d.ts +13 -0
- package/dist/esm/use-video.js +24 -0
- package/dist/esm/validate-frame.d.ts +1 -0
- package/dist/esm/validate-frame.js +20 -0
- package/dist/esm/validate-media-props.d.ts +4 -0
- package/dist/esm/validate-media-props.js +20 -0
- package/dist/esm/validate-start-from-props.d.ts +1 -0
- package/dist/esm/validate-start-from-props.js +27 -0
- package/dist/esm/validation/validate-composition-id.d.ts +3 -0
- package/dist/esm/validation/validate-composition-id.js +8 -0
- package/dist/esm/validation/validate-dimensions.d.ts +1 -0
- package/dist/esm/validation/validate-dimensions.js +17 -0
- package/dist/esm/validation/validate-duration-in-frames.d.ts +1 -0
- package/dist/esm/validation/validate-duration-in-frames.js +11 -0
- package/dist/esm/validation/validate-folder-name.d.ts +3 -0
- package/dist/esm/validation/validate-folder-name.js +14 -0
- package/dist/esm/validation/validate-fps.d.ts +1 -0
- package/dist/esm/validation/validate-fps.js +17 -0
- package/dist/esm/validation/validate-offthreadvideo-image-format.d.ts +1 -0
- package/dist/esm/validation/validate-offthreadvideo-image-format.js +11 -0
- package/dist/esm/validation/validation-spring-duration.d.ts +1 -0
- package/dist/esm/validation/validation-spring-duration.js +17 -0
- package/dist/esm/version.d.ts +1 -0
- package/dist/esm/version.js +2 -0
- package/dist/esm/video/OffthreadVideo.d.ts +3 -0
- package/dist/esm/video/OffthreadVideo.js +29 -0
- package/dist/esm/video/OffthreadVideoForRendering.d.ts +3 -0
- package/dist/esm/video/OffthreadVideoForRendering.js +100 -0
- package/dist/esm/video/Video.d.ts +8 -0
- package/dist/esm/video/Video.js +47 -0
- package/dist/esm/video/VideoForDevelopment.d.ts +11 -0
- package/dist/esm/video/VideoForDevelopment.js +110 -0
- package/dist/esm/video/VideoForRendering.d.ts +10 -0
- package/dist/esm/video/VideoForRendering.js +200 -0
- package/dist/esm/video/duration-state.d.ts +17 -0
- package/dist/esm/video/duration-state.js +29 -0
- package/dist/esm/video/get-current-time.d.ts +13 -0
- package/dist/esm/video/get-current-time.js +26 -0
- package/dist/esm/video/index.d.ts +3 -0
- package/dist/esm/video/index.js +2 -0
- package/dist/esm/video/props.d.ts +25 -0
- package/dist/esm/video/props.js +1 -0
- package/dist/esm/video/video-fragment.d.ts +12 -0
- package/dist/esm/video/video-fragment.js +55 -0
- package/dist/esm/video-config.d.ts +8 -0
- package/dist/esm/video-config.js +1 -0
- package/dist/esm/volume-position-state.d.ts +19 -0
- package/dist/esm/volume-position-state.js +27 -0
- package/dist/esm/volume-prop.d.ts +7 -0
- package/dist/esm/volume-prop.js +20 -0
- package/dist/esm/warn-about-non-seekable-media.d.ts +1 -0
- package/dist/esm/warn-about-non-seekable-media.js +30 -0
- package/dist/esm/wrap-remotion-context.d.ts +18 -0
- package/dist/esm/wrap-remotion-context.js +45 -0
- package/dist/tsconfig-cjs.tsbuildinfo +1 -0
- package/package.json +22 -11
- package/tsconfig-cjs.json +11 -0
- package/tsconfig.json +3 -3
- package/dist/LayerMaster.d.ts +0 -8
- package/dist/LayerMaster.js +0 -39
- package/dist/Satori.d.ts +0 -5
- package/dist/Satori.js +0 -92
- package/dist/audio/index.d.ts +0 -2
- package/dist/config.d.ts +0 -291
- package/dist/get-compositions-from-markup.d.ts +0 -3
- package/dist/get-compositions-from-markup.js +0 -19
- package/dist/internals.js +0 -99
- package/dist/layers.d.ts +0 -24
- package/dist/layers.js +0 -149
- package/dist/version.d.ts +0 -1
- package/dist/video/NativeVideo.d.ts +0 -5
- package/dist/video/NativeVideo.js +0 -33
- package/dist/video/NativeVideoForRendering.d.ts +0 -8
- package/dist/video/NativeVideoForRendering.js +0 -14
- package/dist/video/OffthreadVideo.js +0 -33
- package/dist/wrap-remotion-context.d.ts +0 -18
- /package/dist/{AbsoluteFill.d.ts → cjs/AbsoluteFill.d.ts} +0 -0
- /package/dist/{AbsoluteFill.js → cjs/AbsoluteFill.js} +0 -0
- /package/dist/{CanUseRemotionHooks.d.ts → cjs/CanUseRemotionHooks.d.ts} +0 -0
- /package/dist/{CanUseRemotionHooks.js → cjs/CanUseRemotionHooks.js} +0 -0
- /package/dist/{Clipper.d.ts → cjs/Clipper.d.ts} +0 -0
- /package/dist/{Composition.d.ts → cjs/Composition.d.ts} +0 -0
- /package/dist/{Folder.d.ts → cjs/Folder.d.ts} +0 -0
- /package/dist/{IFrame.d.ts → cjs/IFrame.d.ts} +0 -0
- /package/dist/{Img.d.ts → cjs/Img.d.ts} +0 -0
- /package/dist/{NativeLayers.d.ts → cjs/NativeLayers.d.ts} +0 -0
- /package/dist/{NativeLayers.js → cjs/NativeLayers.js} +0 -0
- /package/dist/{Null.d.ts → cjs/Null.d.ts} +0 -0
- /package/dist/{RemotionRoot.d.ts → cjs/RemotionRoot.d.ts} +0 -0
- /package/dist/{absolute-src.d.ts → cjs/absolute-src.d.ts} +0 -0
- /package/dist/{absolute-src.js → cjs/absolute-src.js} +0 -0
- /package/dist/{asset-types.d.ts → cjs/asset-types.d.ts} +0 -0
- /package/dist/{asset-types.js → cjs/asset-types.js} +0 -0
- /package/dist/{audio → cjs/audio}/props.js +0 -0
- /package/dist/{audio → cjs/audio}/shared-audio-tags.js +0 -0
- /package/dist/{audio → cjs/audio}/use-audio-frame.d.ts +0 -0
- /package/dist/{bezier.d.ts → cjs/bezier.d.ts} +0 -0
- /package/dist/{bezier.js → cjs/bezier.js} +0 -0
- /package/dist/{cancel-render.d.ts → cjs/cancel-render.d.ts} +0 -0
- /package/dist/{cancel-render.js → cjs/cancel-render.js} +0 -0
- /package/dist/{config → cjs/config}/input-props.d.ts +0 -0
- /package/dist/{config.js → cjs/config.js} +0 -0
- /package/dist/{default-css.d.ts → cjs/default-css.d.ts} +0 -0
- /package/dist/{default-css.js → cjs/default-css.js} +0 -0
- /package/dist/{delay-render.d.ts → cjs/delay-render.d.ts} +0 -0
- /package/dist/{easing.d.ts → cjs/easing.d.ts} +0 -0
- /package/dist/{freeze.d.ts → cjs/freeze.d.ts} +0 -0
- /package/dist/{get-asset-file-name.d.ts → cjs/get-asset-file-name.d.ts} +0 -0
- /package/dist/{get-asset-file-name.js → cjs/get-asset-file-name.js} +0 -0
- /package/dist/{get-environment.d.ts → cjs/get-environment.d.ts} +0 -0
- /package/dist/{get-preview-dom-element.d.ts → cjs/get-preview-dom-element.d.ts} +0 -0
- /package/dist/{get-preview-dom-element.js → cjs/get-preview-dom-element.js} +0 -0
- /package/dist/{get-static-files.d.ts → cjs/get-static-files.d.ts} +0 -0
- /package/dist/{get-static-files.js → cjs/get-static-files.js} +0 -0
- /package/dist/{get-timeline-clip-name.d.ts → cjs/get-timeline-clip-name.d.ts} +0 -0
- /package/dist/{get-timeline-clip-name.js → cjs/get-timeline-clip-name.js} +0 -0
- /package/dist/{interpolate-colors.d.ts → cjs/interpolate-colors.d.ts} +0 -0
- /package/dist/{interpolate.d.ts → cjs/interpolate.d.ts} +0 -0
- /package/dist/{interpolate.js → cjs/interpolate.js} +0 -0
- /package/dist/{is-approximately-the-same.d.ts → cjs/is-approximately-the-same.d.ts} +0 -0
- /package/dist/{is-approximately-the-same.js → cjs/is-approximately-the-same.js} +0 -0
- /package/dist/{is-player.d.ts → cjs/is-player.d.ts} +0 -0
- /package/dist/{is-player.js → cjs/is-player.js} +0 -0
- /package/dist/{loading-indicator.d.ts → cjs/loading-indicator.d.ts} +0 -0
- /package/dist/{multiple-versions-warning.d.ts → cjs/multiple-versions-warning.d.ts} +0 -0
- /package/dist/{nonce.d.ts → cjs/nonce.d.ts} +0 -0
- /package/dist/{nonce.js → cjs/nonce.js} +0 -0
- /package/dist/{play-and-handle-not-allowed-error.d.ts → cjs/play-and-handle-not-allowed-error.d.ts} +0 -0
- /package/dist/{play-and-handle-not-allowed-error.js → cjs/play-and-handle-not-allowed-error.js} +0 -0
- /package/dist/{portal-node.d.ts → cjs/portal-node.d.ts} +0 -0
- /package/dist/{portal-node.js → cjs/portal-node.js} +0 -0
- /package/dist/{prefetch-state.d.ts → cjs/prefetch-state.d.ts} +0 -0
- /package/dist/{prefetch-state.js → cjs/prefetch-state.js} +0 -0
- /package/dist/{prefetch.d.ts → cjs/prefetch.d.ts} +0 -0
- /package/dist/{random.d.ts → cjs/random.d.ts} +0 -0
- /package/dist/{register-root.d.ts → cjs/register-root.d.ts} +0 -0
- /package/dist/{register-root.js → cjs/register-root.js} +0 -0
- /package/dist/{series → cjs/series}/flatten-children.d.ts +0 -0
- /package/dist/{series → cjs/series}/flatten-children.js +0 -0
- /package/dist/{setup-env-variables.d.ts → cjs/setup-env-variables.d.ts} +0 -0
- /package/dist/{spring → cjs/spring}/spring-utils.d.ts +0 -0
- /package/dist/{spring → cjs/spring}/spring-utils.js +0 -0
- /package/dist/{static-file.d.ts → cjs/static-file.d.ts} +0 -0
- /package/dist/{static-file.js → cjs/static-file.js} +0 -0
- /package/dist/{timeline-position-state.d.ts → cjs/timeline-position-state.d.ts} +0 -0
- /package/dist/{timeline-position-state.js → cjs/timeline-position-state.js} +0 -0
- /package/dist/{truthy.d.ts → cjs/truthy.d.ts} +0 -0
- /package/dist/{truthy.js → cjs/truthy.js} +0 -0
- /package/dist/{use-current-frame.d.ts → cjs/use-current-frame.d.ts} +0 -0
- /package/dist/{use-lazy-component.js → cjs/use-lazy-component.js} +0 -0
- /package/dist/{use-media-playback.d.ts → cjs/use-media-playback.d.ts} +0 -0
- /package/dist/{use-media-tag-volume.d.ts → cjs/use-media-tag-volume.d.ts} +0 -0
- /package/dist/{use-media-tag-volume.js → cjs/use-media-tag-volume.js} +0 -0
- /package/dist/{use-video.d.ts → cjs/use-video.d.ts} +0 -0
- /package/dist/{validate-media-props.js → cjs/validate-media-props.js} +0 -0
- /package/dist/{validate-start-from-props.d.ts → cjs/validate-start-from-props.d.ts} +0 -0
- /package/dist/{validate-start-from-props.js → cjs/validate-start-from-props.js} +0 -0
- /package/dist/{validation → cjs/validation}/validate-composition-id.d.ts +0 -0
- /package/dist/{validation → cjs/validation}/validate-composition-id.js +0 -0
- /package/dist/{validation → cjs/validation}/validate-dimensions.d.ts +0 -0
- /package/dist/{validation → cjs/validation}/validate-dimensions.js +0 -0
- /package/dist/{validation → cjs/validation}/validate-duration-in-frames.d.ts +0 -0
- /package/dist/{validation → cjs/validation}/validate-duration-in-frames.js +0 -0
- /package/dist/{validation → cjs/validation}/validate-folder-name.d.ts +0 -0
- /package/dist/{validation → cjs/validation}/validate-folder-name.js +0 -0
- /package/dist/{validation → cjs/validation}/validate-fps.d.ts +0 -0
- /package/dist/{validation → cjs/validation}/validate-fps.js +0 -0
- /package/dist/{validation → cjs/validation}/validate-offthreadvideo-image-format.d.ts +0 -0
- /package/dist/{validation → cjs/validation}/validate-offthreadvideo-image-format.js +0 -0
- /package/dist/{validation → cjs/validation}/validation-spring-duration.d.ts +0 -0
- /package/dist/{validation → cjs/validation}/validation-spring-duration.js +0 -0
- /package/dist/{video → cjs/video}/duration-state.d.ts +0 -0
- /package/dist/{video → cjs/video}/duration-state.js +0 -0
- /package/dist/{video → cjs/video}/get-current-time.d.ts +0 -0
- /package/dist/{video → cjs/video}/props.js +0 -0
- /package/dist/{video → cjs/video}/video-fragment.d.ts +0 -0
- /package/dist/{video → cjs/video}/video-fragment.js +0 -0
- /package/dist/{video-config.d.ts → cjs/video-config.d.ts} +0 -0
- /package/dist/{video-config.js → cjs/video-config.js} +0 -0
- /package/dist/{volume-position-state.d.ts → cjs/volume-position-state.d.ts} +0 -0
- /package/dist/{volume-position-state.js → cjs/volume-position-state.js} +0 -0
- /package/dist/{volume-prop.d.ts → cjs/volume-prop.d.ts} +0 -0
- /package/dist/{volume-prop.js → cjs/volume-prop.js} +0 -0
- /package/dist/{warn-about-non-seekable-media.d.ts → cjs/warn-about-non-seekable-media.d.ts} +0 -0
- /package/dist/{warn-about-non-seekable-media.js → cjs/warn-about-non-seekable-media.js} +0 -0
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { expect, test } from 'vitest';
|
|
2
|
+
import { truthy } from '../truthy.js';
|
|
3
|
+
test.each([
|
|
4
|
+
['true', true],
|
|
5
|
+
['false', true],
|
|
6
|
+
['True', true],
|
|
7
|
+
['False', true],
|
|
8
|
+
['', false],
|
|
9
|
+
['abc', true],
|
|
10
|
+
[true, true],
|
|
11
|
+
[false, false],
|
|
12
|
+
[null, false],
|
|
13
|
+
[undefined, false],
|
|
14
|
+
[0, false],
|
|
15
|
+
[1, true],
|
|
16
|
+
[0.5, true],
|
|
17
|
+
[12, true],
|
|
18
|
+
[-1, true],
|
|
19
|
+
[-4, true],
|
|
20
|
+
])('test with %s', (input, expected) => {
|
|
21
|
+
expect(truthy(input)).toEqual(expected);
|
|
22
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { afterAll, beforeAll, describe, expect, test, vitest } from 'vitest';
|
|
3
|
+
import * as useAudioFrameModule from '../audio/use-audio-frame.js';
|
|
4
|
+
import { useFrameForVolumeProp, useMediaStartsAt, } from '../audio/use-audio-frame.js';
|
|
5
|
+
import { SequenceContext } from '../Sequence.js';
|
|
6
|
+
import * as useFrameModule from '../use-current-frame.js';
|
|
7
|
+
import { renderHook } from './render-hook.js';
|
|
8
|
+
test.skip('Media starts at 0 if it is outside a sequence', () => {
|
|
9
|
+
const wrapper = ({ children }) => (_jsx(SequenceContext.Provider, { value: null, children: children }));
|
|
10
|
+
const { result } = renderHook(() => useMediaStartsAt(), { wrapper });
|
|
11
|
+
expect(result.current).toEqual(0);
|
|
12
|
+
});
|
|
13
|
+
test.skip('Media start is shifted back based on sequence', () => {
|
|
14
|
+
const mockSequence = {
|
|
15
|
+
cumulatedFrom: 0,
|
|
16
|
+
relativeFrom: -100,
|
|
17
|
+
parentFrom: 0,
|
|
18
|
+
durationInFrames: 0,
|
|
19
|
+
id: 'mock',
|
|
20
|
+
};
|
|
21
|
+
const wrapper = ({ children }) => (_jsx(SequenceContext.Provider, { value: mockSequence, children: children }));
|
|
22
|
+
const { result } = renderHook(() => useMediaStartsAt(), { wrapper });
|
|
23
|
+
expect(result.current).toEqual(-100);
|
|
24
|
+
});
|
|
25
|
+
describe('useFrameForVolumeProp hook tests', () => {
|
|
26
|
+
beforeAll(() => {
|
|
27
|
+
vitest
|
|
28
|
+
.spyOn(useAudioFrameModule, 'useMediaStartsAt')
|
|
29
|
+
.mockImplementation(() => -10);
|
|
30
|
+
});
|
|
31
|
+
afterAll(() => {
|
|
32
|
+
vitest.spyOn(useAudioFrameModule, 'useMediaStartsAt').mockRestore();
|
|
33
|
+
});
|
|
34
|
+
test.skip('Media not mounted', () => {
|
|
35
|
+
vitest.spyOn(useFrameModule, 'useCurrentFrame').mockImplementation(() => 9);
|
|
36
|
+
const { result } = renderHook(() => useFrameForVolumeProp());
|
|
37
|
+
expect(result.current).toEqual(-1);
|
|
38
|
+
});
|
|
39
|
+
test.skip('Media mounted', () => {
|
|
40
|
+
vitest
|
|
41
|
+
.spyOn(useFrameModule, 'useCurrentFrame')
|
|
42
|
+
.mockImplementation(() => 10);
|
|
43
|
+
const { result } = renderHook(() => useFrameForVolumeProp());
|
|
44
|
+
expect(result.current).toEqual(0);
|
|
45
|
+
});
|
|
46
|
+
test.skip('Media mounted + 1 frame', () => {
|
|
47
|
+
vitest
|
|
48
|
+
.spyOn(useFrameModule, 'useCurrentFrame')
|
|
49
|
+
.mockImplementation(() => 11);
|
|
50
|
+
const { result } = renderHook(() => useFrameForVolumeProp());
|
|
51
|
+
expect(result.current).toEqual(1);
|
|
52
|
+
});
|
|
53
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { afterAll, beforeAll, expect, test, vitest } from 'vitest';
|
|
3
|
+
import { Internals } from '../internals.js';
|
|
4
|
+
import { useMediaInTimeline } from '../use-media-in-timeline.js';
|
|
5
|
+
import * as useVideoConfigModule from '../use-video-config.js';
|
|
6
|
+
import { renderHook } from './render-hook.js';
|
|
7
|
+
import { mockCompositionContext } from './wrap-sequence-context.js';
|
|
8
|
+
beforeAll(() => {
|
|
9
|
+
vitest
|
|
10
|
+
.spyOn(useVideoConfigModule, 'useVideoConfig')
|
|
11
|
+
.mockImplementation(() => ({
|
|
12
|
+
width: 10,
|
|
13
|
+
height: 10,
|
|
14
|
+
fps: 30,
|
|
15
|
+
durationInFrames: 100,
|
|
16
|
+
id: 'hithere',
|
|
17
|
+
defaultProps: () => ({}),
|
|
18
|
+
}));
|
|
19
|
+
});
|
|
20
|
+
afterAll(() => {
|
|
21
|
+
vitest.spyOn(useVideoConfigModule, 'useVideoConfig').mockClear();
|
|
22
|
+
});
|
|
23
|
+
test('useMediaInTimeline registers and unregisters new sequence', () => {
|
|
24
|
+
const registerSequence = vitest.fn();
|
|
25
|
+
const unregisterSequence = vitest.fn();
|
|
26
|
+
const wrapper = ({ children }) => (_jsx(Internals.CompositionManager.Provider, { value:
|
|
27
|
+
// eslint-disable-next-line react/jsx-no-constructed-context-values
|
|
28
|
+
{
|
|
29
|
+
...mockCompositionContext,
|
|
30
|
+
registerSequence,
|
|
31
|
+
unregisterSequence,
|
|
32
|
+
}, children: children }));
|
|
33
|
+
const audioRef = {
|
|
34
|
+
current: { volume: 0.5 },
|
|
35
|
+
};
|
|
36
|
+
const { unmount } = renderHook(() => useMediaInTimeline({
|
|
37
|
+
volume: 1,
|
|
38
|
+
src: 'test',
|
|
39
|
+
mediaVolume: 1,
|
|
40
|
+
mediaType: 'audio',
|
|
41
|
+
mediaRef: audioRef,
|
|
42
|
+
playbackRate: 1,
|
|
43
|
+
}), {
|
|
44
|
+
wrapper,
|
|
45
|
+
});
|
|
46
|
+
expect(registerSequence).toHaveBeenCalled();
|
|
47
|
+
unmount();
|
|
48
|
+
expect(unregisterSequence).toHaveBeenCalled();
|
|
49
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { afterEach, beforeEach, describe, expect, test, vitest } from 'vitest';
|
|
3
|
+
import { useMediaTagVolume } from '../use-media-tag-volume.js';
|
|
4
|
+
import { renderHook } from './render-hook.js';
|
|
5
|
+
describe('Should update state when volume changes', () => {
|
|
6
|
+
const setState = vitest.fn();
|
|
7
|
+
const useStateSpy = vitest.spyOn(React, 'useState');
|
|
8
|
+
beforeEach(() => {
|
|
9
|
+
// @ts-expect-error
|
|
10
|
+
useStateSpy.mockImplementation((init) => [init, setState]);
|
|
11
|
+
});
|
|
12
|
+
afterEach(() => {
|
|
13
|
+
useStateSpy.mockRestore();
|
|
14
|
+
});
|
|
15
|
+
test.skip('has the volume been set', () => {
|
|
16
|
+
const addEventListener = vitest.fn();
|
|
17
|
+
const removeEventListener = vitest.fn();
|
|
18
|
+
let audioRef = {
|
|
19
|
+
current: { volume: 0.5, addEventListener, removeEventListener },
|
|
20
|
+
};
|
|
21
|
+
const { rerender } = renderHook(({ mediaRef }) => useMediaTagVolume(mediaRef), {
|
|
22
|
+
initialProps: { mediaRef: audioRef },
|
|
23
|
+
});
|
|
24
|
+
expect(setState).toHaveBeenCalledWith(0.5);
|
|
25
|
+
audioRef = {
|
|
26
|
+
current: { ...audioRef.current, volume: 0.75 },
|
|
27
|
+
};
|
|
28
|
+
rerender({ mediaRef: audioRef });
|
|
29
|
+
expect(setState).toHaveBeenCalledWith(0.75);
|
|
30
|
+
expect(addEventListener).toHaveBeenCalledWith('volumechange', expect.anything());
|
|
31
|
+
expect(removeEventListener).toHaveBeenCalledWith('volumechange', expect.anything());
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
test('Should listen for volume changes', () => {
|
|
35
|
+
const addEventListener = vitest.fn();
|
|
36
|
+
const removeEventListener = vitest.fn();
|
|
37
|
+
const audioRef = {
|
|
38
|
+
current: { volume: 0.5, addEventListener, removeEventListener },
|
|
39
|
+
};
|
|
40
|
+
renderHook(({ mediaRef }) => useMediaTagVolume(mediaRef), {
|
|
41
|
+
initialProps: { mediaRef: audioRef },
|
|
42
|
+
});
|
|
43
|
+
expect(addEventListener).toHaveBeenCalledTimes(1);
|
|
44
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { expect, test, vitest } from 'vitest';
|
|
2
|
+
import { useSyncVolumeWithMediaTag } from '../use-sync-volume-with-media-tag.js';
|
|
3
|
+
import { renderHook } from './render-hook.js';
|
|
4
|
+
test('has the volume been adapted', () => {
|
|
5
|
+
var _a, _b;
|
|
6
|
+
const addEventListener = vitest.fn();
|
|
7
|
+
const removeEventListener = vitest.fn();
|
|
8
|
+
const audioRef = {
|
|
9
|
+
current: { volume: 0.5, addEventListener, removeEventListener },
|
|
10
|
+
};
|
|
11
|
+
const volume = 0.6;
|
|
12
|
+
const volumePropFrame = 1;
|
|
13
|
+
const actualVolume = 0.4;
|
|
14
|
+
const initialProps = {
|
|
15
|
+
volumePropFrame,
|
|
16
|
+
actualVolume,
|
|
17
|
+
volume,
|
|
18
|
+
mediaRef: audioRef,
|
|
19
|
+
mediaVolume: 1,
|
|
20
|
+
};
|
|
21
|
+
const { rerender } = renderHook((hookProps) => useSyncVolumeWithMediaTag(hookProps), {
|
|
22
|
+
initialProps,
|
|
23
|
+
});
|
|
24
|
+
expect((_a = audioRef.current) === null || _a === void 0 ? void 0 : _a.volume).toEqual(initialProps.volume);
|
|
25
|
+
const newVolume = 0.5;
|
|
26
|
+
rerender({
|
|
27
|
+
...initialProps,
|
|
28
|
+
volume: newVolume,
|
|
29
|
+
});
|
|
30
|
+
expect((_b = audioRef.current) === null || _b === void 0 ? void 0 : _b.volume).toEqual(newVolume);
|
|
31
|
+
});
|
|
32
|
+
test('volume should not be adapted', () => {
|
|
33
|
+
var _a;
|
|
34
|
+
const addEventListener = vitest.fn();
|
|
35
|
+
const removeEventListener = vitest.fn();
|
|
36
|
+
const audioRef = {
|
|
37
|
+
current: { volume: 0.4, addEventListener, removeEventListener },
|
|
38
|
+
};
|
|
39
|
+
const volume = 0.4;
|
|
40
|
+
const volumePropFrame = 1;
|
|
41
|
+
const actualVolume = 0.4;
|
|
42
|
+
const initialProps = {
|
|
43
|
+
volumePropFrame,
|
|
44
|
+
actualVolume,
|
|
45
|
+
volume,
|
|
46
|
+
mediaRef: audioRef,
|
|
47
|
+
mediaVolume: 1,
|
|
48
|
+
};
|
|
49
|
+
renderHook((hookProps) => useSyncVolumeWithMediaTag(hookProps), {
|
|
50
|
+
initialProps,
|
|
51
|
+
});
|
|
52
|
+
expect((_a = audioRef.current) === null || _a === void 0 ? void 0 : _a.volume).toEqual(initialProps.volume);
|
|
53
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { describe, test } from 'vitest';
|
|
2
|
+
import { validateStartFromProps } from '../validate-start-from-props.js';
|
|
3
|
+
import { expectToThrow } from './expect-to-throw.js';
|
|
4
|
+
describe('ValidateStartFrom props should throw', () => {
|
|
5
|
+
describe('Throw with invalid startFrom prop', () => {
|
|
6
|
+
test('It should throw if startFrom prop is negative', () => {
|
|
7
|
+
expectToThrow(() => validateStartFromProps(-40, 1), /startFrom must be greater than equal to 0 instead got -40./);
|
|
8
|
+
});
|
|
9
|
+
test('It should throw if startFrom is not a number', () => {
|
|
10
|
+
expectToThrow(
|
|
11
|
+
// @ts-expect-error
|
|
12
|
+
() => validateStartFromProps('10', 20), /type of startFrom prop must be a number, instead got type string./);
|
|
13
|
+
});
|
|
14
|
+
test('It should throw if startFrom is NaN', () => {
|
|
15
|
+
expectToThrow(() => validateStartFromProps(NaN, 20), /startFrom prop can not be NaN or Infinity./);
|
|
16
|
+
});
|
|
17
|
+
test('It should throw if startFrom is Infinity', () => {
|
|
18
|
+
expectToThrow(() => validateStartFromProps(Infinity, 20), /startFrom prop can not be NaN or Infinity./);
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
describe('Throw with invalid endAt prop', () => {
|
|
22
|
+
test('It should throw if endAt prop is negative', () => {
|
|
23
|
+
expectToThrow(() => validateStartFromProps(0, -40), /endAt must be a positive number, instead got -40./);
|
|
24
|
+
});
|
|
25
|
+
test('It should throw if endAt is less than startFrom', () => {
|
|
26
|
+
expectToThrow(() => validateStartFromProps(10, 1), /endAt prop must be greater than startFrom prop./);
|
|
27
|
+
});
|
|
28
|
+
test('It should throw if endAt is not a number', () => {
|
|
29
|
+
expectToThrow(
|
|
30
|
+
// @ts-expect-error
|
|
31
|
+
() => validateStartFromProps(10, '20'), /type of endAt prop must be a number, instead got type string./);
|
|
32
|
+
});
|
|
33
|
+
test('It should throw if endAt is NaN', () => {
|
|
34
|
+
expectToThrow(() => validateStartFromProps(10, NaN), /endAt prop can not be NaN./);
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* @vitest-environment jsdom
|
|
4
|
+
*/
|
|
5
|
+
import { render } from '@testing-library/react';
|
|
6
|
+
import React, { useContext } from 'react';
|
|
7
|
+
import { describe, expect, test } from 'vitest';
|
|
8
|
+
import { CanUseRemotionHooksProvider } from '../CanUseRemotionHooks.js';
|
|
9
|
+
import { Internals } from '../internals.js';
|
|
10
|
+
import { Video } from '../video';
|
|
11
|
+
import { expectToThrow } from './expect-to-throw.js';
|
|
12
|
+
const Wrapper = ({ children }) => {
|
|
13
|
+
const compositions = useContext(Internals.CompositionManager);
|
|
14
|
+
return (_jsx(CanUseRemotionHooksProvider, { children: _jsx(Internals.RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Internals.CompositionManager.Provider
|
|
15
|
+
// eslint-disable-next-line react/jsx-no-constructed-context-values
|
|
16
|
+
, {
|
|
17
|
+
// eslint-disable-next-line react/jsx-no-constructed-context-values
|
|
18
|
+
value: {
|
|
19
|
+
...compositions,
|
|
20
|
+
compositions: [
|
|
21
|
+
{
|
|
22
|
+
height: 1080,
|
|
23
|
+
width: 1080,
|
|
24
|
+
fps: 30,
|
|
25
|
+
durationInFrames: 30,
|
|
26
|
+
id: 'markup',
|
|
27
|
+
nonce: 0,
|
|
28
|
+
component: React.lazy(() => Promise.resolve({
|
|
29
|
+
default: (() => null),
|
|
30
|
+
})),
|
|
31
|
+
defaultProps: undefined,
|
|
32
|
+
folderName: null,
|
|
33
|
+
parentFolderName: null,
|
|
34
|
+
},
|
|
35
|
+
],
|
|
36
|
+
currentComposition: 'markup',
|
|
37
|
+
}, children: children }) }) }));
|
|
38
|
+
};
|
|
39
|
+
describe('Render correctly with props', () => {
|
|
40
|
+
test('It should render Video without startFrom / endAt props', () => {
|
|
41
|
+
expect(() => render(_jsx(Wrapper, { children: _jsx(Video, { src: "test" }) }))).not.toThrow();
|
|
42
|
+
});
|
|
43
|
+
test('It should render Video with startFrom props', () => {
|
|
44
|
+
expect(() => render(_jsx(Wrapper, { children: _jsx(Video, { src: "test", startFrom: 10 }) }))).not.toThrow();
|
|
45
|
+
});
|
|
46
|
+
test('It should render Video with endAt props', () => {
|
|
47
|
+
expect(() => render(_jsx(Wrapper, { children: _jsx(Video, { src: "test", endAt: 10 }) }))).not.toThrow();
|
|
48
|
+
});
|
|
49
|
+
test('It should render Video with startFrom and endAt props', () => {
|
|
50
|
+
expect(() => render(_jsx(Wrapper, { children: _jsx(Video, { src: "test", startFrom: 10, endAt: 15 }) }))).not.toThrow();
|
|
51
|
+
});
|
|
52
|
+
test('It should throw if videoConfig/Wrapper is missing', () => {
|
|
53
|
+
expectToThrow(() => render(_jsx(CanUseRemotionHooksProvider, { children: _jsx(Video, { startFrom: 10, endAt: 15 }) })), /No video config found/);
|
|
54
|
+
});
|
|
55
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { describe, expect, test } from 'vitest';
|
|
2
|
+
import { evaluateVolume } from '../volume-prop.js';
|
|
3
|
+
import { expectToThrow } from './expect-to-throw.js';
|
|
4
|
+
describe('EvaluateVolume does not throw', () => {
|
|
5
|
+
test('Volume is undefined', () => {
|
|
6
|
+
const toEvaluate = {
|
|
7
|
+
frame: 10,
|
|
8
|
+
volume: undefined,
|
|
9
|
+
mediaVolume: 1,
|
|
10
|
+
allowAmplificationDuringRender: false,
|
|
11
|
+
};
|
|
12
|
+
expect(evaluateVolume(toEvaluate)).toEqual(1);
|
|
13
|
+
});
|
|
14
|
+
test('Volume is smaller than one', () => {
|
|
15
|
+
const smallVolume = 0.5;
|
|
16
|
+
const toEvaluate = {
|
|
17
|
+
frame: 10,
|
|
18
|
+
volume: smallVolume,
|
|
19
|
+
mediaVolume: 1,
|
|
20
|
+
allowAmplificationDuringRender: false,
|
|
21
|
+
};
|
|
22
|
+
expect(evaluateVolume(toEvaluate)).toEqual(smallVolume);
|
|
23
|
+
});
|
|
24
|
+
test('Volume is bigger than one', () => {
|
|
25
|
+
const toEvaluate = {
|
|
26
|
+
frame: 10,
|
|
27
|
+
volume: 10,
|
|
28
|
+
mediaVolume: 1,
|
|
29
|
+
allowAmplificationDuringRender: true,
|
|
30
|
+
};
|
|
31
|
+
expect(evaluateVolume(toEvaluate)).toBe(10);
|
|
32
|
+
});
|
|
33
|
+
test('evaluated volume from frame that is smaller than one', () => {
|
|
34
|
+
const toEvaluate = {
|
|
35
|
+
frame: 1,
|
|
36
|
+
volume: (frame) => frame * 0.5,
|
|
37
|
+
mediaVolume: 1,
|
|
38
|
+
allowAmplificationDuringRender: false,
|
|
39
|
+
};
|
|
40
|
+
expect(evaluateVolume(toEvaluate)).toBe(0.5);
|
|
41
|
+
});
|
|
42
|
+
test('evaluated volume from frame that is bigger than one', () => {
|
|
43
|
+
const toEvaluate = {
|
|
44
|
+
frame: 10,
|
|
45
|
+
volume: (frame) => frame,
|
|
46
|
+
mediaVolume: 1,
|
|
47
|
+
allowAmplificationDuringRender: false,
|
|
48
|
+
};
|
|
49
|
+
expect(evaluateVolume(toEvaluate)).toBe(1);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
describe('evaluateVolume throws exception', () => {
|
|
53
|
+
test('It should throw if volume prop is neither number nor undefined', () => {
|
|
54
|
+
const toEvaluate = { frame: 10, volume: 'NaN' };
|
|
55
|
+
expectToThrow(() => {
|
|
56
|
+
// @ts-expect-error
|
|
57
|
+
evaluateVolume(toEvaluate);
|
|
58
|
+
}, /volume is not a function/);
|
|
59
|
+
});
|
|
60
|
+
test('It should throw if volume is invalid type', () => {
|
|
61
|
+
const invalidVolume = 'anystring';
|
|
62
|
+
const toEvaluate = { frame: 1, volume: () => invalidVolume, mediaVolume: 1 };
|
|
63
|
+
// changing the test because string multiply by a number in javascript is `NaN`
|
|
64
|
+
expectToThrow(() => {
|
|
65
|
+
// @ts-expect-error
|
|
66
|
+
evaluateVolume(toEvaluate);
|
|
67
|
+
}, /You passed in a function to the volume prop but it returned NaN for frame 1./);
|
|
68
|
+
});
|
|
69
|
+
test('It should throw if volume is NaN', () => {
|
|
70
|
+
const invalidVolume = NaN;
|
|
71
|
+
const toEvaluate = {
|
|
72
|
+
frame: 1,
|
|
73
|
+
volume: () => invalidVolume,
|
|
74
|
+
mediaVolume: 1,
|
|
75
|
+
allowAmplificationDuringRender: false,
|
|
76
|
+
};
|
|
77
|
+
expectToThrow(() => {
|
|
78
|
+
evaluateVolume(toEvaluate);
|
|
79
|
+
}, /You passed in a function to the volume prop but it returned NaN for frame 1/);
|
|
80
|
+
});
|
|
81
|
+
test('It should throw if volume returns non finite number', () => {
|
|
82
|
+
const invalidVolume = Infinity;
|
|
83
|
+
const toEvaluate = {
|
|
84
|
+
frame: 1,
|
|
85
|
+
volume: () => invalidVolume,
|
|
86
|
+
mediaVolume: 1,
|
|
87
|
+
allowAmplificationDuringRender: false,
|
|
88
|
+
};
|
|
89
|
+
expectToThrow(() => {
|
|
90
|
+
evaluateVolume(toEvaluate);
|
|
91
|
+
}, /You passed in a function to the volume prop but it returned a non-finite number for frame 1/);
|
|
92
|
+
});
|
|
93
|
+
});
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { CanUseRemotionHooksProvider } from '../CanUseRemotionHooks.js';
|
|
3
|
+
import { CompositionManager } from '../CompositionManager.js';
|
|
4
|
+
const Comp = () => null;
|
|
5
|
+
export const mockCompositionContext = {
|
|
6
|
+
assets: [],
|
|
7
|
+
compositions: [
|
|
8
|
+
{
|
|
9
|
+
id: 'my-comp',
|
|
10
|
+
durationInFrames: 100,
|
|
11
|
+
// @ts-expect-error
|
|
12
|
+
component: Comp,
|
|
13
|
+
defaultProps: {},
|
|
14
|
+
folderName: null,
|
|
15
|
+
fps: 30,
|
|
16
|
+
height: 1080,
|
|
17
|
+
width: 1080,
|
|
18
|
+
parentFolderName: null,
|
|
19
|
+
nonce: 0,
|
|
20
|
+
},
|
|
21
|
+
],
|
|
22
|
+
currentComposition: 'my-comp',
|
|
23
|
+
folders: [],
|
|
24
|
+
registerAsset: () => undefined,
|
|
25
|
+
registerComposition: () => undefined,
|
|
26
|
+
registerFolder: () => undefined,
|
|
27
|
+
registerSequence: () => undefined,
|
|
28
|
+
sequences: [],
|
|
29
|
+
setCurrentComposition: () => undefined,
|
|
30
|
+
unregisterAsset: () => undefined,
|
|
31
|
+
unregisterComposition: () => undefined,
|
|
32
|
+
unregisterFolder: () => undefined,
|
|
33
|
+
unregisterSequence: () => undefined,
|
|
34
|
+
};
|
|
35
|
+
export const WrapSequenceContext = ({ children }) => {
|
|
36
|
+
return (_jsx(CanUseRemotionHooksProvider, { children: _jsx(CompositionManager.Provider, { value: mockCompositionContext, children: children }) }));
|
|
37
|
+
};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { MutableRefObject } from 'react';
|
|
2
|
+
export declare type PlayableMediaTag = {
|
|
3
|
+
play: () => void;
|
|
4
|
+
id: string;
|
|
5
|
+
};
|
|
6
|
+
export declare type TimelineContextValue = {
|
|
7
|
+
frame: number;
|
|
8
|
+
playing: boolean;
|
|
9
|
+
rootId: string;
|
|
10
|
+
playbackRate: number;
|
|
11
|
+
imperativePlaying: MutableRefObject<boolean>;
|
|
12
|
+
setPlaybackRate: (u: React.SetStateAction<number>) => void;
|
|
13
|
+
audioAndVideoTags: MutableRefObject<PlayableMediaTag[]>;
|
|
14
|
+
};
|
|
15
|
+
export declare type SetTimelineContextValue = {
|
|
16
|
+
setFrame: (u: React.SetStateAction<number>) => void;
|
|
17
|
+
setPlaying: (u: React.SetStateAction<boolean>) => void;
|
|
18
|
+
};
|
|
19
|
+
export declare const TimelineContext: import("react").Context<TimelineContextValue>;
|
|
20
|
+
export declare const SetTimelineContext: import("react").Context<SetTimelineContextValue>;
|
|
21
|
+
export declare const useTimelinePosition: () => number;
|
|
22
|
+
export declare const useTimelineSetFrame: () => (u: React.SetStateAction<number>) => void;
|
|
23
|
+
declare type PlayingReturnType = readonly [
|
|
24
|
+
boolean,
|
|
25
|
+
(u: React.SetStateAction<boolean>) => void,
|
|
26
|
+
MutableRefObject<boolean>
|
|
27
|
+
];
|
|
28
|
+
export declare const usePlayingState: () => PlayingReturnType;
|
|
29
|
+
export {};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { createContext, useContext, useMemo } from 'react';
|
|
2
|
+
export const TimelineContext = createContext({
|
|
3
|
+
frame: 0,
|
|
4
|
+
playing: false,
|
|
5
|
+
playbackRate: 1,
|
|
6
|
+
rootId: '',
|
|
7
|
+
imperativePlaying: {
|
|
8
|
+
current: false,
|
|
9
|
+
},
|
|
10
|
+
setPlaybackRate: () => {
|
|
11
|
+
throw new Error('default');
|
|
12
|
+
},
|
|
13
|
+
audioAndVideoTags: { current: [] },
|
|
14
|
+
});
|
|
15
|
+
export const SetTimelineContext = createContext({
|
|
16
|
+
setFrame: () => {
|
|
17
|
+
throw new Error('default');
|
|
18
|
+
},
|
|
19
|
+
setPlaying: () => {
|
|
20
|
+
throw new Error('default');
|
|
21
|
+
},
|
|
22
|
+
});
|
|
23
|
+
export const useTimelinePosition = () => {
|
|
24
|
+
const state = useContext(TimelineContext);
|
|
25
|
+
return state.frame;
|
|
26
|
+
};
|
|
27
|
+
export const useTimelineSetFrame = () => {
|
|
28
|
+
const { setFrame } = useContext(SetTimelineContext);
|
|
29
|
+
return setFrame;
|
|
30
|
+
};
|
|
31
|
+
export const usePlayingState = () => {
|
|
32
|
+
const { playing, imperativePlaying } = useContext(TimelineContext);
|
|
33
|
+
const { setPlaying } = useContext(SetTimelineContext);
|
|
34
|
+
return useMemo(() => [playing, setPlaying, imperativePlaying], [imperativePlaying, playing, setPlaying]);
|
|
35
|
+
};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Get the current frame of the video.
|
|
3
|
+
* Frames are 0-indexed, meaning the first frame is 0, the last frame is the duration of the composition in frames minus one.
|
|
4
|
+
* @link https://www.remotion.dev/docs/use-current-frame
|
|
5
|
+
*/
|
|
6
|
+
export declare const useCurrentFrame: () => number;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { useContext } from 'react';
|
|
2
|
+
import { CanUseRemotionHooks } from './CanUseRemotionHooks.js';
|
|
3
|
+
import { SequenceContext } from './Sequence.js';
|
|
4
|
+
import { useTimelinePosition } from './timeline-position-state.js';
|
|
5
|
+
/**
|
|
6
|
+
* Get the current frame of the video.
|
|
7
|
+
* Frames are 0-indexed, meaning the first frame is 0, the last frame is the duration of the composition in frames minus one.
|
|
8
|
+
* @link https://www.remotion.dev/docs/use-current-frame
|
|
9
|
+
*/
|
|
10
|
+
export const useCurrentFrame = () => {
|
|
11
|
+
const canUseRemotionHooks = useContext(CanUseRemotionHooks);
|
|
12
|
+
if (!canUseRemotionHooks) {
|
|
13
|
+
if (typeof window !== 'undefined' && window.remotion_isPlayer) {
|
|
14
|
+
throw new Error(`useCurrentFrame can only be called inside a component that was passed to <Player>. See: https://www.remotion.dev/docs/player/examples`);
|
|
15
|
+
}
|
|
16
|
+
throw new Error(`useCurrentFrame() can only be called inside a component that was registered as a composition. See https://www.remotion.dev/docs/the-fundamentals#defining-compositions`);
|
|
17
|
+
}
|
|
18
|
+
const frame = useTimelinePosition();
|
|
19
|
+
const context = useContext(SequenceContext);
|
|
20
|
+
const contextOffset = context
|
|
21
|
+
? context.cumulatedFrom + context.relativeFrom
|
|
22
|
+
: 0;
|
|
23
|
+
return frame - contextOffset;
|
|
24
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ComponentPropsWithRef, ComponentType, ExoticComponent } from 'react';
|
|
2
|
+
import type { CompProps } from './internals.js';
|
|
3
|
+
declare type LazyExoticComponent<T extends ComponentType<any>> = ExoticComponent<ComponentPropsWithRef<T>> & {
|
|
4
|
+
readonly _result: T;
|
|
5
|
+
};
|
|
6
|
+
export declare const useLazyComponent: <T>(compProps: CompProps<T>) => LazyExoticComponent<ComponentType<T>>;
|
|
7
|
+
export {};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import React, { useMemo } from 'react';
|
|
2
|
+
// Expected, it can be any component props
|
|
3
|
+
export const useLazyComponent = (compProps) => {
|
|
4
|
+
const lazy = useMemo(() => {
|
|
5
|
+
if ('lazyComponent' in compProps) {
|
|
6
|
+
return React.lazy(compProps.lazyComponent);
|
|
7
|
+
}
|
|
8
|
+
if ('component' in compProps) {
|
|
9
|
+
// In SSR, suspense is not yet supported, we cannot use React.lazy
|
|
10
|
+
if (typeof document === 'undefined') {
|
|
11
|
+
return compProps.component;
|
|
12
|
+
}
|
|
13
|
+
return React.lazy(() => Promise.resolve({ default: compProps.component }));
|
|
14
|
+
}
|
|
15
|
+
throw new Error("You must pass either 'component' or 'lazyComponent'");
|
|
16
|
+
// Very important to leave the dependencies as they are, or instead
|
|
17
|
+
// the player will remount on every frame.
|
|
18
|
+
// @ts-expect-error
|
|
19
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
20
|
+
}, [compProps.component, compProps.lazyComponent]);
|
|
21
|
+
return lazy;
|
|
22
|
+
};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { RefObject } from 'react';
|
|
2
|
+
import type { VolumeProp } from './volume-prop.js';
|
|
3
|
+
export declare const useMediaInTimeline: ({ volume, mediaVolume, mediaRef, src, mediaType, playbackRate, }: {
|
|
4
|
+
volume: VolumeProp | undefined;
|
|
5
|
+
mediaVolume: number;
|
|
6
|
+
mediaRef: RefObject<HTMLAudioElement | HTMLVideoElement>;
|
|
7
|
+
src: string | undefined;
|
|
8
|
+
mediaType: 'audio' | 'video';
|
|
9
|
+
playbackRate: number;
|
|
10
|
+
}) => void;
|