remotion 4.0.199 → 4.0.201
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/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/AbsoluteFill.d.ts +6 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/AbsoluteFill.js +25 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/CanUseRemotionHooks.d.ts +5 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/CanUseRemotionHooks.js +6 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Clipper.d.ts +7 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Clipper.js +20 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Composition.d.ts +60 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Composition.js +118 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/CompositionManager.d.ts +76 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/CompositionManager.js +93 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/CompositionManagerContext.d.ts +29 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/CompositionManagerContext.js +13 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/EditorProps.d.ts +15 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/EditorProps.js +26 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Folder.d.ts +19 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Folder.js +33 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/IFrame.d.ts +6 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/IFrame.js +26 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Img.d.ts +11 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Img.js +106 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/NativeLayers.d.ts +13 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/NativeLayers.js +26 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Null.d.ts +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Null.js +21 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/RemotionRoot.d.ts +5 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/RemotionRoot.js +71 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/RenderAssetManager.d.ts +11 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/RenderAssetManager.js +37 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/ResolveCompositionConfig.d.ts +24 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/ResolveCompositionConfig.js +216 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Sequence.d.ts +33 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Sequence.js +137 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/SequenceContext.d.ts +11 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/SequenceContext.js +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/SequenceManager.d.ts +16 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/SequenceManager.js +43 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Still.d.ts +8 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/Still.js +15 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/absolute-src.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/absolute-src.js +6 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/asset-types.d.ts +50 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/asset-types.js +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/Audio.d.ts +23 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/Audio.js +77 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/AudioForPreview.d.ts +12 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/AudioForPreview.js +117 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/AudioForRendering.d.ts +16 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/AudioForRendering.js +119 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/index.d.ts +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/index.js +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/props.d.ts +18 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/shared-audio-tags.d.ts +39 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/shared-audio-tags.js +217 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/use-audio-frame.d.ts +6 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/use-audio-frame.js +18 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/bezier.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/bezier.js +110 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/buffering.d.ts +26 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/buffering.js +48 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/calculate-loop.d.ts +6 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/calculate-loop.js +13 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/cancel-render.d.ts +5 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/cancel-render.js +43 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/codec.d.ts +4 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/codec.js +14 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/config/input-props.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/config/input-props.js +30 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/default-css.d.ts +3 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/default-css.js +44 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/delay-render.d.ts +14 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/delay-render.js +80 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/easing.d.ts +23 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/easing.js +77 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/enable-sequence-stack-traces.d.ts +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/enable-sequence-stack-traces.js +29 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/freeze.d.ts +12 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/freeze.js +58 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/get-asset-file-name.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/get-asset-file-name.js +10 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/get-preview-dom-element.d.ts +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/get-preview-dom-element.js +4 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/get-remotion-environment.d.ts +10 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/get-remotion-environment.js +17 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/get-static-files.d.ts +21 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/get-static-files.js +33 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/index.d.ts +123 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/index.js +80 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/input-props-serialization.d.ts +15 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/input-props-serialization.js +44 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/internals.d.ts +164 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/internals.js +106 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/interpolate-colors.d.ts +13 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/interpolate-colors.js +394 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/interpolate.d.ts +23 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/interpolate.js +127 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/is-approximately-the-same.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/is-approximately-the-same.js +4 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/is-player.d.ts +3 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/is-player.js +9 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/loading-indicator.d.ts +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/loading-indicator.js +31 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/loop/index.d.ts +13 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/loop/index.js +41 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/multiple-versions-warning.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/multiple-versions-warning.js +28 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/no-react.d.ts +43 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/no-react.js +29 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/nonce.d.ts +7 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/nonce.js +19 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/play-and-handle-not-allowed-error.d.ts +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/play-and-handle-not-allowed-error.js +42 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/portal-node.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/portal-node.js +24 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/prefetch-state.d.ts +8 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/prefetch-state.js +22 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/prefetch.d.ts +19 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/prefetch.js +157 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/props-if-has-props.d.ts +10 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/props-if-has-props.js +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/random.d.ts +6 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/random.js +37 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/register-root.d.ts +8 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/register-root.js +31 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/resolve-video-config.d.ts +9 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/resolve-video-config.js +80 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/series/flatten-children.d.ts +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/series/flatten-children.js +12 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/series/index.d.ts +18 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/series/index.js +67 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/setup-env-variables.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/setup-env-variables.js +36 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/spring/index.d.ts +31 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/spring/index.js +75 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/spring/measure-spring.d.ts +12 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/spring/measure-spring.js +79 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/spring/spring-utils.d.ts +21 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/spring/spring-utils.js +99 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/static-file.d.ts +33 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/static-file.js +95 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/Img.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/Img.test.js +20 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/absolute-src.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/absolute-src.test.js +16 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/audio-for-rendering.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/audio-for-rendering.test.js +65 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/audio.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/audio.test.js +25 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/bezier.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/bezier.test.js +50 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/composition-rules.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/composition-rules.test.js +28 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/composition-validation.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/composition-validation.test.js +310 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/easing.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/easing.test.js +189 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/expect-to-throw.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/expect-to-throw.js +13 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/freeze.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/freeze.test.js +60 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/get-asset-file-name.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/get-asset-file-name.test.js +12 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/get-current-time.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/get-current-time.test.js +60 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/includes-hex-of-unsafe-char.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/includes-hex-of-unsafe-char.test.js +11 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/input-props.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/input-props.test.js +29 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/interpolate.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/interpolate.test.js +140 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/interpolateColors.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/interpolateColors.test.js +61 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/json-serialization.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/json-serialization.test.js +32 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/loop-validation.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/loop-validation.test.js +39 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/measure-spring.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/measure-spring.test.js +43 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/media-validation.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/media-validation.test.js +45 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/nested-sequences.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/nested-sequences.test.js +98 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/not-all-props-in-media-tags.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/not-all-props-in-media-tags.test.js +28 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/offthread-props.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/offthread-props.test.js +11 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/random.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/random.test.js +58 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/ready-manager.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/ready-manager.test.js +27 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/render-hook.d.ts +23 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/render-hook.js +20 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/sequence-from-initial-offset.test.d.ts +4 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/sequence-from-initial-offset.test.js +35 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/sequence-validation.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/sequence-validation.test.js +43 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/series.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/series.test.js +119 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/spring-bench.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/spring-bench.test.js +30 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/spring.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/spring.test.js +164 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/static-file-errors.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/static-file-errors.test.js +16 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/static-file-safe-uri.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/static-file-safe-uri.test.js +26 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/truthy.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/truthy.test.js +22 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/use-media-in-timeline.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/use-media-in-timeline.test.js +63 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/use-media-tag-volume.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/use-media-tag-volume.test.js +44 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/use-sync-volume-with-media-tag.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/use-sync-volume-with-media-tag.test.js +53 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/validate-start-from-props.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/validate-start-from-props.test.js +37 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/video.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/video.test.js +27 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/volume-prop.test.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/volume-prop.test.js +93 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/wrap-sequence-context.d.ts +6 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/test/wrap-sequence-context.js +33 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/timeline-position-state.d.ts +33 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/timeline-position-state.js +66 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/truthy.d.ts +3 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/truthy.js +3 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-buffer-state.d.ts +5 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-buffer-state.js +16 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-current-frame.d.ts +5 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-current-frame.js +23 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-current-scale.d.ts +43 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-current-scale.js +46 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-lazy-component.d.ts +7 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-lazy-component.js +22 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-media-buffering.d.ts +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-media-buffering.js +38 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-media-in-timeline.d.ts +14 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-media-in-timeline.js +130 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-media-playback.d.ts +10 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-media-playback.js +114 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-media-tag-volume.d.ts +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-media-tag-volume.js +27 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-sync-volume-with-media-tag.d.ts +10 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-sync-volume-with-media-tag.js +17 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-unsafe-video-config.d.ts +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-unsafe-video-config.js +27 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-video-config.d.ts +8 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-video-config.js +30 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-video.d.ts +7 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/use-video.js +36 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validate-frame.d.ts +5 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validate-frame.js +20 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validate-media-props.d.ts +4 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validate-media-props.js +20 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validate-start-from-props.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validate-start-from-props.js +27 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-composition-id.d.ts +3 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-composition-id.js +8 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-default-codec.d.ts +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-default-codec.js +12 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-default-props.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-default-props.js +11 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-dimensions.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-dimensions.js +17 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-duration-in-frames.d.ts +4 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-duration-in-frames.js +18 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-folder-name.d.ts +3 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-folder-name.js +14 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-fps.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validate-fps.js +17 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validation-spring-duration.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/validation/validation-spring-duration.js +17 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/version.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/version.js +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/OffthreadVideo.d.ts +7 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/OffthreadVideo.js +37 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/OffthreadVideoForRendering.d.ts +3 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/OffthreadVideoForRendering.js +113 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/Video.d.ts +21 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/Video.js +63 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/VideoForPreview.d.ts +12 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/VideoForPreview.js +148 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/VideoForRendering.d.ts +14 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/VideoForRendering.js +192 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/duration-state.d.ts +17 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/duration-state.js +30 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/get-current-time.d.ts +11 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/get-current-time.js +14 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/index.d.ts +3 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/index.js +2 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/offthread-video-source.d.ts +6 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/offthread-video-source.js +4 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/props.d.ts +49 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/props.js +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/seek-until-right.d.ts +8 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/seek-until-right.js +88 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/video-fragment.d.ts +13 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video/video-fragment.js +59 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video-config.d.ts +11 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/video-config.js +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/volume-position-state.d.ts +19 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/volume-position-state.js +27 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/volume-prop.d.ts +7 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/volume-prop.js +20 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/warn-about-non-seekable-media.d.ts +1 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/warn-about-non-seekable-media.js +38 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/watch-static-file.d.ts +17 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/watch-static-file.js +48 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/wrap-remotion-context.d.ts +45 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/wrap-remotion-context.js +61 -0
- package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/tsconfig-esm.tsbuildinfo +1 -0
- package/dist/cjs/use-media-playback.js +6 -2
- package/dist/cjs/version.d.ts +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/video/OffthreadVideoForRendering.js +4 -0
- package/dist/cjs/video/track-source-change.d.ts +2 -0
- package/dist/cjs/video/track-source-change.js +20 -0
- package/dist/esm/index.mjs +10 -3
- package/dist/esm/version.mjs +1 -1
- package/dist/tsconfig-esm.tsbuildinfo +1 -0
- package/package.json +1 -1
- package/dist/cjs/check-rsc.js +0 -6
- /package/{dist/cjs/check-rsc.d.ts → .rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/props.js} +0 -0
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef, useContext, useEffect, useImperativeHandle, useLayoutEffect, useMemo, useRef, } from 'react';
|
|
3
|
+
import { getAbsoluteSrc } from '../absolute-src.js';
|
|
4
|
+
import { continueRender, delayRender } from '../delay-render.js';
|
|
5
|
+
import { random } from '../random.js';
|
|
6
|
+
import { RenderAssetManager } from '../RenderAssetManager.js';
|
|
7
|
+
import { SequenceContext } from '../SequenceContext.js';
|
|
8
|
+
import { useTimelinePosition } from '../timeline-position-state.js';
|
|
9
|
+
import { useCurrentFrame } from '../use-current-frame.js';
|
|
10
|
+
import { evaluateVolume } from '../volume-prop.js';
|
|
11
|
+
import { useFrameForVolumeProp } from './use-audio-frame.js';
|
|
12
|
+
const AudioForRenderingRefForwardingFunction = (props, ref) => {
|
|
13
|
+
const audioRef = useRef(null);
|
|
14
|
+
const absoluteFrame = useTimelinePosition();
|
|
15
|
+
const volumePropFrame = useFrameForVolumeProp();
|
|
16
|
+
const frame = useCurrentFrame();
|
|
17
|
+
const sequenceContext = useContext(SequenceContext);
|
|
18
|
+
const { registerRenderAsset, unregisterRenderAsset } = useContext(RenderAssetManager);
|
|
19
|
+
// Generate a string that's as unique as possible for this asset
|
|
20
|
+
// but at the same time the same on all threads
|
|
21
|
+
const id = useMemo(() => {
|
|
22
|
+
var _a;
|
|
23
|
+
return `audio-${random((_a = props.src) !== null && _a !== void 0 ? _a : '')}-${sequenceContext === null || sequenceContext === void 0 ? void 0 : sequenceContext.relativeFrom}-${sequenceContext === null || sequenceContext === void 0 ? void 0 : sequenceContext.cumulatedFrom}-${sequenceContext === null || sequenceContext === void 0 ? void 0 : sequenceContext.durationInFrames}`;
|
|
24
|
+
}, [
|
|
25
|
+
props.src,
|
|
26
|
+
sequenceContext === null || sequenceContext === void 0 ? void 0 : sequenceContext.relativeFrom,
|
|
27
|
+
sequenceContext === null || sequenceContext === void 0 ? void 0 : sequenceContext.cumulatedFrom,
|
|
28
|
+
sequenceContext === null || sequenceContext === void 0 ? void 0 : sequenceContext.durationInFrames,
|
|
29
|
+
]);
|
|
30
|
+
const { volume: volumeProp, playbackRate, allowAmplificationDuringRender, onDuration, toneFrequency, _remotionInternalNeedsDurationCalculation, _remotionInternalNativeLoopPassed, acceptableTimeShiftInSeconds, name, onError, ...nativeProps } = props;
|
|
31
|
+
const volume = evaluateVolume({
|
|
32
|
+
volume: volumeProp,
|
|
33
|
+
frame: volumePropFrame,
|
|
34
|
+
mediaVolume: 1,
|
|
35
|
+
allowAmplificationDuringRender: allowAmplificationDuringRender !== null && allowAmplificationDuringRender !== void 0 ? allowAmplificationDuringRender : false,
|
|
36
|
+
});
|
|
37
|
+
useImperativeHandle(ref, () => {
|
|
38
|
+
return audioRef.current;
|
|
39
|
+
}, []);
|
|
40
|
+
useEffect(() => {
|
|
41
|
+
var _a;
|
|
42
|
+
if (!props.src) {
|
|
43
|
+
throw new Error('No src passed');
|
|
44
|
+
}
|
|
45
|
+
if (!window.remotion_audioEnabled) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
if (props.muted) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
if (volume <= 0) {
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
registerRenderAsset({
|
|
55
|
+
type: 'audio',
|
|
56
|
+
src: getAbsoluteSrc(props.src),
|
|
57
|
+
id,
|
|
58
|
+
frame: absoluteFrame,
|
|
59
|
+
volume,
|
|
60
|
+
mediaFrame: frame,
|
|
61
|
+
playbackRate: (_a = props.playbackRate) !== null && _a !== void 0 ? _a : 1,
|
|
62
|
+
allowAmplificationDuringRender: allowAmplificationDuringRender !== null && allowAmplificationDuringRender !== void 0 ? allowAmplificationDuringRender : false,
|
|
63
|
+
toneFrequency: toneFrequency !== null && toneFrequency !== void 0 ? toneFrequency : null,
|
|
64
|
+
});
|
|
65
|
+
return () => unregisterRenderAsset(id);
|
|
66
|
+
}, [
|
|
67
|
+
props.muted,
|
|
68
|
+
props.src,
|
|
69
|
+
registerRenderAsset,
|
|
70
|
+
absoluteFrame,
|
|
71
|
+
id,
|
|
72
|
+
unregisterRenderAsset,
|
|
73
|
+
volume,
|
|
74
|
+
volumePropFrame,
|
|
75
|
+
frame,
|
|
76
|
+
playbackRate,
|
|
77
|
+
props.playbackRate,
|
|
78
|
+
allowAmplificationDuringRender,
|
|
79
|
+
toneFrequency,
|
|
80
|
+
]);
|
|
81
|
+
const { src } = props;
|
|
82
|
+
// The <audio> tag is only rendered if the duration needs to be calculated for the `loop`
|
|
83
|
+
// attribute to work, or if the user assigns a ref to it.
|
|
84
|
+
const needsToRenderAudioTag = ref || _remotionInternalNeedsDurationCalculation;
|
|
85
|
+
// If audio source switches, make new handle
|
|
86
|
+
useLayoutEffect(() => {
|
|
87
|
+
if (process.env.NODE_ENV === 'test') {
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
if (!needsToRenderAudioTag) {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
const newHandle = delayRender('Loading <Audio> duration with src=' + src);
|
|
94
|
+
const { current } = audioRef;
|
|
95
|
+
const didLoad = () => {
|
|
96
|
+
if (current === null || current === void 0 ? void 0 : current.duration) {
|
|
97
|
+
onDuration(current.src, current.duration);
|
|
98
|
+
}
|
|
99
|
+
continueRender(newHandle);
|
|
100
|
+
};
|
|
101
|
+
if (current === null || current === void 0 ? void 0 : current.duration) {
|
|
102
|
+
onDuration(current.src, current.duration);
|
|
103
|
+
continueRender(newHandle);
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
current === null || current === void 0 ? void 0 : current.addEventListener('loadedmetadata', didLoad, { once: true });
|
|
107
|
+
}
|
|
108
|
+
// If tag gets unmounted, clear pending handles because video metadata is not going to load
|
|
109
|
+
return () => {
|
|
110
|
+
current === null || current === void 0 ? void 0 : current.removeEventListener('loadedmetadata', didLoad);
|
|
111
|
+
continueRender(newHandle);
|
|
112
|
+
};
|
|
113
|
+
}, [src, onDuration, needsToRenderAudioTag]);
|
|
114
|
+
if (!needsToRenderAudioTag) {
|
|
115
|
+
return null;
|
|
116
|
+
}
|
|
117
|
+
return _jsx("audio", { ref: audioRef, ...nativeProps });
|
|
118
|
+
};
|
|
119
|
+
export const AudioForRendering = forwardRef(AudioForRenderingRefForwardingFunction);
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import type { VolumeProp } from '../volume-prop.js';
|
|
3
|
+
export type RemotionMainAudioProps = {
|
|
4
|
+
startFrom?: number;
|
|
5
|
+
endAt?: number;
|
|
6
|
+
};
|
|
7
|
+
export type RemotionAudioProps = Omit<React.DetailedHTMLProps<React.AudioHTMLAttributes<HTMLAudioElement>, HTMLAudioElement>, 'autoPlay' | 'controls' | 'onEnded' | 'nonce' | 'onResize' | 'onResizeCapture'> & {
|
|
8
|
+
name?: string;
|
|
9
|
+
volume?: VolumeProp;
|
|
10
|
+
playbackRate?: number;
|
|
11
|
+
acceptableTimeShiftInSeconds?: number;
|
|
12
|
+
allowAmplificationDuringRender?: boolean;
|
|
13
|
+
_remotionInternalNeedsDurationCalculation?: boolean;
|
|
14
|
+
_remotionInternalNativeLoopPassed?: boolean;
|
|
15
|
+
toneFrequency?: number;
|
|
16
|
+
pauseWhenBuffering?: boolean;
|
|
17
|
+
showInTimeline?: boolean;
|
|
18
|
+
};
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import type { ComponentType, LazyExoticComponent } from 'react';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import type { RemotionAudioProps } from './props.js';
|
|
4
|
+
/**
|
|
5
|
+
* This functionality of Remotion will keep a certain amount
|
|
6
|
+
* of <audio> tags pre-mounted and by default filled with an empty audio track.
|
|
7
|
+
* If the user interacts, the empty audio will be played.
|
|
8
|
+
* If one of Remotions <Audio /> tags get mounted, the audio will not be rendered at this location, but into one of the prerendered audio tags.
|
|
9
|
+
*
|
|
10
|
+
* This helps with autoplay issues on iOS Safari and soon other browsers,
|
|
11
|
+
* which only allow audio playback upon user interaction.
|
|
12
|
+
*
|
|
13
|
+
* The behavior can be disabled by passing `0` as the number of shared audio tracks.
|
|
14
|
+
*/
|
|
15
|
+
type AudioElem = {
|
|
16
|
+
id: number;
|
|
17
|
+
props: RemotionAudioProps;
|
|
18
|
+
el: React.RefObject<HTMLAudioElement>;
|
|
19
|
+
audioId: string;
|
|
20
|
+
};
|
|
21
|
+
type SharedContext = {
|
|
22
|
+
registerAudio: (aud: RemotionAudioProps, audioId: string) => AudioElem;
|
|
23
|
+
unregisterAudio: (id: number) => void;
|
|
24
|
+
updateAudio: (options: {
|
|
25
|
+
id: number;
|
|
26
|
+
aud: RemotionAudioProps;
|
|
27
|
+
audioId: string;
|
|
28
|
+
}) => void;
|
|
29
|
+
playAllAudios: () => void;
|
|
30
|
+
numberOfAudioTags: number;
|
|
31
|
+
};
|
|
32
|
+
export declare const SharedAudioContext: React.Context<SharedContext | null>;
|
|
33
|
+
export declare const SharedAudioContextProvider: React.FC<{
|
|
34
|
+
numberOfAudioTags: number;
|
|
35
|
+
children: React.ReactNode;
|
|
36
|
+
component: LazyExoticComponent<ComponentType<Record<string, unknown>>> | null;
|
|
37
|
+
}>;
|
|
38
|
+
export declare const useSharedAudio: (aud: RemotionAudioProps, audioId: string) => AudioElem;
|
|
39
|
+
export {};
|
|
@@ -0,0 +1,217 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React, { createContext, createRef, useCallback, useContext, useEffect, useMemo, useRef, useState, } from 'react';
|
|
3
|
+
import { playAndHandleNotAllowedError } from '../play-and-handle-not-allowed-error.js';
|
|
4
|
+
const EMPTY_AUDIO = 'data:audio/mp3;base64,/+MYxAAJcAV8AAgAABn//////+/gQ5BAMA+D4Pg+BAQBAEAwD4Pg+D4EBAEAQDAPg++hYBH///hUFQVBUFREDQNHmf///////+MYxBUGkAGIMAAAAP/29Xt6lUxBTUUzLjEwMFVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV/+MYxDUAAANIAAAAAFVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV';
|
|
5
|
+
const compareProps = (obj1, obj2) => {
|
|
6
|
+
const keysA = Object.keys(obj1).sort();
|
|
7
|
+
const keysB = Object.keys(obj2).sort();
|
|
8
|
+
if (keysA.length !== keysB.length) {
|
|
9
|
+
return false;
|
|
10
|
+
}
|
|
11
|
+
for (let i = 0; i < keysA.length; i++) {
|
|
12
|
+
// Not the same keys
|
|
13
|
+
if (keysA[i] !== keysB[i]) {
|
|
14
|
+
return false;
|
|
15
|
+
}
|
|
16
|
+
// Not the same values
|
|
17
|
+
if (obj1[keysA[i]] !== obj2[keysB[i]]) {
|
|
18
|
+
return false;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return true;
|
|
22
|
+
};
|
|
23
|
+
const didPropChange = (key, newProp, prevProp) => {
|
|
24
|
+
// /music.mp3 and http://localhost:3000/music.mp3 are the same
|
|
25
|
+
if (key === 'src' &&
|
|
26
|
+
!prevProp.startsWith('data:') &&
|
|
27
|
+
!newProp.startsWith('data:')) {
|
|
28
|
+
return (new URL(prevProp, window.origin).toString() !==
|
|
29
|
+
new URL(newProp, window.origin).toString());
|
|
30
|
+
}
|
|
31
|
+
if (prevProp === newProp) {
|
|
32
|
+
return false;
|
|
33
|
+
}
|
|
34
|
+
return true;
|
|
35
|
+
};
|
|
36
|
+
export const SharedAudioContext = createContext(null);
|
|
37
|
+
export const SharedAudioContextProvider = ({ children, numberOfAudioTags, component }) => {
|
|
38
|
+
const audios = useRef([]);
|
|
39
|
+
const [initialNumberOfAudioTags] = useState(numberOfAudioTags);
|
|
40
|
+
if (numberOfAudioTags !== initialNumberOfAudioTags) {
|
|
41
|
+
throw new Error('The number of shared audio tags has changed dynamically. Once you have set this property, you cannot change it afterwards.');
|
|
42
|
+
}
|
|
43
|
+
const refs = useMemo(() => {
|
|
44
|
+
return new Array(numberOfAudioTags).fill(true).map(() => {
|
|
45
|
+
return { id: Math.random(), ref: createRef() };
|
|
46
|
+
});
|
|
47
|
+
}, [numberOfAudioTags]);
|
|
48
|
+
const takenAudios = useRef(new Array(numberOfAudioTags).fill(false));
|
|
49
|
+
const rerenderAudios = useCallback(() => {
|
|
50
|
+
refs.forEach(({ ref, id }) => {
|
|
51
|
+
var _a;
|
|
52
|
+
const data = (_a = audios.current) === null || _a === void 0 ? void 0 : _a.find((a) => a.id === id);
|
|
53
|
+
const { current } = ref;
|
|
54
|
+
if (!current) {
|
|
55
|
+
// Whole player has been unmounted, the refs don't exist anymore.
|
|
56
|
+
// It is not an error anymore though
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
if (data === undefined) {
|
|
60
|
+
current.src = EMPTY_AUDIO;
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
if (!data) {
|
|
64
|
+
throw new TypeError('Expected audio data to be there');
|
|
65
|
+
}
|
|
66
|
+
Object.keys(data.props).forEach((key) => {
|
|
67
|
+
// @ts-expect-error
|
|
68
|
+
if (didPropChange(key, data.props[key], current[key])) {
|
|
69
|
+
// @ts-expect-error
|
|
70
|
+
current[key] = data.props[key];
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
}, [refs]);
|
|
75
|
+
const registerAudio = useCallback((aud, audioId) => {
|
|
76
|
+
var _a, _b;
|
|
77
|
+
const found = (_a = audios.current) === null || _a === void 0 ? void 0 : _a.find((a) => a.audioId === audioId);
|
|
78
|
+
if (found) {
|
|
79
|
+
return found;
|
|
80
|
+
}
|
|
81
|
+
const firstFreeAudio = takenAudios.current.findIndex((a) => a === false);
|
|
82
|
+
if (firstFreeAudio === -1) {
|
|
83
|
+
throw new Error(`Tried to simultaneously mount ${numberOfAudioTags + 1} <Audio /> tags at the same time. With the current settings, the maximum amount of <Audio /> tags is limited to ${numberOfAudioTags} at the same time. Remotion pre-mounts silent audio tags to help avoid browser autoplay restrictions. See https://remotion.dev/docs/player/autoplay#use-the-numberofsharedaudiotags-property for more information on how to increase this limit.`);
|
|
84
|
+
}
|
|
85
|
+
const { id, ref } = refs[firstFreeAudio];
|
|
86
|
+
const cloned = [...takenAudios.current];
|
|
87
|
+
cloned[firstFreeAudio] = id;
|
|
88
|
+
takenAudios.current = cloned;
|
|
89
|
+
const newElem = {
|
|
90
|
+
props: aud,
|
|
91
|
+
id,
|
|
92
|
+
el: ref,
|
|
93
|
+
audioId,
|
|
94
|
+
};
|
|
95
|
+
(_b = audios.current) === null || _b === void 0 ? void 0 : _b.push(newElem);
|
|
96
|
+
rerenderAudios();
|
|
97
|
+
return newElem;
|
|
98
|
+
}, [numberOfAudioTags, refs, rerenderAudios]);
|
|
99
|
+
const unregisterAudio = useCallback((id) => {
|
|
100
|
+
var _a;
|
|
101
|
+
const cloned = [...takenAudios.current];
|
|
102
|
+
const index = refs.findIndex((r) => r.id === id);
|
|
103
|
+
if (index === -1) {
|
|
104
|
+
throw new TypeError('Error occured in ');
|
|
105
|
+
}
|
|
106
|
+
cloned[index] = false;
|
|
107
|
+
takenAudios.current = cloned;
|
|
108
|
+
audios.current = (_a = audios.current) === null || _a === void 0 ? void 0 : _a.filter((a) => a.id !== id);
|
|
109
|
+
rerenderAudios();
|
|
110
|
+
}, [refs, rerenderAudios]);
|
|
111
|
+
const updateAudio = useCallback(({ aud, audioId, id, }) => {
|
|
112
|
+
var _a;
|
|
113
|
+
let changed = false;
|
|
114
|
+
audios.current = (_a = audios.current) === null || _a === void 0 ? void 0 : _a.map((prevA) => {
|
|
115
|
+
if (prevA.id === id) {
|
|
116
|
+
const isTheSame = compareProps(aud, prevA.props);
|
|
117
|
+
if (isTheSame) {
|
|
118
|
+
return prevA;
|
|
119
|
+
}
|
|
120
|
+
changed = true;
|
|
121
|
+
return {
|
|
122
|
+
...prevA,
|
|
123
|
+
props: aud,
|
|
124
|
+
audioId,
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
return prevA;
|
|
128
|
+
});
|
|
129
|
+
if (changed) {
|
|
130
|
+
rerenderAudios();
|
|
131
|
+
}
|
|
132
|
+
}, [rerenderAudios]);
|
|
133
|
+
const playAllAudios = useCallback(() => {
|
|
134
|
+
refs.forEach((ref) => {
|
|
135
|
+
playAndHandleNotAllowedError(ref.ref, 'audio');
|
|
136
|
+
});
|
|
137
|
+
}, [refs]);
|
|
138
|
+
const value = useMemo(() => {
|
|
139
|
+
return {
|
|
140
|
+
registerAudio,
|
|
141
|
+
unregisterAudio,
|
|
142
|
+
updateAudio,
|
|
143
|
+
playAllAudios,
|
|
144
|
+
numberOfAudioTags,
|
|
145
|
+
};
|
|
146
|
+
}, [
|
|
147
|
+
numberOfAudioTags,
|
|
148
|
+
playAllAudios,
|
|
149
|
+
registerAudio,
|
|
150
|
+
unregisterAudio,
|
|
151
|
+
updateAudio,
|
|
152
|
+
]);
|
|
153
|
+
// Fixing a bug: In React, if a component is unmounted using useInsertionEffect, then
|
|
154
|
+
// the cleanup function does sometimes not work properly. That is why when we
|
|
155
|
+
// are changing the composition, we reset the audio state.
|
|
156
|
+
// TODO: Possibly this does not save the problem completely, since the
|
|
157
|
+
// if an audio tag that is inside a sequence will also not be removed
|
|
158
|
+
// from the shared audios.
|
|
159
|
+
const resetAudio = useCallback(() => {
|
|
160
|
+
takenAudios.current = new Array(numberOfAudioTags).fill(false);
|
|
161
|
+
audios.current = [];
|
|
162
|
+
rerenderAudios();
|
|
163
|
+
}, [numberOfAudioTags, rerenderAudios]);
|
|
164
|
+
useEffect(() => {
|
|
165
|
+
return () => {
|
|
166
|
+
resetAudio();
|
|
167
|
+
};
|
|
168
|
+
}, [component, resetAudio]);
|
|
169
|
+
return (_jsxs(SharedAudioContext.Provider, { value: value, children: [refs.map(({ id, ref }) => {
|
|
170
|
+
return (
|
|
171
|
+
// Without preload="metadata", iOS will seek the time internally
|
|
172
|
+
// but not actually with sound. Adding `preload="metadata"` helps here.
|
|
173
|
+
// https://discord.com/channels/809501355504959528/817306414069710848/1130519583367888906
|
|
174
|
+
_jsx("audio", { ref: ref, preload: "metadata", src: EMPTY_AUDIO }, id));
|
|
175
|
+
}), children] }));
|
|
176
|
+
};
|
|
177
|
+
export const useSharedAudio = (aud, audioId) => {
|
|
178
|
+
var _a;
|
|
179
|
+
const ctx = useContext(SharedAudioContext);
|
|
180
|
+
/**
|
|
181
|
+
* We work around this in React 18 so an audio tag will only register itself once
|
|
182
|
+
*/
|
|
183
|
+
const [elem] = useState(() => {
|
|
184
|
+
if (ctx && ctx.numberOfAudioTags > 0) {
|
|
185
|
+
return ctx.registerAudio(aud, audioId);
|
|
186
|
+
}
|
|
187
|
+
return {
|
|
188
|
+
el: React.createRef(),
|
|
189
|
+
id: Math.random(),
|
|
190
|
+
props: aud,
|
|
191
|
+
audioId,
|
|
192
|
+
};
|
|
193
|
+
});
|
|
194
|
+
/**
|
|
195
|
+
* Effects in React 18 fire twice, and we are looking for a way to only fire it once.
|
|
196
|
+
* - useInsertionEffect only fires once. If it's available we are in React 18.
|
|
197
|
+
* - useLayoutEffect only fires once in React 17.
|
|
198
|
+
*
|
|
199
|
+
* Need to import it from React to fix React 17 ESM support.
|
|
200
|
+
*/
|
|
201
|
+
const effectToUse = (_a = React.useInsertionEffect) !== null && _a !== void 0 ? _a : React.useLayoutEffect;
|
|
202
|
+
if (typeof document !== 'undefined') {
|
|
203
|
+
effectToUse(() => {
|
|
204
|
+
if (ctx && ctx.numberOfAudioTags > 0) {
|
|
205
|
+
ctx.updateAudio({ id: elem.id, aud, audioId });
|
|
206
|
+
}
|
|
207
|
+
}, [aud, ctx, elem.id, audioId]);
|
|
208
|
+
effectToUse(() => {
|
|
209
|
+
return () => {
|
|
210
|
+
if (ctx && ctx.numberOfAudioTags > 0) {
|
|
211
|
+
ctx.unregisterAudio(elem.id);
|
|
212
|
+
}
|
|
213
|
+
};
|
|
214
|
+
}, [ctx, elem.id]);
|
|
215
|
+
}
|
|
216
|
+
return elem;
|
|
217
|
+
};
|
package/.rollup.cache/Users/jonathanburger/remotion/packages/core/dist/esm/audio/use-audio-frame.js
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { useContext } from 'react';
|
|
2
|
+
import { SequenceContext } from '../SequenceContext.js';
|
|
3
|
+
import { useCurrentFrame } from '../use-current-frame.js';
|
|
4
|
+
export const useMediaStartsAt = () => {
|
|
5
|
+
var _a;
|
|
6
|
+
const parentSequence = useContext(SequenceContext);
|
|
7
|
+
const startsAt = Math.min(0, (_a = parentSequence === null || parentSequence === void 0 ? void 0 : parentSequence.relativeFrom) !== null && _a !== void 0 ? _a : 0);
|
|
8
|
+
return startsAt;
|
|
9
|
+
};
|
|
10
|
+
/**
|
|
11
|
+
* When passing a function as the prop for `volume`,
|
|
12
|
+
* we calculate the way more intuitive value for currentFrame
|
|
13
|
+
*/
|
|
14
|
+
export const useFrameForVolumeProp = () => {
|
|
15
|
+
const frame = useCurrentFrame();
|
|
16
|
+
const startsAt = useMediaStartsAt();
|
|
17
|
+
return frame + startsAt;
|
|
18
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function bezier(mX1: number, mY1: number, mX2: number, mY2: number): (x: number) => number;
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
// Taken from https://github.com/facebook/react-native/blob/0b9ea60b4fee8cacc36e7160e31b91fc114dbc0d/Libraries/Animated/src/bezier.js
|
|
2
|
+
const NEWTON_ITERATIONS = 4;
|
|
3
|
+
const NEWTON_MIN_SLOPE = 0.001;
|
|
4
|
+
const SUBDIVISION_PRECISION = 0.0000001;
|
|
5
|
+
const SUBDIVISION_MAX_ITERATIONS = 10;
|
|
6
|
+
const kSplineTableSize = 11;
|
|
7
|
+
const kSampleStepSize = 1.0 / (kSplineTableSize - 1.0);
|
|
8
|
+
const float32ArraySupported = typeof Float32Array === 'function';
|
|
9
|
+
function a(aA1, aA2) {
|
|
10
|
+
return 1.0 - 3.0 * aA2 + 3.0 * aA1;
|
|
11
|
+
}
|
|
12
|
+
function b(aA1, aA2) {
|
|
13
|
+
return 3.0 * aA2 - 6.0 * aA1;
|
|
14
|
+
}
|
|
15
|
+
function c(aA1) {
|
|
16
|
+
return 3.0 * aA1;
|
|
17
|
+
}
|
|
18
|
+
// Returns x(t) given t, x1, and x2, or y(t) given t, y1, and y2.
|
|
19
|
+
function calcBezier(aT, aA1, aA2) {
|
|
20
|
+
return ((a(aA1, aA2) * aT + b(aA1, aA2)) * aT + c(aA1)) * aT;
|
|
21
|
+
}
|
|
22
|
+
// Returns dx/dt given t, x1, and x2, or dy/dt given t, y1, and y2.
|
|
23
|
+
function getSlope(aT, aA1, aA2) {
|
|
24
|
+
return 3.0 * a(aA1, aA2) * aT * aT + 2.0 * b(aA1, aA2) * aT + c(aA1);
|
|
25
|
+
}
|
|
26
|
+
function binarySubdivide({ aX, _aA, _aB, mX1, mX2, }) {
|
|
27
|
+
let currentX;
|
|
28
|
+
let currentT;
|
|
29
|
+
let i = 0;
|
|
30
|
+
let aA = _aA;
|
|
31
|
+
let aB = _aB;
|
|
32
|
+
do {
|
|
33
|
+
currentT = aA + (aB - aA) / 2.0;
|
|
34
|
+
currentX = calcBezier(currentT, mX1, mX2) - aX;
|
|
35
|
+
if (currentX > 0.0) {
|
|
36
|
+
aB = currentT;
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
aA = currentT;
|
|
40
|
+
}
|
|
41
|
+
} while (Math.abs(currentX) > SUBDIVISION_PRECISION &&
|
|
42
|
+
++i < SUBDIVISION_MAX_ITERATIONS);
|
|
43
|
+
return currentT;
|
|
44
|
+
}
|
|
45
|
+
function newtonRaphsonIterate(aX, _aGuessT, mX1, mX2) {
|
|
46
|
+
let aGuessT = _aGuessT;
|
|
47
|
+
for (let i = 0; i < NEWTON_ITERATIONS; ++i) {
|
|
48
|
+
const currentSlope = getSlope(aGuessT, mX1, mX2);
|
|
49
|
+
if (currentSlope === 0.0) {
|
|
50
|
+
return aGuessT;
|
|
51
|
+
}
|
|
52
|
+
const currentX = calcBezier(aGuessT, mX1, mX2) - aX;
|
|
53
|
+
aGuessT -= currentX / currentSlope;
|
|
54
|
+
}
|
|
55
|
+
return aGuessT;
|
|
56
|
+
}
|
|
57
|
+
export function bezier(mX1, mY1, mX2, mY2) {
|
|
58
|
+
if (!(mX1 >= 0 && mX1 <= 1 && mX2 >= 0 && mX2 <= 1)) {
|
|
59
|
+
throw new Error('bezier x values must be in [0, 1] range');
|
|
60
|
+
}
|
|
61
|
+
// Precompute samples table
|
|
62
|
+
const sampleValues = float32ArraySupported
|
|
63
|
+
? new Float32Array(kSplineTableSize)
|
|
64
|
+
: new Array(kSplineTableSize);
|
|
65
|
+
if (mX1 !== mY1 || mX2 !== mY2) {
|
|
66
|
+
for (let i = 0; i < kSplineTableSize; ++i) {
|
|
67
|
+
sampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
function getTForX(aX) {
|
|
71
|
+
let intervalStart = 0.0;
|
|
72
|
+
let currentSample = 1;
|
|
73
|
+
const lastSample = kSplineTableSize - 1;
|
|
74
|
+
for (; currentSample !== lastSample && sampleValues[currentSample] <= aX; ++currentSample) {
|
|
75
|
+
intervalStart += kSampleStepSize;
|
|
76
|
+
}
|
|
77
|
+
--currentSample;
|
|
78
|
+
// Interpolate to provide an initial guess for t
|
|
79
|
+
const dist = (aX - sampleValues[currentSample]) /
|
|
80
|
+
(sampleValues[currentSample + 1] - sampleValues[currentSample]);
|
|
81
|
+
const guessForT = intervalStart + dist * kSampleStepSize;
|
|
82
|
+
const initialSlope = getSlope(guessForT, mX1, mX2);
|
|
83
|
+
if (initialSlope >= NEWTON_MIN_SLOPE) {
|
|
84
|
+
return newtonRaphsonIterate(aX, guessForT, mX1, mX2);
|
|
85
|
+
}
|
|
86
|
+
if (initialSlope === 0.0) {
|
|
87
|
+
return guessForT;
|
|
88
|
+
}
|
|
89
|
+
return binarySubdivide({
|
|
90
|
+
aX,
|
|
91
|
+
_aA: intervalStart,
|
|
92
|
+
_aB: intervalStart + kSampleStepSize,
|
|
93
|
+
mX1,
|
|
94
|
+
mX2,
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
return function (x) {
|
|
98
|
+
if (mX1 === mY1 && mX2 === mY2) {
|
|
99
|
+
return x; // linear
|
|
100
|
+
}
|
|
101
|
+
// Because JavaScript number are imprecise, we should guarantee the extremes are right.
|
|
102
|
+
if (x === 0) {
|
|
103
|
+
return 0;
|
|
104
|
+
}
|
|
105
|
+
if (x === 1) {
|
|
106
|
+
return 1;
|
|
107
|
+
}
|
|
108
|
+
return calcBezier(getTForX(x), mY1, mY2);
|
|
109
|
+
};
|
|
110
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
type Block = {
|
|
3
|
+
id: string;
|
|
4
|
+
};
|
|
5
|
+
type OnBufferingCallback = () => void;
|
|
6
|
+
type OnResumeCallback = () => void;
|
|
7
|
+
type ListenForBuffering = (callback: OnBufferingCallback) => {
|
|
8
|
+
remove: () => void;
|
|
9
|
+
};
|
|
10
|
+
type ListenForResume = (callback: OnResumeCallback) => {
|
|
11
|
+
remove: () => void;
|
|
12
|
+
};
|
|
13
|
+
type AddBlock = (block: Block) => {
|
|
14
|
+
unblock: () => void;
|
|
15
|
+
};
|
|
16
|
+
type BufferManager = {
|
|
17
|
+
addBlock: AddBlock;
|
|
18
|
+
listenForBuffering: ListenForBuffering;
|
|
19
|
+
listenForResume: ListenForResume;
|
|
20
|
+
buffering: React.MutableRefObject<boolean>;
|
|
21
|
+
};
|
|
22
|
+
export declare const BufferingContextReact: React.Context<BufferManager | null>;
|
|
23
|
+
export declare const BufferingProvider: React.FC<{
|
|
24
|
+
children: React.ReactNode;
|
|
25
|
+
}>;
|
|
26
|
+
export {};
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';
|
|
3
|
+
const useBufferManager = () => {
|
|
4
|
+
const [blocks, setBlocks] = useState([]);
|
|
5
|
+
const [onBufferingCallbacks, setOnBufferingCallbacks] = useState([]);
|
|
6
|
+
const [onResumeCallbacks, setOnResumeCallbacks] = useState([]);
|
|
7
|
+
const buffering = useRef(false);
|
|
8
|
+
const addBlock = useCallback((block) => {
|
|
9
|
+
setBlocks((b) => [...b, block]);
|
|
10
|
+
return {
|
|
11
|
+
unblock: () => {
|
|
12
|
+
setBlocks((b) => b.filter((bx) => bx !== block));
|
|
13
|
+
},
|
|
14
|
+
};
|
|
15
|
+
}, []);
|
|
16
|
+
const listenForBuffering = useCallback((callback) => {
|
|
17
|
+
setOnBufferingCallbacks((c) => [...c, callback]);
|
|
18
|
+
return {
|
|
19
|
+
remove: () => {
|
|
20
|
+
setOnBufferingCallbacks((c) => c.filter((cb) => cb !== callback));
|
|
21
|
+
},
|
|
22
|
+
};
|
|
23
|
+
}, []);
|
|
24
|
+
const listenForResume = useCallback((callback) => {
|
|
25
|
+
setOnResumeCallbacks((c) => [...c, callback]);
|
|
26
|
+
return {
|
|
27
|
+
remove: () => {
|
|
28
|
+
setOnResumeCallbacks((c) => c.filter((cb) => cb !== callback));
|
|
29
|
+
},
|
|
30
|
+
};
|
|
31
|
+
}, []);
|
|
32
|
+
useEffect(() => {
|
|
33
|
+
if (blocks.length > 0) {
|
|
34
|
+
onBufferingCallbacks.forEach((c) => c());
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
onResumeCallbacks.forEach((c) => c());
|
|
38
|
+
}
|
|
39
|
+
}, [blocks, onBufferingCallbacks, onResumeCallbacks]);
|
|
40
|
+
return useMemo(() => {
|
|
41
|
+
return { addBlock, listenForBuffering, listenForResume, buffering };
|
|
42
|
+
}, [addBlock, buffering, listenForBuffering, listenForResume]);
|
|
43
|
+
};
|
|
44
|
+
export const BufferingContextReact = React.createContext(null);
|
|
45
|
+
export const BufferingProvider = ({ children }) => {
|
|
46
|
+
const bufferManager = useBufferManager();
|
|
47
|
+
return (_jsx(BufferingContextReact.Provider, { value: bufferManager, children: children }));
|
|
48
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export const calculateLoopDuration = ({ endAt, mediaDuration, playbackRate, startFrom, }) => {
|
|
2
|
+
let duration = mediaDuration;
|
|
3
|
+
// Account for endAt
|
|
4
|
+
if (typeof endAt !== 'undefined') {
|
|
5
|
+
duration = endAt;
|
|
6
|
+
}
|
|
7
|
+
// Account for startFrom
|
|
8
|
+
if (typeof startFrom !== 'undefined') {
|
|
9
|
+
duration -= startFrom;
|
|
10
|
+
}
|
|
11
|
+
const actualDuration = duration / playbackRate;
|
|
12
|
+
return Math.floor(actualDuration);
|
|
13
|
+
};
|