remotion 3.3.45 → 3.3.52
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Sequence.js +1 -1
- package/dist/Still.d.ts +0 -1
- package/dist/audio/Audio.d.ts +2 -2
- package/dist/audio/AudioForDevelopment.d.ts +1 -1
- package/dist/audio/AudioForRendering.d.ts +1 -1
- package/dist/cjs/AbsoluteFill.d.ts +6 -0
- package/dist/cjs/AbsoluteFill.js +28 -0
- package/dist/cjs/CanUseRemotionHooks.d.ts +5 -0
- package/dist/cjs/CanUseRemotionHooks.js +10 -0
- package/dist/cjs/Clipper.d.ts +7 -0
- package/dist/cjs/Clipper.js +24 -0
- package/dist/cjs/Composition.d.ts +23 -0
- package/dist/cjs/Composition.js +113 -0
- package/dist/cjs/CompositionManager.d.ts +82 -0
- package/dist/cjs/CompositionManager.js +164 -0
- package/dist/cjs/Folder.d.ts +15 -0
- package/dist/cjs/Folder.js +33 -0
- package/dist/cjs/IFrame.d.ts +2 -0
- package/dist/cjs/IFrame.js +24 -0
- package/dist/cjs/Img.d.ts +2 -0
- package/dist/cjs/Img.js +52 -0
- package/dist/cjs/NativeLayers.d.ts +13 -0
- package/dist/cjs/NativeLayers.js +29 -0
- package/dist/cjs/Null.d.ts +2 -0
- package/dist/cjs/Null.js +25 -0
- package/dist/cjs/RemotionRoot.d.ts +5 -0
- package/dist/cjs/RemotionRoot.js +73 -0
- package/dist/cjs/Sequence.d.ts +29 -0
- package/dist/cjs/Sequence.js +131 -0
- package/dist/cjs/Still.d.ts +3 -0
- package/dist/cjs/Still.js +9 -0
- package/dist/cjs/absolute-src.d.ts +1 -0
- package/dist/cjs/absolute-src.js +7 -0
- package/dist/cjs/asset-types.d.ts +50 -0
- package/dist/cjs/asset-types.js +1 -0
- package/dist/cjs/audio/Audio.d.ts +8 -0
- package/dist/cjs/audio/Audio.js +52 -0
- package/dist/cjs/audio/AudioForDevelopment.d.ts +11 -0
- package/dist/cjs/audio/AudioForDevelopment.js +94 -0
- package/dist/cjs/audio/AudioForRendering.d.ts +10 -0
- package/dist/cjs/audio/AudioForRendering.js +111 -0
- package/dist/cjs/audio/index.d.ts +2 -0
- package/dist/cjs/audio/index.js +18 -0
- package/dist/cjs/audio/props.d.ts +12 -0
- package/dist/cjs/audio/props.js +2 -0
- package/dist/cjs/audio/shared-audio-tags.d.ts +37 -0
- package/dist/cjs/audio/shared-audio-tags.js +222 -0
- package/dist/cjs/audio/use-audio-frame.d.ts +6 -0
- package/dist/cjs/audio/use-audio-frame.js +23 -0
- package/dist/cjs/bezier.d.ts +1 -0
- package/dist/cjs/bezier.js +114 -0
- package/dist/cjs/cancel-render.d.ts +1 -0
- package/dist/cjs/cancel-render.js +43 -0
- package/dist/cjs/config/input-props.d.ts +1 -0
- package/dist/cjs/config/input-props.js +31 -0
- package/dist/cjs/config.d.ts +285 -0
- package/dist/cjs/config.js +21 -0
- package/dist/cjs/default-css.d.ts +3 -0
- package/dist/cjs/default-css.js +49 -0
- package/dist/cjs/delay-render.d.ts +14 -0
- package/dist/cjs/delay-render.js +77 -0
- package/dist/cjs/easing.d.ts +19 -0
- package/dist/cjs/easing.js +77 -0
- package/dist/cjs/freeze.d.ts +7 -0
- package/dist/cjs/freeze.js +34 -0
- package/dist/cjs/get-asset-file-name.d.ts +1 -0
- package/dist/cjs/get-asset-file-name.js +14 -0
- package/dist/cjs/get-environment.d.ts +3 -0
- package/dist/cjs/get-environment.js +34 -0
- package/dist/cjs/get-preview-dom-element.d.ts +1 -0
- package/dist/cjs/get-preview-dom-element.js +7 -0
- package/dist/cjs/get-static-files.d.ts +17 -0
- package/dist/cjs/get-static-files.js +31 -0
- package/dist/cjs/get-timeline-clip-name.d.ts +1 -0
- package/dist/cjs/get-timeline-clip-name.js +25 -0
- package/dist/cjs/index.d.ts +92 -0
- package/dist/cjs/index.js +73 -0
- package/dist/cjs/internals.d.ts +99 -0
- package/dist/cjs/internals.js +101 -0
- package/dist/cjs/interpolate-colors.d.ts +5 -0
- package/dist/cjs/interpolate-colors.js +401 -0
- package/dist/cjs/interpolate.d.ts +18 -0
- package/dist/cjs/interpolate.js +123 -0
- package/dist/cjs/is-approximately-the-same.d.ts +1 -0
- package/dist/cjs/is-approximately-the-same.js +8 -0
- package/dist/cjs/is-player.d.ts +3 -0
- package/dist/cjs/is-player.js +14 -0
- package/dist/cjs/loading-indicator.d.ts +2 -0
- package/dist/cjs/loading-indicator.js +35 -0
- package/dist/cjs/loop/index.d.ts +9 -0
- package/dist/cjs/loop/index.js +29 -0
- package/dist/cjs/multiple-versions-warning.d.ts +1 -0
- package/dist/cjs/multiple-versions-warning.js +32 -0
- package/dist/cjs/nonce.d.ts +7 -0
- package/dist/cjs/nonce.js +17 -0
- package/dist/cjs/play-and-handle-not-allowed-error.d.ts +2 -0
- package/dist/cjs/play-and-handle-not-allowed-error.js +44 -0
- package/dist/cjs/portal-node.d.ts +1 -0
- package/dist/cjs/portal-node.js +23 -0
- package/dist/cjs/prefetch-state.d.ts +8 -0
- package/dist/cjs/prefetch-state.js +27 -0
- package/dist/cjs/prefetch.d.ts +9 -0
- package/dist/cjs/prefetch.js +108 -0
- package/dist/cjs/random.d.ts +7 -0
- package/dist/cjs/random.js +42 -0
- package/dist/cjs/register-root.d.ts +4 -0
- package/dist/cjs/register-root.js +33 -0
- package/dist/cjs/series/flatten-children.d.ts +2 -0
- package/dist/cjs/series/flatten-children.js +19 -0
- package/dist/cjs/series/index.d.ts +13 -0
- package/dist/cjs/series/index.js +60 -0
- package/dist/cjs/setup-env-variables.d.ts +2 -0
- package/dist/cjs/setup-env-variables.js +36 -0
- package/dist/cjs/spring/index.d.ts +27 -0
- package/dist/cjs/spring/index.js +55 -0
- package/dist/cjs/spring/measure-spring.d.ts +8 -0
- package/dist/cjs/spring/measure-spring.js +64 -0
- package/dist/cjs/spring/spring-utils.d.ts +21 -0
- package/dist/cjs/spring/spring-utils.js +103 -0
- package/dist/cjs/static-file.d.ts +5 -0
- package/dist/cjs/static-file.js +33 -0
- 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 +115 -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/cjs/timeline-position-state.d.ts +29 -0
- package/dist/cjs/timeline-position-state.js +41 -0
- package/dist/cjs/truthy.d.ts +3 -0
- package/dist/cjs/truthy.js +7 -0
- package/dist/cjs/use-current-frame.d.ts +6 -0
- package/dist/cjs/use-current-frame.js +28 -0
- package/dist/cjs/use-lazy-component.d.ts +7 -0
- package/dist/cjs/use-lazy-component.js +49 -0
- package/dist/cjs/use-media-in-timeline.d.ts +10 -0
- package/dist/cjs/use-media-in-timeline.js +129 -0
- package/dist/cjs/use-media-playback.d.ts +10 -0
- package/dist/cjs/use-media-playback.js +77 -0
- package/dist/cjs/use-media-tag-volume.d.ts +2 -0
- package/dist/cjs/use-media-tag-volume.js +31 -0
- package/dist/cjs/use-sync-volume-with-media-tag.d.ts +10 -0
- package/dist/cjs/use-sync-volume-with-media-tag.js +21 -0
- package/dist/cjs/use-unsafe-video-config.d.ts +2 -0
- package/dist/cjs/use-unsafe-video-config.js +27 -0
- package/dist/cjs/use-video-config.d.ts +7 -0
- package/dist/cjs/use-video-config.js +29 -0
- package/dist/cjs/use-video.d.ts +13 -0
- package/dist/cjs/use-video.js +28 -0
- package/dist/cjs/validate-frame.d.ts +1 -0
- package/dist/cjs/validate-frame.js +24 -0
- package/dist/cjs/validate-media-props.d.ts +4 -0
- package/dist/cjs/validate-media-props.js +24 -0
- package/dist/cjs/validate-start-from-props.d.ts +1 -0
- package/dist/cjs/validate-start-from-props.js +31 -0
- package/dist/cjs/validation/validate-composition-id.d.ts +3 -0
- package/dist/cjs/validation/validate-composition-id.js +13 -0
- package/dist/cjs/validation/validate-dimensions.d.ts +1 -0
- package/dist/cjs/validation/validate-dimensions.js +21 -0
- package/dist/cjs/validation/validate-duration-in-frames.d.ts +1 -0
- package/dist/cjs/validation/validate-duration-in-frames.js +15 -0
- package/dist/cjs/validation/validate-folder-name.d.ts +3 -0
- package/dist/cjs/validation/validate-folder-name.js +19 -0
- package/dist/cjs/validation/validate-fps.d.ts +1 -0
- package/dist/cjs/validation/validate-fps.js +21 -0
- package/dist/cjs/validation/validate-offthreadvideo-image-format.d.ts +1 -0
- package/dist/cjs/validation/validate-offthreadvideo-image-format.js +15 -0
- package/dist/cjs/validation/validation-spring-duration.d.ts +1 -0
- package/dist/cjs/validation/validation-spring-duration.js +21 -0
- package/dist/cjs/version.d.ts +1 -0
- package/dist/cjs/version.js +5 -0
- package/dist/cjs/video/OffthreadVideo.d.ts +3 -0
- package/dist/cjs/video/OffthreadVideo.js +33 -0
- package/dist/cjs/video/OffthreadVideoForRendering.d.ts +3 -0
- package/dist/cjs/video/OffthreadVideoForRendering.js +104 -0
- package/dist/cjs/video/Video.d.ts +8 -0
- package/dist/cjs/video/Video.js +50 -0
- package/dist/cjs/video/VideoForDevelopment.d.ts +11 -0
- package/dist/cjs/video/VideoForDevelopment.js +113 -0
- package/dist/cjs/video/VideoForRendering.d.ts +10 -0
- package/dist/cjs/video/VideoForRendering.js +203 -0
- package/dist/cjs/video/duration-state.d.ts +17 -0
- package/dist/cjs/video/duration-state.js +34 -0
- package/dist/cjs/video/get-current-time.d.ts +13 -0
- package/dist/cjs/video/get-current-time.js +31 -0
- package/dist/cjs/video/index.d.ts +3 -0
- package/dist/cjs/video/index.js +7 -0
- package/dist/cjs/video/props.d.ts +25 -0
- package/dist/cjs/video/props.js +2 -0
- package/dist/cjs/video/video-fragment.d.ts +12 -0
- package/dist/cjs/video/video-fragment.js +60 -0
- package/dist/cjs/video-config.d.ts +8 -0
- package/dist/cjs/video-config.js +2 -0
- package/dist/cjs/volume-position-state.d.ts +19 -0
- package/dist/cjs/volume-position-state.js +32 -0
- package/dist/cjs/volume-prop.d.ts +7 -0
- package/dist/cjs/volume-prop.js +24 -0
- package/dist/cjs/warn-about-non-seekable-media.d.ts +1 -0
- package/dist/cjs/warn-about-non-seekable-media.js +34 -0
- package/dist/cjs/wrap-remotion-context.d.ts +18 -0
- package/dist/cjs/wrap-remotion-context.js +73 -0
- 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 +57 -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 +113 -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/internals.d.ts +0 -1
- package/dist/series/index.js +5 -2
- package/dist/tsconfig-cjs.tsbuildinfo +1 -0
- package/dist/use-video.d.ts +0 -1
- package/dist/version.d.ts +1 -1
- package/dist/version.js +1 -1
- package/dist/video/Video.d.ts +1 -1
- package/dist/video/VideoForDevelopment.d.ts +1 -1
- package/dist/video/VideoForRendering.d.ts +1 -1
- package/package.json +23 -12
- 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/get-compositions-from-markup.d.ts +0 -3
- package/dist/get-compositions-from-markup.js +0 -19
- package/dist/layers.d.ts +0 -24
- package/dist/layers.js +0 -149
- 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
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
const defaultSpringConfig = {
|
|
2
|
+
damping: 10,
|
|
3
|
+
mass: 1,
|
|
4
|
+
stiffness: 100,
|
|
5
|
+
overshootClamping: false,
|
|
6
|
+
};
|
|
7
|
+
const advanceCache = {};
|
|
8
|
+
function advance({ animation, now, config, }) {
|
|
9
|
+
const { toValue, lastTimestamp, current, velocity } = animation;
|
|
10
|
+
const deltaTime = Math.min(now - lastTimestamp, 64);
|
|
11
|
+
const c = config.damping;
|
|
12
|
+
const m = config.mass;
|
|
13
|
+
const k = config.stiffness;
|
|
14
|
+
const cacheKey = [
|
|
15
|
+
toValue,
|
|
16
|
+
lastTimestamp,
|
|
17
|
+
current,
|
|
18
|
+
velocity,
|
|
19
|
+
c,
|
|
20
|
+
m,
|
|
21
|
+
k,
|
|
22
|
+
now,
|
|
23
|
+
].join('-');
|
|
24
|
+
if (advanceCache[cacheKey]) {
|
|
25
|
+
return advanceCache[cacheKey];
|
|
26
|
+
}
|
|
27
|
+
const v0 = -velocity;
|
|
28
|
+
const x0 = toValue - current;
|
|
29
|
+
const zeta = c / (2 * Math.sqrt(k * m)); // damping ratio
|
|
30
|
+
const omega0 = Math.sqrt(k / m); // undamped angular frequency of the oscillator (rad/ms)
|
|
31
|
+
const omega1 = omega0 * Math.sqrt(1 - zeta ** 2); // exponential decay
|
|
32
|
+
const t = deltaTime / 1000;
|
|
33
|
+
const sin1 = Math.sin(omega1 * t);
|
|
34
|
+
const cos1 = Math.cos(omega1 * t);
|
|
35
|
+
// under damped
|
|
36
|
+
const underDampedEnvelope = Math.exp(-zeta * omega0 * t);
|
|
37
|
+
const underDampedFrag1 = underDampedEnvelope *
|
|
38
|
+
(sin1 * ((v0 + zeta * omega0 * x0) / omega1) + x0 * cos1);
|
|
39
|
+
const underDampedPosition = toValue - underDampedFrag1;
|
|
40
|
+
// This looks crazy -- it's actually just the derivative of the oscillation function
|
|
41
|
+
const underDampedVelocity = zeta * omega0 * underDampedFrag1 -
|
|
42
|
+
underDampedEnvelope *
|
|
43
|
+
(cos1 * (v0 + zeta * omega0 * x0) - omega1 * x0 * sin1);
|
|
44
|
+
// critically damped
|
|
45
|
+
const criticallyDampedEnvelope = Math.exp(-omega0 * t);
|
|
46
|
+
const criticallyDampedPosition = toValue - criticallyDampedEnvelope * (x0 + (v0 + omega0 * x0) * t);
|
|
47
|
+
const criticallyDampedVelocity = criticallyDampedEnvelope *
|
|
48
|
+
(v0 * (t * omega0 - 1) + t * x0 * omega0 * omega0);
|
|
49
|
+
const animationNode = {
|
|
50
|
+
toValue,
|
|
51
|
+
prevPosition: current,
|
|
52
|
+
lastTimestamp: now,
|
|
53
|
+
current: zeta < 1 ? underDampedPosition : criticallyDampedPosition,
|
|
54
|
+
velocity: zeta < 1 ? underDampedVelocity : criticallyDampedVelocity,
|
|
55
|
+
};
|
|
56
|
+
advanceCache[cacheKey] = animationNode;
|
|
57
|
+
return animationNode;
|
|
58
|
+
}
|
|
59
|
+
const calculationCache = {};
|
|
60
|
+
export function springCalculation({ from = 0, to = 1, frame, fps, config = {}, }) {
|
|
61
|
+
const cacheKey = [
|
|
62
|
+
from,
|
|
63
|
+
to,
|
|
64
|
+
frame,
|
|
65
|
+
fps,
|
|
66
|
+
config.damping,
|
|
67
|
+
config.mass,
|
|
68
|
+
config.overshootClamping,
|
|
69
|
+
config.stiffness,
|
|
70
|
+
].join('-');
|
|
71
|
+
if (calculationCache[cacheKey]) {
|
|
72
|
+
return calculationCache[cacheKey];
|
|
73
|
+
}
|
|
74
|
+
let animation = {
|
|
75
|
+
lastTimestamp: 0,
|
|
76
|
+
current: from,
|
|
77
|
+
toValue: to,
|
|
78
|
+
velocity: 0,
|
|
79
|
+
prevPosition: 0,
|
|
80
|
+
};
|
|
81
|
+
const frameClamped = Math.max(0, frame);
|
|
82
|
+
const unevenRest = frameClamped % 1;
|
|
83
|
+
for (let f = 0; f <= Math.floor(frameClamped); f++) {
|
|
84
|
+
if (f === Math.floor(frameClamped)) {
|
|
85
|
+
f += unevenRest;
|
|
86
|
+
}
|
|
87
|
+
const time = (f / fps) * 1000;
|
|
88
|
+
animation = advance({
|
|
89
|
+
animation,
|
|
90
|
+
now: time,
|
|
91
|
+
config: {
|
|
92
|
+
...defaultSpringConfig,
|
|
93
|
+
...config,
|
|
94
|
+
},
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
calculationCache[cacheKey] = animation;
|
|
98
|
+
return animation;
|
|
99
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
const trimLeadingSlash = (path) => {
|
|
2
|
+
if (path.startsWith('/')) {
|
|
3
|
+
return trimLeadingSlash(path.substr(1));
|
|
4
|
+
}
|
|
5
|
+
return path;
|
|
6
|
+
};
|
|
7
|
+
const inner = (path) => {
|
|
8
|
+
if (typeof window !== 'undefined' && window.remotion_staticBase) {
|
|
9
|
+
return `${window.remotion_staticBase}/${trimLeadingSlash(path)}`;
|
|
10
|
+
}
|
|
11
|
+
return `/${trimLeadingSlash(path)}`;
|
|
12
|
+
};
|
|
13
|
+
/**
|
|
14
|
+
* Reference a file from the public/ folder.
|
|
15
|
+
* If the file does not appear in the autocomplete, type the path manually.
|
|
16
|
+
*/
|
|
17
|
+
export const staticFile = (path) => {
|
|
18
|
+
if (path.startsWith('http://') || path.startsWith('https://')) {
|
|
19
|
+
throw new TypeError(`staticFile() does not support remote URLs - got "${path}". Instead, pass the URL without wrapping it in staticFile(). See: https://remotion.dev/docs/staticfile-remote-urls`);
|
|
20
|
+
}
|
|
21
|
+
if (path.startsWith('..') || path.startsWith('./')) {
|
|
22
|
+
throw new TypeError(`staticFile() does not support relative paths - got "${path}". Instead, pass the name of a file that is inside the public/ folder. See: https://remotion.dev/docs/staticfile-relative-paths`);
|
|
23
|
+
}
|
|
24
|
+
const preparsed = inner(path);
|
|
25
|
+
if (!preparsed.startsWith('/')) {
|
|
26
|
+
return `/${preparsed}`;
|
|
27
|
+
}
|
|
28
|
+
return preparsed;
|
|
29
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,20 @@
|
|
|
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 from 'react';
|
|
7
|
+
import { beforeEach, expect, test } from 'vitest';
|
|
8
|
+
import { Img } from '../Img.js';
|
|
9
|
+
const ref = React.createRef();
|
|
10
|
+
const testImgUrl = 'https://source.unsplash.com/random/50x50';
|
|
11
|
+
beforeEach(() => {
|
|
12
|
+
render(_jsx(Img, { ref: ref, src: testImgUrl }));
|
|
13
|
+
});
|
|
14
|
+
test('Img component renders img tag', () => {
|
|
15
|
+
var _a;
|
|
16
|
+
expect((_a = ref.current) === null || _a === void 0 ? void 0 : _a.tagName).toBe('IMG');
|
|
17
|
+
});
|
|
18
|
+
test('Src attribute is forwarded to img tag', () => {
|
|
19
|
+
expect(ref.current).toHaveProperty('src', testImgUrl);
|
|
20
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @vitest-environment jsdom
|
|
3
|
+
*/
|
|
4
|
+
import { describe, expect, test } from 'vitest';
|
|
5
|
+
import { getAbsoluteSrc } from '../absolute-src.js';
|
|
6
|
+
describe('Absolute src should behave as expected', () => {
|
|
7
|
+
test('Get localhost:8080', () => {
|
|
8
|
+
expect(getAbsoluteSrc('http://localhost:8080')).toBe('http://localhost:8080/');
|
|
9
|
+
});
|
|
10
|
+
test('Get localhost/hi', () => {
|
|
11
|
+
expect(getAbsoluteSrc('/hi')).toBe('http://localhost:3000/hi');
|
|
12
|
+
});
|
|
13
|
+
test('Get data:base64', () => {
|
|
14
|
+
expect(getAbsoluteSrc('data:base64,image/png,abc')).toBe('data:base64,image/png,abc');
|
|
15
|
+
});
|
|
16
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* @vitest-environment jsdom
|
|
4
|
+
*/
|
|
5
|
+
import { render } from '@testing-library/react';
|
|
6
|
+
import React from 'react';
|
|
7
|
+
import { afterAll, beforeAll, beforeEach, describe, expect, test, vitest, } from 'vitest';
|
|
8
|
+
import { AudioForRendering } from '../audio/AudioForRendering.js';
|
|
9
|
+
import { CanUseRemotionHooksProvider } from '../CanUseRemotionHooks.js';
|
|
10
|
+
import { Internals } from '../internals.js';
|
|
11
|
+
import { expectToThrow } from './expect-to-throw.js';
|
|
12
|
+
let mockContext;
|
|
13
|
+
describe('Register and unregister asset', () => {
|
|
14
|
+
function createMockContext() {
|
|
15
|
+
const registerAsset = vitest.fn();
|
|
16
|
+
const unregisterAsset = vitest.fn();
|
|
17
|
+
window.remotion_audioEnabled = true;
|
|
18
|
+
const MockProvider = ({ children }) => {
|
|
19
|
+
return (_jsx(CanUseRemotionHooksProvider, { children: _jsx(Internals.CompositionManager.Provider, { value:
|
|
20
|
+
// eslint-disable-next-line react/jsx-no-constructed-context-values
|
|
21
|
+
{
|
|
22
|
+
registerAsset,
|
|
23
|
+
unregisterAsset,
|
|
24
|
+
}, children: children }) }));
|
|
25
|
+
};
|
|
26
|
+
return {
|
|
27
|
+
MockProvider,
|
|
28
|
+
registerAsset,
|
|
29
|
+
unregisterAsset,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
beforeEach(() => {
|
|
33
|
+
mockContext = createMockContext();
|
|
34
|
+
});
|
|
35
|
+
test('register and unregister asset', () => {
|
|
36
|
+
const props = {
|
|
37
|
+
src: 'test',
|
|
38
|
+
muted: false,
|
|
39
|
+
volume: 50,
|
|
40
|
+
onDuration: vitest.fn(),
|
|
41
|
+
};
|
|
42
|
+
const { unmount } = render(_jsx(CanUseRemotionHooksProvider, { children: _jsx(mockContext.MockProvider, { children: _jsx(AudioForRendering, { ...props }) }) }));
|
|
43
|
+
expect(mockContext.registerAsset).toHaveBeenCalled();
|
|
44
|
+
unmount();
|
|
45
|
+
expect(mockContext.unregisterAsset).toHaveBeenCalled();
|
|
46
|
+
});
|
|
47
|
+
test('no src passed', () => {
|
|
48
|
+
const props = {
|
|
49
|
+
src: undefined,
|
|
50
|
+
muted: false,
|
|
51
|
+
volume: 50,
|
|
52
|
+
onDuration: vitest.fn(),
|
|
53
|
+
};
|
|
54
|
+
expectToThrow(() => {
|
|
55
|
+
render(_jsx(CanUseRemotionHooksProvider, { children: _jsx(mockContext.MockProvider, { children: _jsx(AudioForRendering, { ...props }) }) }));
|
|
56
|
+
}, /No src passed/);
|
|
57
|
+
expect(mockContext.registerAsset).not.toHaveBeenCalled();
|
|
58
|
+
expect(mockContext.unregisterAsset).not.toHaveBeenCalled();
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
let mockUseEffect;
|
|
62
|
+
describe('useEffect tests', () => {
|
|
63
|
+
const useEffectSpy = vitest.spyOn(React, 'useEffect');
|
|
64
|
+
mockUseEffect = vitest.fn();
|
|
65
|
+
beforeAll(() => {
|
|
66
|
+
useEffectSpy.mockImplementation(() => {
|
|
67
|
+
mockUseEffect();
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
afterAll(() => {
|
|
71
|
+
useEffectSpy.mockRestore();
|
|
72
|
+
});
|
|
73
|
+
test.skip('has registered', () => {
|
|
74
|
+
const props = {
|
|
75
|
+
src: 'test',
|
|
76
|
+
muted: false,
|
|
77
|
+
volume: 50,
|
|
78
|
+
onDuration: vitest.fn(),
|
|
79
|
+
};
|
|
80
|
+
render(_jsxs(CanUseRemotionHooksProvider, { children: [_jsx(AudioForRendering, { ...props }), ' '] }));
|
|
81
|
+
expect(mockUseEffect).toHaveBeenCalled();
|
|
82
|
+
});
|
|
83
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,51 @@
|
|
|
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 { Audio } from '../audio';
|
|
9
|
+
import { CanUseRemotionHooksProvider } from '../CanUseRemotionHooks.js';
|
|
10
|
+
import { Internals } from '../internals.js';
|
|
11
|
+
const Wrapper = ({ children }) => {
|
|
12
|
+
const compositions = useContext(Internals.CompositionManager);
|
|
13
|
+
return (_jsx(CanUseRemotionHooksProvider, { children: _jsx(Internals.RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Internals.CompositionManager.Provider
|
|
14
|
+
// eslint-disable-next-line react/jsx-no-constructed-context-values
|
|
15
|
+
, {
|
|
16
|
+
// eslint-disable-next-line react/jsx-no-constructed-context-values
|
|
17
|
+
value: {
|
|
18
|
+
...compositions,
|
|
19
|
+
compositions: [
|
|
20
|
+
{
|
|
21
|
+
height: 1080,
|
|
22
|
+
width: 1080,
|
|
23
|
+
fps: 30,
|
|
24
|
+
durationInFrames: 30,
|
|
25
|
+
id: 'markup',
|
|
26
|
+
nonce: 0,
|
|
27
|
+
component: React.lazy(() => Promise.resolve({
|
|
28
|
+
default: (() => null),
|
|
29
|
+
})),
|
|
30
|
+
defaultProps: undefined,
|
|
31
|
+
folderName: null,
|
|
32
|
+
parentFolderName: null,
|
|
33
|
+
},
|
|
34
|
+
],
|
|
35
|
+
currentComposition: 'markup',
|
|
36
|
+
}, children: children }) }) }));
|
|
37
|
+
};
|
|
38
|
+
describe('Render correctly with props', () => {
|
|
39
|
+
test('It should render Audio without startFrom / endAt props', () => {
|
|
40
|
+
expect(() => render(_jsx(Wrapper, { children: _jsx(Audio, { src: "test", volume: 1 }) }))).not.toThrow();
|
|
41
|
+
});
|
|
42
|
+
test('It should render Audio with startAt props', () => {
|
|
43
|
+
expect(() => render(_jsx(Wrapper, { children: _jsx(Audio, { src: "test", volume: 1, startFrom: 10 }) }))).not.toThrow();
|
|
44
|
+
});
|
|
45
|
+
test('It should render Audio with endAt props', () => {
|
|
46
|
+
expect(() => render(_jsx(Wrapper, { children: _jsx(Audio, { src: "test", volume: 1, endAt: 10 }) }))).not.toThrow();
|
|
47
|
+
});
|
|
48
|
+
test('It should render Audio with startFrom and endAt props', () => {
|
|
49
|
+
expect(() => render(_jsx(Wrapper, { children: _jsx(Audio, { src: "test", volume: 1, startFrom: 10, endAt: 20 }) }))).not.toThrow();
|
|
50
|
+
});
|
|
51
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { expect, test } from 'vitest';
|
|
2
|
+
import { bezier } from '../bezier.js';
|
|
3
|
+
const identity = (x) => {
|
|
4
|
+
return x;
|
|
5
|
+
};
|
|
6
|
+
const assertClose = (a, b, precision = 3) => {
|
|
7
|
+
expect(a).toBeCloseTo(b, precision);
|
|
8
|
+
};
|
|
9
|
+
const allEquals = (be1, be2, samples) => {
|
|
10
|
+
for (let i = 0; i <= samples; ++i) {
|
|
11
|
+
const x = i / samples;
|
|
12
|
+
assertClose(be1(x), be2(x));
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
function repeat(n) {
|
|
16
|
+
return function (f) {
|
|
17
|
+
for (let i = 0; i < n; ++i) {
|
|
18
|
+
f();
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
test('bezier - should create an object', () => {
|
|
23
|
+
expect(typeof bezier(0, 0, 1, 1) === 'function').toBe(true);
|
|
24
|
+
});
|
|
25
|
+
test('bezier - fail with wrong params', () => {
|
|
26
|
+
const valuesToTest = [
|
|
27
|
+
[0.5, 0.5, -5, 0.5],
|
|
28
|
+
[0.5, 0.5, 5, 0.5],
|
|
29
|
+
[-2, 0.5, 0.5, 0.5],
|
|
30
|
+
[2, 0.5, 0.5, 0.5],
|
|
31
|
+
];
|
|
32
|
+
valuesToTest.forEach((entry) => {
|
|
33
|
+
expect(() => bezier(entry[0], entry[1], entry[2], entry[3])).toThrow();
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
test('bezier - linear curves', () => {
|
|
37
|
+
allEquals(bezier(0, 0, 1, 1), bezier(1, 1, 0, 0), 100);
|
|
38
|
+
allEquals(bezier(0, 0, 1, 1), identity, 100);
|
|
39
|
+
});
|
|
40
|
+
test('bezier - right value at extremes', () => {
|
|
41
|
+
repeat(10)(() => {
|
|
42
|
+
const a = Math.random();
|
|
43
|
+
const b = 2 * Math.random() - 0.5;
|
|
44
|
+
const c = Math.random();
|
|
45
|
+
const d = 2 * Math.random() - 0.5;
|
|
46
|
+
const easing = bezier(a, b, c, d);
|
|
47
|
+
expect(easing(0)).toBe(0);
|
|
48
|
+
expect(easing(1)).toBe(1);
|
|
49
|
+
});
|
|
50
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* @vitest-environment jsdom
|
|
4
|
+
*/
|
|
5
|
+
import { render } from '@testing-library/react';
|
|
6
|
+
import { describe, expect, test } from 'vitest';
|
|
7
|
+
import { Composition } from '../Composition.js';
|
|
8
|
+
import { RemotionRoot } from '../RemotionRoot.js';
|
|
9
|
+
import { expectToThrow } from './expect-to-throw.js';
|
|
10
|
+
const AnyComp = () => null;
|
|
11
|
+
describe('Render composition-rules should throw with invalid props', () => {
|
|
12
|
+
test('It should report invalid component id', () => {
|
|
13
|
+
expectToThrow(() => render(_jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100, id: "invalid@id", width: 100 })), /can only contain/);
|
|
14
|
+
});
|
|
15
|
+
test('It should throw if no id is passed', () => {
|
|
16
|
+
expectToThrow(() => render(
|
|
17
|
+
// @ts-expect-error
|
|
18
|
+
_jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100, width: 100 })), /No id for composition passed./);
|
|
19
|
+
});
|
|
20
|
+
test('It should throw if multiple components have the same id', () => {
|
|
21
|
+
expectToThrow(() => render(_jsxs(RemotionRoot, { numberOfAudioTags: 0, children: [_jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100, width: 100, id: "id" }), _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100, width: 100, id: "id" })] })), /Multiple composition with id id/);
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
describe('Render composition-rules should not with valid props', () => {
|
|
25
|
+
test('It should validate the component id', () => {
|
|
26
|
+
expect(() => render(_jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100, id: "valid-id", width: 100 }))).not.toThrow();
|
|
27
|
+
});
|
|
28
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* @vitest-environment jsdom
|
|
4
|
+
*/
|
|
5
|
+
import { render } from '@testing-library/react';
|
|
6
|
+
import { describe, expect, test } from 'vitest';
|
|
7
|
+
import { Composition } from '..';
|
|
8
|
+
import { RemotionRoot } from '../RemotionRoot.js';
|
|
9
|
+
import { expectToThrow } from './expect-to-throw.js';
|
|
10
|
+
const AnyComp = () => null;
|
|
11
|
+
describe('Composition-validation render should throw with invalid props', () => {
|
|
12
|
+
test('It should throw if multiple components have the same id', () => {
|
|
13
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100, id: "id" }) })), /The "width/);
|
|
14
|
+
});
|
|
15
|
+
describe('Throw with invalid height props', () => {
|
|
16
|
+
test('It should throw if height is a negative number', () => {
|
|
17
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: -100, width: 100, id: "id" }) })), /The "height" prop of the <Composition\/> component must be positive, but got -100./);
|
|
18
|
+
});
|
|
19
|
+
test('It should throw if height=0 is boundary off-point', () => {
|
|
20
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 0, width: 100, id: "id" }) })), /The "height" prop of the <Composition\/> component must be positive, but got 0./);
|
|
21
|
+
});
|
|
22
|
+
test('It should throw if height is not a number', () => {
|
|
23
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30,
|
|
24
|
+
// @ts-expect-error
|
|
25
|
+
height: '100', width: 100, id: "id" }) })), /The "height" prop of the <Composition\/> component must be a number, but you passed a value of type string/);
|
|
26
|
+
});
|
|
27
|
+
test('It should throw if height is not an integer', () => {
|
|
28
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100.01, width: 100, id: "id" }) })), /The "height" prop of the <Composition\/> component must be an integer, but is 100.01/);
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
describe('Throw with invalid width props', () => {
|
|
32
|
+
test('It should throw if width is a negative number', () => {
|
|
33
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100, width: -100, id: "id" }) })), /The "width" prop of the <Composition\/> component must be positive, but got -100./);
|
|
34
|
+
});
|
|
35
|
+
test('It should throw if width=0 is boundary off-point', () => {
|
|
36
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100, width: 0, id: "id" }) })), /The "width" prop of the <Composition\/> component must be positive, but got 0./);
|
|
37
|
+
});
|
|
38
|
+
test('It should throw if width is not a number', () => {
|
|
39
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100,
|
|
40
|
+
// @ts-expect-error
|
|
41
|
+
width: '100', id: "id" }) })), /The "width" prop of the <Composition\/> component must be a number, but you passed a value of type string/);
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
describe('Throw with invalid durationInFrames', () => {
|
|
45
|
+
test('It should throw if durationInFrames of a composition is a negative number', () => {
|
|
46
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: -100, fps: 30, height: 100, width: 100, id: "id" }) })), /The "durationInFrames" prop of the <Composition\/> component must be positive, but got -100./);
|
|
47
|
+
});
|
|
48
|
+
test('It should throw if durationInFrames=0 of a composition is boundary off-point', () => {
|
|
49
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 0, fps: 30, height: 100, width: 100, id: "id" }) })), /The "durationInFrames" prop of the <Composition\/> component must be positive, but got 0./);
|
|
50
|
+
});
|
|
51
|
+
test('It should throw if durationInFrames of a composition is not an integer', () => {
|
|
52
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 0.11, fps: 30, height: 100, width: 100, id: "id" }) })), /The "durationInFrames" prop of the <Composition\/> component must be an integer, but got 0.11./);
|
|
53
|
+
});
|
|
54
|
+
test('It should throw if durationInFrames of a composition is not a number', () => {
|
|
55
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }),
|
|
56
|
+
// @ts-expect-error
|
|
57
|
+
durationInFrames: '100', fps: 30, height: 100, width: 100, id: "id" }) })), /The "durationInFrames" prop of the <Composition\/> component must be a number, but you passed a value of type string/);
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
describe('Throw with invalid fps', () => {
|
|
61
|
+
test('It should throw if fps is of a composition is negative', () => {
|
|
62
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: -30, height: 100, width: 100, id: "id" }) })), /"fps" must be positive, but got -30./);
|
|
63
|
+
});
|
|
64
|
+
test('It should throw if fps=0 of a composition is boundary off-point', () => {
|
|
65
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 0, height: 100, width: 100, id: "id" }) })), /"fps" must be positive, but got 0./);
|
|
66
|
+
});
|
|
67
|
+
test('It should throw if fps of a composition is not a number', () => {
|
|
68
|
+
expectToThrow(() => render(_jsx(RemotionRoot, { numberOfAudioTags: 0, children: _jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100,
|
|
69
|
+
// @ts-expect-error
|
|
70
|
+
fps: '30', height: 100, width: 100, id: "id" }) })), /"fps" must be a number, but you passed a value of type string/);
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
describe('Composition-validation render should NOT throw with valid props', () => {
|
|
75
|
+
describe('Not throw with valid height props', () => {
|
|
76
|
+
test('It should not throw if height is a positive number', () => {
|
|
77
|
+
expect(() => render(_jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100, width: 100, id: "id" }))).not.toThrow();
|
|
78
|
+
});
|
|
79
|
+
test('It should not throw if height=1 is boundary on-point', () => {
|
|
80
|
+
expect(() => render(_jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 1, width: 100, id: "id" }))).not.toThrow();
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
describe('Not throw with valid width props', () => {
|
|
84
|
+
test('It should not throw if width is a positive number', () => {
|
|
85
|
+
expect(() => render(_jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100, width: 100, id: "id" }))).not.toThrow();
|
|
86
|
+
});
|
|
87
|
+
test('It should not throw if width=1 is boundary on-point', () => {
|
|
88
|
+
expect(() => render(_jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 30, height: 100, width: 1, id: "id" }))).not.toThrow();
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
test('It should not throw if durationInFrames=1 of a composition is boundary on-point', () => {
|
|
92
|
+
expect(() => render(_jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 1, fps: 30, height: 100, width: 100, id: "id" }))).not.toThrow();
|
|
93
|
+
});
|
|
94
|
+
test('It should not throw if fps=1 of a composition is boundary on-point', () => {
|
|
95
|
+
expect(() => render(_jsx(Composition, { lazyComponent: () => Promise.resolve({ default: AnyComp }), durationInFrames: 100, fps: 1, height: 100, width: 100, id: "id" }))).not.toThrow();
|
|
96
|
+
});
|
|
97
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|