@editframe/elements 0.23.8-beta.0 → 0.25.0-beta.0
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/DelayedLoadingState.js +31 -0
- package/dist/DelayedLoadingState.js.map +1 -0
- package/dist/EF_FRAMEGEN.d.ts +50 -46
- package/dist/EF_FRAMEGEN.js +5 -1
- package/dist/EF_FRAMEGEN.js.map +1 -0
- package/dist/EF_INTERACTIVE.js +4 -0
- package/dist/EF_INTERACTIVE.js.map +1 -0
- package/dist/EF_RENDERING.js +4 -0
- package/dist/EF_RENDERING.js.map +1 -0
- package/dist/_virtual/_@oxc-project_runtime@0.94.0/helpers/decorate.js +4 -1
- package/dist/attachContextRoot.js +6 -1
- package/dist/attachContextRoot.js.map +1 -0
- package/dist/elements/CrossUpdateController.js +4 -0
- package/dist/elements/CrossUpdateController.js.map +1 -0
- package/dist/elements/EFAudio.d.ts +24 -16
- package/dist/elements/EFAudio.js +10 -1
- package/dist/elements/EFAudio.js.map +1 -0
- package/dist/elements/EFCaptions.d.ts +118 -109
- package/dist/elements/EFCaptions.js +11 -6
- package/dist/elements/EFCaptions.js.map +1 -0
- package/dist/elements/EFImage.d.ts +31 -20
- package/dist/elements/EFImage.js +6 -1
- package/dist/elements/EFImage.js.map +1 -0
- package/dist/elements/EFMedia/AssetIdMediaEngine.js +5 -0
- package/dist/elements/EFMedia/AssetIdMediaEngine.js.map +1 -0
- package/dist/elements/EFMedia/AssetMediaEngine.js +12 -0
- package/dist/elements/EFMedia/AssetMediaEngine.js.map +1 -0
- package/dist/elements/EFMedia/BaseMediaEngine.js +53 -0
- package/dist/elements/EFMedia/BaseMediaEngine.js.map +1 -0
- package/dist/elements/EFMedia/BufferedSeekingInput.d.ts +47 -46
- package/dist/elements/EFMedia/BufferedSeekingInput.js +6 -1
- package/dist/elements/EFMedia/BufferedSeekingInput.js.map +1 -0
- package/dist/elements/EFMedia/JitMediaEngine.js +12 -0
- package/dist/elements/EFMedia/JitMediaEngine.js.map +1 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioBufferTask.d.ts +9 -13
- package/dist/elements/EFMedia/audioTasks/makeAudioBufferTask.js +5 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioBufferTask.js.map +1 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioFrequencyAnalysisTask.js +6 -1
- package/dist/elements/EFMedia/audioTasks/makeAudioFrequencyAnalysisTask.js.map +1 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioInitSegmentFetchTask.js +5 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioInitSegmentFetchTask.js.map +1 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioInputTask.js +5 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioInputTask.js.map +1 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioSeekTask.js +5 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioSeekTask.js.map +1 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioSegmentFetchTask.js +5 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioSegmentFetchTask.js.map +1 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioSegmentIdTask.js +5 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioSegmentIdTask.js.map +1 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioTimeDomainAnalysisTask.js +6 -1
- package/dist/elements/EFMedia/audioTasks/makeAudioTimeDomainAnalysisTask.js.map +1 -0
- package/dist/elements/EFMedia/shared/AudioSpanUtils.js +18 -2
- package/dist/elements/EFMedia/shared/AudioSpanUtils.js.map +1 -0
- package/dist/elements/EFMedia/shared/BufferUtils.d.ts +9 -67
- package/dist/elements/EFMedia/shared/BufferUtils.js +15 -0
- package/dist/elements/EFMedia/shared/BufferUtils.js.map +1 -0
- package/dist/elements/EFMedia/shared/GlobalInputCache.js +29 -0
- package/dist/elements/EFMedia/shared/GlobalInputCache.js.map +1 -0
- package/dist/elements/EFMedia/shared/MediaTaskUtils.d.ts +11 -17
- package/dist/elements/EFMedia/shared/PrecisionUtils.js +25 -0
- package/dist/elements/EFMedia/shared/PrecisionUtils.js.map +1 -0
- package/dist/elements/EFMedia/shared/ThumbnailExtractor.js +22 -0
- package/dist/elements/EFMedia/shared/ThumbnailExtractor.js.map +1 -0
- package/dist/elements/EFMedia/tasks/makeMediaEngineTask.js +13 -0
- package/dist/elements/EFMedia/tasks/makeMediaEngineTask.js.map +1 -0
- package/dist/elements/EFMedia/videoTasks/MainVideoInputCache.js +21 -0
- package/dist/elements/EFMedia/videoTasks/MainVideoInputCache.js.map +1 -0
- package/dist/elements/EFMedia/videoTasks/ScrubInputCache.js +18 -0
- package/dist/elements/EFMedia/videoTasks/ScrubInputCache.js.map +1 -0
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoBufferTask.js +10 -0
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoBufferTask.js.map +1 -0
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoInitSegmentFetchTask.js +5 -0
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoInitSegmentFetchTask.js.map +1 -0
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoInputTask.js +5 -0
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoInputTask.js.map +1 -0
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoSeekTask.js +6 -1
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoSeekTask.js.map +1 -0
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoSegmentFetchTask.js +5 -0
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoSegmentFetchTask.js.map +1 -0
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoSegmentIdTask.js +5 -0
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoSegmentIdTask.js.map +1 -0
- package/dist/elements/EFMedia/videoTasks/makeUnifiedVideoSeekTask.js +16 -2
- package/dist/elements/EFMedia/videoTasks/makeUnifiedVideoSeekTask.js.map +1 -0
- package/dist/elements/EFMedia/videoTasks/makeVideoBufferTask.d.ts +9 -13
- package/dist/elements/EFMedia/videoTasks/makeVideoBufferTask.js +5 -0
- package/dist/elements/EFMedia/videoTasks/makeVideoBufferTask.js.map +1 -0
- package/dist/elements/EFMedia.d.ts +115 -104
- package/dist/elements/EFMedia.js +25 -1
- package/dist/elements/EFMedia.js.map +1 -0
- package/dist/elements/EFSourceMixin.d.ts +10 -11
- package/dist/elements/EFSourceMixin.js +5 -0
- package/dist/elements/EFSourceMixin.js.map +1 -0
- package/dist/elements/EFSurface.d.ts +35 -27
- package/dist/elements/EFSurface.js +6 -1
- package/dist/elements/EFSurface.js.map +1 -0
- package/dist/elements/EFTemporal.d.ts +200 -213
- package/dist/elements/EFTemporal.js +24 -4
- package/dist/elements/EFTemporal.js.map +1 -0
- package/dist/elements/EFThumbnailStrip.d.ts +91 -83
- package/dist/elements/EFThumbnailStrip.js +49 -4
- package/dist/elements/EFThumbnailStrip.js.map +1 -0
- package/dist/elements/EFTimegroup.d.ts +107 -88
- package/dist/elements/EFTimegroup.js +74 -4
- package/dist/elements/EFTimegroup.js.map +1 -0
- package/dist/elements/EFVideo.d.ts +120 -108
- package/dist/elements/EFVideo.js +46 -2
- package/dist/elements/EFVideo.js.map +1 -0
- package/dist/elements/EFWaveform.d.ts +48 -41
- package/dist/elements/EFWaveform.js +6 -1
- package/dist/elements/EFWaveform.js.map +1 -0
- package/dist/elements/FetchMixin.d.ts +8 -6
- package/dist/elements/FetchMixin.js +4 -0
- package/dist/elements/FetchMixin.js.map +1 -0
- package/dist/elements/SampleBuffer.d.ts +18 -13
- package/dist/elements/SampleBuffer.js +5 -0
- package/dist/elements/SampleBuffer.js.map +1 -0
- package/dist/elements/TargetController.d.ts +23 -24
- package/dist/elements/TargetController.js +8 -3
- package/dist/elements/TargetController.js.map +1 -0
- package/dist/elements/TimegroupController.d.ts +17 -12
- package/dist/elements/TimegroupController.js +4 -0
- package/dist/elements/TimegroupController.js.map +1 -0
- package/dist/elements/durationConverter.js +9 -4
- package/dist/elements/durationConverter.js.map +1 -0
- package/dist/elements/parseTimeToMs.js +4 -0
- package/dist/elements/parseTimeToMs.js.map +1 -0
- package/dist/elements/renderTemporalAudio.js +4 -0
- package/dist/elements/renderTemporalAudio.js.map +1 -0
- package/dist/elements/updateAnimations.js +29 -8
- package/dist/elements/updateAnimations.js.map +1 -0
- package/dist/elements-ZhsB7B5N.css +9 -0
- package/dist/elements-ZhsB7B5N.css.map +1 -0
- package/dist/getRenderInfo.d.ts +53 -47
- package/dist/getRenderInfo.js +5 -0
- package/dist/getRenderInfo.js.map +1 -0
- package/dist/gui/ContextMixin.d.ts +19 -20
- package/dist/gui/ContextMixin.js +32 -1
- package/dist/gui/ContextMixin.js.map +1 -0
- package/dist/gui/Controllable.d.ts +13 -14
- package/dist/gui/Controllable.js +5 -0
- package/dist/gui/Controllable.js.map +1 -0
- package/dist/gui/EFConfiguration.d.ts +18 -14
- package/dist/gui/EFConfiguration.js +6 -1
- package/dist/gui/EFConfiguration.js.map +1 -0
- package/dist/gui/EFControls.d.ts +35 -31
- package/dist/gui/EFControls.js +8 -3
- package/dist/gui/EFControls.js.map +1 -0
- package/dist/gui/EFDial.d.ts +23 -16
- package/dist/gui/EFDial.js +6 -1
- package/dist/gui/EFDial.js.map +1 -0
- package/dist/gui/EFFilmstrip.d.ts +183 -177
- package/dist/gui/EFFilmstrip.js +30 -25
- package/dist/gui/EFFilmstrip.js.map +1 -0
- package/dist/gui/EFFitScale.d.ts +30 -24
- package/dist/gui/EFFitScale.js +6 -1
- package/dist/gui/EFFitScale.js.map +1 -0
- package/dist/gui/EFFocusOverlay.d.ts +22 -14
- package/dist/gui/EFFocusOverlay.js +6 -1
- package/dist/gui/EFFocusOverlay.js.map +1 -0
- package/dist/gui/EFPause.d.ts +24 -18
- package/dist/gui/EFPause.js +6 -1
- package/dist/gui/EFPause.js.map +1 -0
- package/dist/gui/EFPlay.d.ts +24 -18
- package/dist/gui/EFPlay.js +6 -1
- package/dist/gui/EFPlay.js.map +1 -0
- package/dist/gui/EFPreview.d.ts +22 -15
- package/dist/gui/EFPreview.js +9 -1
- package/dist/gui/EFPreview.js.map +1 -0
- package/dist/gui/EFResizableBox.d.ts +39 -32
- package/dist/gui/EFResizableBox.js +8 -3
- package/dist/gui/EFResizableBox.js.map +1 -0
- package/dist/gui/EFScrubber.d.ts +31 -25
- package/dist/gui/EFScrubber.js +6 -1
- package/dist/gui/EFScrubber.js.map +1 -0
- package/dist/gui/EFTimeDisplay.d.ts +21 -14
- package/dist/gui/EFTimeDisplay.js +6 -1
- package/dist/gui/EFTimeDisplay.js.map +1 -0
- package/dist/gui/EFToggleLoop.d.ts +19 -13
- package/dist/gui/EFToggleLoop.js +6 -1
- package/dist/gui/EFToggleLoop.js.map +1 -0
- package/dist/gui/EFTogglePlay.d.ts +23 -17
- package/dist/gui/EFTogglePlay.js +6 -1
- package/dist/gui/EFTogglePlay.js.map +1 -0
- package/dist/gui/EFWorkbench.d.ts +24 -16
- package/dist/gui/EFWorkbench.js +6 -1
- package/dist/gui/EFWorkbench.js.map +1 -0
- package/dist/gui/PlaybackController.d.ts +54 -50
- package/dist/gui/PlaybackController.js +23 -1
- package/dist/gui/PlaybackController.js.map +1 -0
- package/dist/gui/TWMixin.js +5 -1
- package/dist/gui/TWMixin.js.map +1 -0
- package/dist/gui/TWMixin2.js +6 -1
- package/dist/gui/TWMixin2.js.map +1 -0
- package/dist/gui/TargetOrContextMixin.js +5 -0
- package/dist/gui/TargetOrContextMixin.js.map +1 -0
- package/dist/gui/currentTimeContext.js +5 -0
- package/dist/gui/currentTimeContext.js.map +1 -0
- package/dist/gui/durationContext.js +5 -0
- package/dist/gui/durationContext.js.map +1 -0
- package/dist/gui/efContext.js +5 -0
- package/dist/gui/efContext.js.map +1 -0
- package/dist/gui/fetchContext.js +5 -0
- package/dist/gui/fetchContext.js.map +1 -0
- package/dist/gui/focusContext.d.ts +6 -5
- package/dist/gui/focusContext.js +5 -0
- package/dist/gui/focusContext.js.map +1 -0
- package/dist/gui/focusedElementContext.js +5 -0
- package/dist/gui/focusedElementContext.js.map +1 -0
- package/dist/gui/playingContext.js +5 -0
- package/dist/gui/playingContext.js.map +1 -0
- package/dist/index.d.ts +27 -26
- package/dist/index.js +6 -1
- package/dist/index.js.map +1 -0
- package/dist/msToTimeCode.js +4 -0
- package/dist/msToTimeCode.js.map +1 -0
- package/dist/otel/BridgeSpanExporter.js +5 -0
- package/dist/otel/BridgeSpanExporter.js.map +1 -0
- package/dist/otel/setupBrowserTracing.js +7 -2
- package/dist/otel/setupBrowserTracing.js.map +1 -0
- package/dist/otel/tracingHelpers.d.ts +7 -34
- package/dist/otel/tracingHelpers.js +34 -2
- package/dist/otel/tracingHelpers.js.map +1 -0
- package/dist/transcoding/cache/RequestDeduplicator.js +25 -0
- package/dist/transcoding/cache/RequestDeduplicator.js.map +1 -0
- package/dist/transcoding/cache/URLTokenDeduplicator.js +23 -0
- package/dist/transcoding/cache/URLTokenDeduplicator.js.map +1 -0
- package/dist/transcoding/types/index.d.ts +96 -270
- package/dist/transcoding/utils/UrlGenerator.d.ts +30 -25
- package/dist/transcoding/utils/UrlGenerator.js +19 -0
- package/dist/transcoding/utils/UrlGenerator.js.map +1 -0
- package/dist/utils/LRUCache.js +44 -0
- package/dist/utils/LRUCache.js.map +1 -0
- package/package.json +11 -24
- package/src/elements/EFCaptions.browsertest.ts +7 -7
- package/src/elements/EFTimegroup.ts +43 -1
- package/src/gui/PlaybackController.ts +6 -1
- package/tsdown.config.ts +36 -0
- package/types.json +1 -1
- package/dist/DelayedLoadingState.d.ts +0 -48
- package/dist/DelayedLoadingState.integration.test.d.ts +0 -1
- package/dist/DelayedLoadingState.test.d.ts +0 -1
- package/dist/EF_INTERACTIVE.d.ts +0 -1
- package/dist/EF_RENDERING.d.ts +0 -1
- package/dist/LoadingDebounce.test.d.ts +0 -1
- package/dist/ManualScrubTest.test.d.ts +0 -1
- package/dist/ScrubResolvedFlashing.test.d.ts +0 -1
- package/dist/ScrubTrackManager.test.d.ts +0 -1
- package/dist/VideoSeekFlashing.browsertest.d.ts +0 -0
- package/dist/VideoStuckDiagnostic.test.d.ts +0 -1
- package/dist/attachContextRoot.d.ts +0 -1
- package/dist/elements/ContextProxiesController.d.ts +0 -39
- package/dist/elements/CrossUpdateController.d.ts +0 -8
- package/dist/elements/EFAudio.browsertest.d.ts +0 -0
- package/dist/elements/EFCaptions.browsertest.d.ts +0 -0
- package/dist/elements/EFImage.browsertest.d.ts +0 -0
- package/dist/elements/EFMedia/AssetIdMediaEngine.d.ts +0 -19
- package/dist/elements/EFMedia/AssetIdMediaEngine.test.d.ts +0 -1
- package/dist/elements/EFMedia/AssetMediaEngine.browsertest.d.ts +0 -0
- package/dist/elements/EFMedia/AssetMediaEngine.d.ts +0 -56
- package/dist/elements/EFMedia/BaseMediaEngine.browsertest.d.ts +0 -1
- package/dist/elements/EFMedia/BaseMediaEngine.d.ts +0 -103
- package/dist/elements/EFMedia/BufferedSeekingInput.browsertest.d.ts +0 -1
- package/dist/elements/EFMedia/JitMediaEngine.browsertest.d.ts +0 -0
- package/dist/elements/EFMedia/JitMediaEngine.d.ts +0 -46
- package/dist/elements/EFMedia/audioTasks/makeAudioBufferTask.browsertest.d.ts +0 -9
- package/dist/elements/EFMedia/audioTasks/makeAudioFrequencyAnalysisTask.d.ts +0 -3
- package/dist/elements/EFMedia/audioTasks/makeAudioInitSegmentFetchTask.browsertest.d.ts +0 -9
- package/dist/elements/EFMedia/audioTasks/makeAudioInitSegmentFetchTask.d.ts +0 -4
- package/dist/elements/EFMedia/audioTasks/makeAudioInputTask.browsertest.d.ts +0 -9
- package/dist/elements/EFMedia/audioTasks/makeAudioInputTask.d.ts +0 -3
- package/dist/elements/EFMedia/audioTasks/makeAudioSeekTask.chunkboundary.regression.browsertest.d.ts +0 -0
- package/dist/elements/EFMedia/audioTasks/makeAudioSeekTask.d.ts +0 -7
- package/dist/elements/EFMedia/audioTasks/makeAudioSegmentFetchTask.d.ts +0 -4
- package/dist/elements/EFMedia/audioTasks/makeAudioSegmentIdTask.d.ts +0 -4
- package/dist/elements/EFMedia/audioTasks/makeAudioTasksVideoOnly.browsertest.d.ts +0 -1
- package/dist/elements/EFMedia/audioTasks/makeAudioTimeDomainAnalysisTask.d.ts +0 -3
- package/dist/elements/EFMedia/shared/AudioSpanUtils.d.ts +0 -7
- package/dist/elements/EFMedia/shared/GlobalInputCache.d.ts +0 -39
- package/dist/elements/EFMedia/shared/PrecisionUtils.d.ts +0 -28
- package/dist/elements/EFMedia/shared/RenditionHelpers.browsertest.d.ts +0 -1
- package/dist/elements/EFMedia/shared/RenditionHelpers.d.ts +0 -11
- package/dist/elements/EFMedia/shared/ThumbnailExtractor.d.ts +0 -27
- package/dist/elements/EFMedia/tasks/makeMediaEngineTask.browsertest.d.ts +0 -9
- package/dist/elements/EFMedia/tasks/makeMediaEngineTask.d.ts +0 -17
- package/dist/elements/EFMedia/videoTasks/MainVideoInputCache.d.ts +0 -29
- package/dist/elements/EFMedia/videoTasks/ScrubInputCache.d.ts +0 -25
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoBufferTask.d.ts +0 -8
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoInitSegmentFetchTask.d.ts +0 -4
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoInputTask.d.ts +0 -3
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoSeekTask.d.ts +0 -6
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoSegmentFetchTask.d.ts +0 -4
- package/dist/elements/EFMedia/videoTasks/makeScrubVideoSegmentIdTask.d.ts +0 -4
- package/dist/elements/EFMedia/videoTasks/makeUnifiedVideoSeekTask.d.ts +0 -6
- package/dist/elements/EFMedia.browsertest.d.ts +0 -10
- package/dist/elements/EFSurface.browsertest.d.ts +0 -0
- package/dist/elements/EFTemporal.browsertest.d.ts +0 -22
- package/dist/elements/EFThumbnailStrip.browsertest.d.ts +0 -0
- package/dist/elements/EFThumbnailStrip.media-engine.browsertest.d.ts +0 -0
- package/dist/elements/EFTimegroup.browsertest.d.ts +0 -41
- package/dist/elements/EFVideo.browsertest.d.ts +0 -0
- package/dist/elements/FetchContext.browsertest.d.ts +0 -0
- package/dist/elements/TargetController.browsertest.d.ts +0 -19
- package/dist/elements/durationConverter.d.ts +0 -16
- package/dist/elements/parseTimeToMs.d.ts +0 -1
- package/dist/elements/printTaskStatus.d.ts +0 -2
- package/dist/elements/renderTemporalAudio.d.ts +0 -10
- package/dist/elements/updateAnimations.browsertest.d.ts +0 -13
- package/dist/elements/updateAnimations.d.ts +0 -24
- package/dist/elements/util.d.ts +0 -3
- package/dist/gui/ContextMixin.browsertest.d.ts +0 -15
- package/dist/gui/Controllable.browsertest.d.ts +0 -0
- package/dist/gui/EFControls.browsertest.d.ts +0 -11
- package/dist/gui/EFDial.browsertest.d.ts +0 -0
- package/dist/gui/EFFilmstrip.browsertest.d.ts +0 -11
- package/dist/gui/EFPause.browsertest.d.ts +0 -0
- package/dist/gui/EFPlay.browsertest.d.ts +0 -0
- package/dist/gui/EFResizableBox.browsertest.d.ts +0 -0
- package/dist/gui/EFTimeDisplay.browsertest.d.ts +0 -0
- package/dist/gui/TWMixin.d.ts +0 -2
- package/dist/gui/TargetOrContextMixin.d.ts +0 -10
- package/dist/gui/currentTimeContext.d.ts +0 -3
- package/dist/gui/durationContext.d.ts +0 -3
- package/dist/gui/efContext.d.ts +0 -4
- package/dist/gui/fetchContext.d.ts +0 -3
- package/dist/gui/focusedElementContext.d.ts +0 -3
- package/dist/gui/playingContext.d.ts +0 -6
- package/dist/msToTimeCode.d.ts +0 -1
- package/dist/otel/BridgeSpanExporter.d.ts +0 -13
- package/dist/otel/setupBrowserTracing.d.ts +0 -12
- package/dist/style.css +0 -2
- package/dist/transcoding/cache/RequestDeduplicator.d.ts +0 -29
- package/dist/transcoding/cache/RequestDeduplicator.test.d.ts +0 -1
- package/dist/transcoding/cache/URLTokenDeduplicator.d.ts +0 -38
- package/dist/transcoding/cache/URLTokenDeduplicator.test.d.ts +0 -1
- package/dist/transcoding/utils/MediaUtils.d.ts +0 -9
- package/dist/transcoding/utils/constants.d.ts +0 -27
- package/dist/utils/LRUCache.d.ts +0 -80
- package/dist/utils/LRUCache.test.d.ts +0 -1
- /package/dist/{LoadingIndicator.browsertest.d.ts → elements.js} +0 -0
package/dist/utils/LRUCache.js
CHANGED
|
@@ -1,3 +1,7 @@
|
|
|
1
|
+
//#region src/utils/LRUCache.ts
|
|
2
|
+
/**
|
|
3
|
+
* A simple LRU (Least Recently Used) cache implementation
|
|
4
|
+
*/
|
|
1
5
|
var LRUCache = class {
|
|
2
6
|
constructor(maxSize) {
|
|
3
7
|
this.cache = /* @__PURE__ */ new Map();
|
|
@@ -32,6 +36,10 @@ var LRUCache = class {
|
|
|
32
36
|
return this.cache.size;
|
|
33
37
|
}
|
|
34
38
|
};
|
|
39
|
+
/**
|
|
40
|
+
* Size-aware LRU cache that tracks memory usage in bytes
|
|
41
|
+
* Evicts entries when total size exceeds the maximum
|
|
42
|
+
*/
|
|
35
43
|
var SizeAwareLRUCache = class {
|
|
36
44
|
constructor(maxSizeBytes) {
|
|
37
45
|
this.cache = /* @__PURE__ */ new Map();
|
|
@@ -105,11 +113,17 @@ var SizeAwareLRUCache = class {
|
|
|
105
113
|
return this.maxSizeBytes;
|
|
106
114
|
}
|
|
107
115
|
};
|
|
116
|
+
/**
|
|
117
|
+
* Red-Black Tree node colors
|
|
118
|
+
*/
|
|
108
119
|
var Color = /* @__PURE__ */ function(Color$1) {
|
|
109
120
|
Color$1["RED"] = "RED";
|
|
110
121
|
Color$1["BLACK"] = "BLACK";
|
|
111
122
|
return Color$1;
|
|
112
123
|
}(Color || {});
|
|
124
|
+
/**
|
|
125
|
+
* Red-Black Tree node for ordered key storage
|
|
126
|
+
*/
|
|
113
127
|
var RBTreeNode = class {
|
|
114
128
|
constructor(key, color = Color.RED, left = null, right = null, parent = null) {
|
|
115
129
|
this.key = key;
|
|
@@ -119,6 +133,10 @@ var RBTreeNode = class {
|
|
|
119
133
|
this.parent = parent;
|
|
120
134
|
}
|
|
121
135
|
};
|
|
136
|
+
/**
|
|
137
|
+
* Red-Black Tree implementation for O(log n) operations
|
|
138
|
+
* Supports insert, delete, search, range queries, and nearest neighbor
|
|
139
|
+
*/
|
|
122
140
|
var RedBlackTree = class {
|
|
123
141
|
constructor(compareFn) {
|
|
124
142
|
this.root = null;
|
|
@@ -371,6 +389,10 @@ var RedBlackTree = class {
|
|
|
371
389
|
if (endCmp < 0) this.inorderRange(node.right, start, end, result);
|
|
372
390
|
}
|
|
373
391
|
};
|
|
392
|
+
/**
|
|
393
|
+
* LRU cache with binary search capabilities using Red-Black tree
|
|
394
|
+
* All operations are O(log n) for ordered queries and O(1) for LRU operations
|
|
395
|
+
*/
|
|
374
396
|
var OrderedLRUCache = class {
|
|
375
397
|
constructor(maxSize, compareFn) {
|
|
376
398
|
this.cache = /* @__PURE__ */ new Map();
|
|
@@ -378,6 +400,9 @@ var OrderedLRUCache = class {
|
|
|
378
400
|
this.compareFn = compareFn || ((a, b) => a < b ? -1 : a > b ? 1 : 0);
|
|
379
401
|
this.tree = new RedBlackTree(this.compareFn);
|
|
380
402
|
}
|
|
403
|
+
/**
|
|
404
|
+
* Get value by exact key (O(1))
|
|
405
|
+
*/
|
|
381
406
|
get(key) {
|
|
382
407
|
const value = this.cache.get(key);
|
|
383
408
|
if (value) {
|
|
@@ -386,6 +411,9 @@ var OrderedLRUCache = class {
|
|
|
386
411
|
}
|
|
387
412
|
return value;
|
|
388
413
|
}
|
|
414
|
+
/**
|
|
415
|
+
* Set key-value pair (O(log n) for tree operations, O(1) for cache)
|
|
416
|
+
*/
|
|
389
417
|
set(key, value) {
|
|
390
418
|
if (this.cache.has(key)) this.cache.delete(key);
|
|
391
419
|
else {
|
|
@@ -400,9 +428,16 @@ var OrderedLRUCache = class {
|
|
|
400
428
|
}
|
|
401
429
|
this.cache.set(key, value);
|
|
402
430
|
}
|
|
431
|
+
/**
|
|
432
|
+
* Find exact key using tree search (O(log n))
|
|
433
|
+
*/
|
|
403
434
|
findExact(key) {
|
|
404
435
|
if (this.tree.find(key) !== null) return this.get(key);
|
|
405
436
|
}
|
|
437
|
+
/**
|
|
438
|
+
* Find keys within distance of center point (O(log n + k) where k is result count)
|
|
439
|
+
* Returns empty array if no keys found in range
|
|
440
|
+
*/
|
|
406
441
|
findNearestInRange(center, distance) {
|
|
407
442
|
const nearestKeys = this.tree.findNearestInRange(center, distance);
|
|
408
443
|
const result = [];
|
|
@@ -415,6 +450,9 @@ var OrderedLRUCache = class {
|
|
|
415
450
|
}
|
|
416
451
|
return result;
|
|
417
452
|
}
|
|
453
|
+
/**
|
|
454
|
+
* Find all key-value pairs in range [start, end] (O(log n + k) where k is result count)
|
|
455
|
+
*/
|
|
418
456
|
findRange(start, end) {
|
|
419
457
|
const keys = this.tree.findRange(start, end);
|
|
420
458
|
const result = [];
|
|
@@ -427,6 +465,9 @@ var OrderedLRUCache = class {
|
|
|
427
465
|
}
|
|
428
466
|
return result;
|
|
429
467
|
}
|
|
468
|
+
/**
|
|
469
|
+
* Get all keys in sorted order (O(n))
|
|
470
|
+
*/
|
|
430
471
|
getSortedKeys() {
|
|
431
472
|
return this.tree.getAllSorted();
|
|
432
473
|
}
|
|
@@ -446,4 +487,7 @@ var OrderedLRUCache = class {
|
|
|
446
487
|
return this.cache.size;
|
|
447
488
|
}
|
|
448
489
|
};
|
|
490
|
+
|
|
491
|
+
//#endregion
|
|
449
492
|
export { LRUCache, OrderedLRUCache, SizeAwareLRUCache };
|
|
493
|
+
//# sourceMappingURL=LRUCache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LRUCache.js","names":["key: K","color: Color","left: RBTreeNode<K> | null","right: RBTreeNode<K> | null","parent: RBTreeNode<K> | null","result: K[]","x: RBTreeNode<K> | null","result: Array<{ key: K; value: V }>"],"sources":["../../src/utils/LRUCache.ts"],"sourcesContent":["/**\n * A simple LRU (Least Recently Used) cache implementation\n */\nexport class LRUCache<K, V> {\n private cache = new Map<K, V>();\n private readonly maxSize: number;\n\n constructor(maxSize: number) {\n this.maxSize = maxSize;\n }\n\n get(key: K): V | undefined {\n const value = this.cache.get(key);\n if (value) {\n // Refresh position by removing and re-adding\n this.cache.delete(key);\n this.cache.set(key, value);\n }\n return value;\n }\n\n set(key: K, value: V): void {\n if (this.cache.has(key)) {\n this.cache.delete(key);\n } else if (this.cache.size >= this.maxSize) {\n // Remove oldest entry (first item in map)\n const firstKey = this.cache.keys().next().value;\n if (firstKey) {\n this.cache.delete(firstKey);\n }\n }\n this.cache.set(key, value);\n }\n\n has(key: K): boolean {\n return this.cache.has(key);\n }\n\n delete(key: K): boolean {\n return this.cache.delete(key);\n }\n\n clear(): void {\n this.cache.clear();\n }\n\n get size(): number {\n return this.cache.size;\n }\n}\n\n/**\n * Size-aware LRU cache that tracks memory usage in bytes\n * Evicts entries when total size exceeds the maximum\n */\nexport class SizeAwareLRUCache<K> {\n private cache = new Map<K, Promise<ArrayBuffer>>();\n private sizes = new Map<K, number>();\n private currentSize = 0;\n private readonly maxSizeBytes: number;\n\n constructor(maxSizeBytes: number) {\n this.maxSizeBytes = maxSizeBytes;\n }\n\n get(key: K): Promise<ArrayBuffer> | undefined {\n const value = this.cache.get(key);\n if (value) {\n // Refresh position by removing and re-adding\n const size = this.sizes.get(key) || 0;\n this.cache.delete(key);\n this.cache.set(key, value);\n this.sizes.delete(key);\n this.sizes.set(key, size);\n }\n return value;\n }\n\n set(key: K, value: Promise<ArrayBuffer>): void {\n // If key already exists, remove it first\n if (this.cache.has(key)) {\n const oldSize = this.sizes.get(key) || 0;\n this.currentSize -= oldSize;\n this.cache.delete(key);\n this.sizes.delete(key);\n }\n\n // Track the size when the promise resolves\n const sizeTrackingPromise = value\n .then((buffer) => {\n const bufferSize = buffer.byteLength;\n this.sizes.set(key, bufferSize);\n this.currentSize += bufferSize;\n\n // Evict oldest entries if we exceed the size limit\n this.evictIfNecessary();\n\n return buffer;\n })\n .catch((error) => {\n // If the promise fails, clean up the entry\n this.cache.delete(key);\n this.sizes.delete(key);\n throw error;\n });\n\n this.cache.set(key, sizeTrackingPromise);\n }\n\n private evictIfNecessary(): void {\n while (this.currentSize > this.maxSizeBytes && this.cache.size > 0) {\n // Remove oldest entry (first item in map)\n const firstKey = this.cache.keys().next().value;\n if (firstKey) {\n const size = this.sizes.get(firstKey) || 0;\n this.currentSize -= size;\n this.cache.delete(firstKey);\n this.sizes.delete(firstKey);\n } else {\n break;\n }\n }\n }\n\n has(key: K): boolean {\n return this.cache.has(key);\n }\n\n delete(key: K): boolean {\n const size = this.sizes.get(key) || 0;\n this.currentSize -= size;\n this.sizes.delete(key);\n return this.cache.delete(key);\n }\n\n clear(): void {\n this.cache.clear();\n this.sizes.clear();\n this.currentSize = 0;\n }\n\n get size(): number {\n return this.cache.size;\n }\n\n get currentSizeBytes(): number {\n return this.currentSize;\n }\n\n get maxSize(): number {\n return this.maxSizeBytes;\n }\n}\n\n/**\n * Red-Black Tree node colors\n */\nenum Color {\n RED = \"RED\",\n BLACK = \"BLACK\",\n}\n\n/**\n * Red-Black Tree node for ordered key storage\n */\nclass RBTreeNode<K> {\n constructor(\n public key: K,\n public color: Color = Color.RED,\n public left: RBTreeNode<K> | null = null,\n public right: RBTreeNode<K> | null = null,\n public parent: RBTreeNode<K> | null = null,\n ) {}\n}\n\n/**\n * Red-Black Tree implementation for O(log n) operations\n * Supports insert, delete, search, range queries, and nearest neighbor\n */\nclass RedBlackTree<K> {\n private root: RBTreeNode<K> | null = null;\n private readonly compareFn: (a: K, b: K) => number;\n\n constructor(compareFn: (a: K, b: K) => number) {\n this.compareFn = compareFn;\n }\n\n insert(key: K): void {\n const node = new RBTreeNode(key);\n\n if (!this.root) {\n this.root = node;\n node.color = Color.BLACK;\n return;\n }\n\n this.insertNode(node);\n this.fixInsert(node);\n }\n\n delete(key: K): boolean {\n const node = this.findNode(key);\n if (!node) return false;\n\n this.deleteNode(node);\n return true;\n }\n\n find(key: K): K | null {\n const node = this.findNode(key);\n return node ? node.key : null;\n }\n\n findNearestInRange(center: K, distance: K): K[] {\n // Calculate the range bounds\n const start = this.subtractDistance(center, distance);\n const end = this.addDistance(center, distance);\n\n // Use existing range search (O(log n + k))\n return this.findRange(start, end);\n }\n\n private subtractDistance(center: K, distance: K): K {\n if (typeof center === \"number\" && typeof distance === \"number\") {\n return (center - distance) as K;\n }\n\n // For strings, we can't easily subtract distance, so just return center\n // This means string searches will be exact matches only\n return center;\n }\n\n private addDistance(center: K, distance: K): K {\n if (typeof center === \"number\" && typeof distance === \"number\") {\n return (center + distance) as K;\n }\n\n // For strings, we can't easily add distance, so just return center\n // This means string searches will be exact matches only\n return center;\n }\n\n findRange(start: K, end: K): K[] {\n const result: K[] = [];\n this.inorderRange(this.root, start, end, result);\n return result;\n }\n\n getAllSorted(): K[] {\n const result: K[] = [];\n this.inorder(this.root, result);\n return result;\n }\n\n private findNode(key: K): RBTreeNode<K> | null {\n let current = this.root;\n\n while (current) {\n const cmp = this.compareFn(key, current.key);\n if (cmp === 0) return current;\n current = cmp < 0 ? current.left : current.right;\n }\n\n return null;\n }\n\n private insertNode(node: RBTreeNode<K>): void {\n let parent = null;\n let current = this.root;\n\n while (current) {\n parent = current;\n const cmp = this.compareFn(node.key, current.key);\n current = cmp < 0 ? current.left : current.right;\n }\n\n node.parent = parent;\n if (!parent) {\n this.root = node;\n } else {\n const cmp = this.compareFn(node.key, parent.key);\n if (cmp < 0) {\n parent.left = node;\n } else {\n parent.right = node;\n }\n }\n }\n\n private fixInsert(node: RBTreeNode<K>): void {\n while (node.parent && node.parent.color === Color.RED) {\n if (node.parent === node.parent.parent?.left) {\n const uncle = node.parent.parent.right;\n\n if (uncle?.color === Color.RED) {\n node.parent.color = Color.BLACK;\n uncle.color = Color.BLACK;\n node.parent.parent.color = Color.RED;\n node = node.parent.parent;\n } else {\n if (node === node.parent.right) {\n node = node.parent;\n this.rotateLeft(node);\n }\n\n if (node.parent) {\n node.parent.color = Color.BLACK;\n if (node.parent.parent) {\n node.parent.parent.color = Color.RED;\n this.rotateRight(node.parent.parent);\n }\n }\n }\n } else {\n const uncle = node.parent.parent?.left;\n\n if (uncle?.color === Color.RED) {\n node.parent.color = Color.BLACK;\n uncle.color = Color.BLACK;\n if (node.parent.parent) {\n node.parent.parent.color = Color.RED;\n node = node.parent.parent;\n }\n } else {\n if (node === node.parent.left) {\n node = node.parent;\n this.rotateRight(node);\n }\n\n if (node.parent) {\n node.parent.color = Color.BLACK;\n if (node.parent.parent) {\n node.parent.parent.color = Color.RED;\n this.rotateLeft(node.parent.parent);\n }\n }\n }\n }\n }\n\n if (this.root) {\n this.root.color = Color.BLACK;\n }\n }\n\n private deleteNode(node: RBTreeNode<K>): void {\n let y = node;\n let yOriginalColor = y.color;\n let x: RBTreeNode<K> | null;\n\n if (!node.left) {\n x = node.right;\n this.transplant(node, node.right);\n } else if (!node.right) {\n x = node.left;\n this.transplant(node, node.left);\n } else {\n y = this.minimum(node.right);\n yOriginalColor = y.color;\n x = y.right;\n\n if (y.parent === node) {\n if (x) x.parent = y;\n } else {\n this.transplant(y, y.right);\n y.right = node.right;\n if (y.right) y.right.parent = y;\n }\n\n this.transplant(node, y);\n y.left = node.left;\n if (y.left) y.left.parent = y;\n y.color = node.color;\n }\n\n if (yOriginalColor === Color.BLACK && x) {\n this.fixDelete(x);\n }\n }\n\n private fixDelete(node: RBTreeNode<K>): void {\n while (node !== this.root && node.color === Color.BLACK) {\n if (node === node.parent?.left) {\n let sibling = node.parent.right;\n\n if (sibling?.color === Color.RED) {\n sibling.color = Color.BLACK;\n node.parent.color = Color.RED;\n this.rotateLeft(node.parent);\n sibling = node.parent.right;\n }\n\n if (\n sibling?.left?.color !== Color.RED &&\n sibling?.right?.color !== Color.RED\n ) {\n if (sibling) {\n sibling.color = Color.RED;\n }\n node = node.parent;\n } else {\n if (sibling?.right?.color !== Color.RED) {\n if (sibling.left) sibling.left.color = Color.BLACK;\n sibling.color = Color.RED;\n this.rotateRight(sibling);\n sibling = node.parent.right;\n }\n\n if (sibling) {\n sibling.color = node.parent.color;\n node.parent.color = Color.BLACK;\n if (sibling.right) sibling.right.color = Color.BLACK;\n this.rotateLeft(node.parent);\n }\n if (!this.root) {\n throw new Error(\"Root is null\");\n }\n node = this.root;\n }\n } else {\n let sibling = node.parent?.left;\n\n if (sibling?.color === Color.RED) {\n sibling.color = Color.BLACK;\n if (node.parent) node.parent.color = Color.RED;\n if (node.parent) this.rotateRight(node.parent);\n sibling = node.parent?.left;\n }\n\n if (\n sibling?.right?.color !== Color.RED &&\n sibling?.left?.color !== Color.RED\n ) {\n if (sibling) {\n sibling.color = Color.RED;\n }\n if (node.parent === null) {\n throw new Error(\"Node parent is null\");\n }\n node = node.parent;\n } else {\n if (sibling?.left?.color !== Color.RED) {\n if (sibling.right) sibling.right.color = Color.BLACK;\n sibling.color = Color.RED;\n this.rotateLeft(sibling);\n sibling = node.parent?.left;\n }\n\n if (sibling) {\n sibling.color = node.parent?.color || Color.BLACK;\n if (node.parent) node.parent.color = Color.BLACK;\n if (sibling.left) sibling.left.color = Color.BLACK;\n if (node.parent) this.rotateRight(node.parent);\n }\n if (!this.root) {\n throw new Error(\"Root is null\");\n }\n node = this.root;\n }\n }\n }\n\n node.color = Color.BLACK;\n }\n\n private rotateLeft(node: RBTreeNode<K>): void {\n const rightChild = node.right;\n if (!rightChild) {\n throw new Error(\"Right child is null\");\n }\n node.right = rightChild.left;\n\n if (rightChild.left) {\n rightChild.left.parent = node;\n }\n\n rightChild.parent = node.parent;\n\n if (!node.parent) {\n this.root = rightChild;\n } else if (node === node.parent.left) {\n node.parent.left = rightChild;\n } else {\n node.parent.right = rightChild;\n }\n\n rightChild.left = node;\n node.parent = rightChild;\n }\n\n private rotateRight(node: RBTreeNode<K>): void {\n const leftChild = node.left;\n if (!leftChild) {\n throw new Error(\"Left child is null\");\n }\n node.left = leftChild.right;\n\n if (leftChild.right) {\n leftChild.right.parent = node;\n }\n\n leftChild.parent = node.parent;\n\n if (!node.parent) {\n this.root = leftChild;\n } else if (node === node.parent.right) {\n node.parent.right = leftChild;\n } else {\n node.parent.left = leftChild;\n }\n\n leftChild.right = node;\n node.parent = leftChild;\n }\n\n private transplant(u: RBTreeNode<K>, v: RBTreeNode<K> | null): void {\n if (!u.parent) {\n this.root = v;\n } else if (u === u.parent.left) {\n u.parent.left = v;\n } else {\n u.parent.right = v;\n }\n\n if (v) {\n v.parent = u.parent;\n }\n }\n\n private minimum(node: RBTreeNode<K>): RBTreeNode<K> {\n while (node.left) {\n node = node.left;\n }\n return node;\n }\n\n private inorder(node: RBTreeNode<K> | null, result: K[]): void {\n if (node) {\n this.inorder(node.left, result);\n result.push(node.key);\n this.inorder(node.right, result);\n }\n }\n\n private inorderRange(\n node: RBTreeNode<K> | null,\n start: K,\n end: K,\n result: K[],\n ): void {\n if (!node) return;\n\n const startCmp = this.compareFn(node.key, start);\n const endCmp = this.compareFn(node.key, end);\n\n if (startCmp > 0) {\n this.inorderRange(node.left, start, end, result);\n }\n\n if (startCmp >= 0 && endCmp <= 0) {\n result.push(node.key);\n }\n\n if (endCmp < 0) {\n this.inorderRange(node.right, start, end, result);\n }\n }\n}\n\n/**\n * LRU cache with binary search capabilities using Red-Black tree\n * All operations are O(log n) for ordered queries and O(1) for LRU operations\n */\nexport class OrderedLRUCache<K extends number | string, V> {\n private cache = new Map<K, V>();\n private tree: RedBlackTree<K>;\n private readonly maxSize: number;\n private readonly compareFn: (a: K, b: K) => number;\n\n constructor(maxSize: number, compareFn?: (a: K, b: K) => number) {\n this.maxSize = maxSize;\n this.compareFn = compareFn || ((a, b) => (a < b ? -1 : a > b ? 1 : 0));\n this.tree = new RedBlackTree(this.compareFn);\n }\n\n /**\n * Get value by exact key (O(1))\n */\n get(key: K): V | undefined {\n const value = this.cache.get(key);\n if (value) {\n // Refresh position by removing and re-adding\n this.cache.delete(key);\n this.cache.set(key, value);\n }\n return value;\n }\n\n /**\n * Set key-value pair (O(log n) for tree operations, O(1) for cache)\n */\n set(key: K, value: V): void {\n const isUpdate = this.cache.has(key);\n\n if (isUpdate) {\n this.cache.delete(key);\n } else {\n if (this.cache.size >= this.maxSize) {\n // Remove oldest entry (first item in map)\n const firstKey = this.cache.keys().next().value;\n if (firstKey) {\n this.cache.delete(firstKey);\n this.tree.delete(firstKey);\n }\n }\n // Add to tree index for new keys\n this.tree.insert(key);\n }\n\n this.cache.set(key, value);\n }\n\n /**\n * Find exact key using tree search (O(log n))\n */\n findExact(key: K): V | undefined {\n const foundKey = this.tree.find(key);\n if (foundKey !== null) {\n return this.get(key);\n }\n return undefined;\n }\n\n /**\n * Find keys within distance of center point (O(log n + k) where k is result count)\n * Returns empty array if no keys found in range\n */\n findNearestInRange(center: K, distance: K): Array<{ key: K; value: V }> {\n const nearestKeys = this.tree.findNearestInRange(center, distance);\n const result: Array<{ key: K; value: V }> = [];\n\n for (const key of nearestKeys) {\n const value = this.get(key);\n if (value !== undefined) {\n result.push({ key, value });\n }\n }\n\n return result;\n }\n\n /**\n * Find all key-value pairs in range [start, end] (O(log n + k) where k is result count)\n */\n findRange(start: K, end: K): Array<{ key: K; value: V }> {\n const keys = this.tree.findRange(start, end);\n const result: Array<{ key: K; value: V }> = [];\n\n for (const key of keys) {\n const value = this.get(key);\n if (value !== undefined) {\n result.push({ key, value });\n }\n }\n\n return result;\n }\n\n /**\n * Get all keys in sorted order (O(n))\n */\n getSortedKeys(): ReadonlyArray<K> {\n return this.tree.getAllSorted();\n }\n\n has(key: K): boolean {\n return this.cache.has(key);\n }\n\n delete(key: K): boolean {\n const deleted = this.cache.delete(key);\n if (deleted) {\n this.tree.delete(key);\n }\n return deleted;\n }\n\n clear(): void {\n this.cache.clear();\n this.tree = new RedBlackTree(this.compareFn);\n }\n\n get size(): number {\n return this.cache.size;\n }\n}\n"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,57 +1,44 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@editframe/elements",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.25.0-beta.0",
|
|
4
4
|
"description": "",
|
|
5
5
|
"exports": {
|
|
6
|
-
".":
|
|
7
|
-
|
|
8
|
-
"types": "./dist/index.d.ts",
|
|
9
|
-
"default": "./dist/index.js"
|
|
10
|
-
}
|
|
11
|
-
},
|
|
12
|
-
"./styles.css": "./dist/style.css",
|
|
13
|
-
"./types.json": {
|
|
14
|
-
"import": {
|
|
15
|
-
"default": "./types.json"
|
|
16
|
-
}
|
|
17
|
-
}
|
|
6
|
+
".": "./dist/index.js",
|
|
7
|
+
"./package.json": "./package.json"
|
|
18
8
|
},
|
|
19
9
|
"type": "module",
|
|
20
10
|
"scripts": {
|
|
21
11
|
"typecheck": "tsc --noEmit --emitDeclarationOnly false",
|
|
22
|
-
"build": "
|
|
23
|
-
"build:watch": "
|
|
12
|
+
"build": "tsdown",
|
|
13
|
+
"build:watch": "tsdown --watch",
|
|
24
14
|
"typedoc": "typedoc --json ./types.json --plugin typedoc-plugin-zod --excludeExternals ./src && jq -c . ./types.json > ./types.tmp.json && mv ./types.tmp.json ./types.json"
|
|
25
15
|
},
|
|
26
16
|
"author": "",
|
|
27
17
|
"license": "UNLICENSED",
|
|
28
18
|
"dependencies": {
|
|
29
19
|
"@bramus/style-observer": "^1.3.0",
|
|
30
|
-
"@editframe/assets": "0.
|
|
20
|
+
"@editframe/assets": "0.25.0-beta.0",
|
|
31
21
|
"@lit/context": "^1.1.6",
|
|
32
22
|
"@lit/task": "^1.0.3",
|
|
33
23
|
"@opentelemetry/api": "^1.9.0",
|
|
34
24
|
"@opentelemetry/context-zone": "^1.26.0",
|
|
35
25
|
"@opentelemetry/core": "^1.26.0",
|
|
36
|
-
"@opentelemetry/exporter-trace-otlp-http": "^0.53.0",
|
|
37
26
|
"@opentelemetry/resources": "^1.26.0",
|
|
38
27
|
"@opentelemetry/sdk-trace-base": "^1.26.0",
|
|
39
28
|
"@opentelemetry/sdk-trace-web": "^1.26.0",
|
|
40
29
|
"@opentelemetry/semantic-conventions": "^1.37.0",
|
|
41
|
-
"d3": "^7.9.0",
|
|
42
30
|
"debug": "^4.3.5",
|
|
43
31
|
"lit": "^3.3.1",
|
|
44
32
|
"mediabunny": "^1.1.1",
|
|
45
33
|
"zod": "^3.24.1"
|
|
46
34
|
},
|
|
47
35
|
"devDependencies": {
|
|
48
|
-
"@types/d3": "^7.4.3",
|
|
49
36
|
"@types/dom-webcodecs": "^0.1.11",
|
|
50
37
|
"@types/node": "^20.14.13",
|
|
51
38
|
"autoprefixer": "^10.4.19",
|
|
52
|
-
"
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
39
|
+
"typescript": "^5.5.4"
|
|
40
|
+
},
|
|
41
|
+
"main": "./dist/index.js",
|
|
42
|
+
"module": "./dist/index.js",
|
|
43
|
+
"types": "./dist/index.d.ts"
|
|
57
44
|
}
|
|
@@ -874,16 +874,16 @@ describe("EFCaptions", () => {
|
|
|
874
874
|
const captionsTask = captions.customCaptionsDataTask;
|
|
875
875
|
await captionsTask.taskComplete;
|
|
876
876
|
|
|
877
|
-
// Test
|
|
878
|
-
timegroup.currentTimeMs =
|
|
877
|
+
// Test at frame before boundary (frame 77 at 30fps = ~2567ms) - should show " timing"
|
|
878
|
+
timegroup.currentTimeMs = 2567;
|
|
879
879
|
await timegroup.seekTask.taskComplete;
|
|
880
880
|
await captions.frameTask.taskComplete;
|
|
881
881
|
await wordContainer.updateComplete;
|
|
882
882
|
|
|
883
|
-
console.log(`At
|
|
883
|
+
console.log(`At 2567ms: wordText="${wordContainer.wordText}"`);
|
|
884
884
|
expect(wordContainer.wordText).toBe(" timing");
|
|
885
885
|
|
|
886
|
-
// Test at exact boundary
|
|
886
|
+
// Test at exact boundary frame (frame 78 at 30fps = 2600ms) - should show " test" (the starting word)
|
|
887
887
|
timegroup.currentTimeMs = 2600;
|
|
888
888
|
await timegroup.seekTask.taskComplete;
|
|
889
889
|
await captions.frameTask.taskComplete;
|
|
@@ -916,14 +916,14 @@ describe("EFCaptions", () => {
|
|
|
916
916
|
const captionsTask = captions.customCaptionsDataTask;
|
|
917
917
|
await captionsTask.taskComplete;
|
|
918
918
|
|
|
919
|
-
// Test
|
|
920
|
-
timegroup.currentTimeMs =
|
|
919
|
+
// Test at frame before boundary (frame 77 at 30fps = ~2567ms)
|
|
920
|
+
timegroup.currentTimeMs = 2567;
|
|
921
921
|
await timegroup.seekTask.taskComplete;
|
|
922
922
|
await captions.frameTask.taskComplete;
|
|
923
923
|
await wordContainer.updateComplete;
|
|
924
924
|
|
|
925
925
|
console.log(
|
|
926
|
-
`Demo case - At
|
|
926
|
+
`Demo case - At 2567ms: wordText="${wordContainer.wordText}", hidden=${wordContainer.hidden}`,
|
|
927
927
|
);
|
|
928
928
|
expect(wordContainer.wordText).toBe(" captions");
|
|
929
929
|
|
|
@@ -60,7 +60,14 @@ export class EFTimegroup extends EFTargetable(EFTemporal(TWMixin(LitElement))) {
|
|
|
60
60
|
static get observedAttributes(): string[] {
|
|
61
61
|
// biome-ignore lint/complexity/noThisInStatic: It's okay to use this here
|
|
62
62
|
const parentAttributes = super.observedAttributes || [];
|
|
63
|
-
return [
|
|
63
|
+
return [
|
|
64
|
+
...parentAttributes,
|
|
65
|
+
"mode",
|
|
66
|
+
"overlap",
|
|
67
|
+
"currenttime",
|
|
68
|
+
"fit",
|
|
69
|
+
"fps",
|
|
70
|
+
];
|
|
64
71
|
}
|
|
65
72
|
|
|
66
73
|
static styles = css`
|
|
@@ -89,6 +96,9 @@ export class EFTimegroup extends EFTargetable(EFTemporal(TWMixin(LitElement))) {
|
|
|
89
96
|
mode: "fit" | "fixed" | "sequence" | "contain" = "contain";
|
|
90
97
|
overlapMs = 0;
|
|
91
98
|
|
|
99
|
+
@property({ type: Number })
|
|
100
|
+
fps = 30;
|
|
101
|
+
|
|
92
102
|
attributeChangedCallback(
|
|
93
103
|
name: string,
|
|
94
104
|
old: string | null,
|
|
@@ -100,6 +110,9 @@ export class EFTimegroup extends EFTargetable(EFTemporal(TWMixin(LitElement))) {
|
|
|
100
110
|
if (name === "overlap" && value) {
|
|
101
111
|
this.overlapMs = parseTimeToMs(value);
|
|
102
112
|
}
|
|
113
|
+
if (name === "fps" && value) {
|
|
114
|
+
this.fps = Number.parseFloat(value);
|
|
115
|
+
}
|
|
103
116
|
super.attributeChangedCallback(name, old, value);
|
|
104
117
|
}
|
|
105
118
|
|
|
@@ -113,6 +126,31 @@ export class EFTimegroup extends EFTargetable(EFTemporal(TWMixin(LitElement))) {
|
|
|
113
126
|
#pendingSeekTime: number | undefined;
|
|
114
127
|
#processingPendingSeek = false;
|
|
115
128
|
|
|
129
|
+
/**
|
|
130
|
+
* Get the effective FPS for this timegroup.
|
|
131
|
+
* During rendering, uses the render options FPS if available.
|
|
132
|
+
* Otherwise uses the configured fps property.
|
|
133
|
+
*/
|
|
134
|
+
get effectiveFps(): number {
|
|
135
|
+
// During rendering, prefer the render options FPS
|
|
136
|
+
if (typeof window !== "undefined" && window.EF_FRAMEGEN?.renderOptions) {
|
|
137
|
+
return window.EF_FRAMEGEN.renderOptions.encoderOptions.video.framerate;
|
|
138
|
+
}
|
|
139
|
+
return this.fps;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
/**
|
|
143
|
+
* Quantize a time value to the nearest frame boundary based on effectiveFps.
|
|
144
|
+
* @param timeSeconds - Time in seconds
|
|
145
|
+
* @returns Time quantized to frame boundaries in seconds
|
|
146
|
+
*/
|
|
147
|
+
private quantizeToFrameTime(timeSeconds: number): number {
|
|
148
|
+
const fps = this.effectiveFps;
|
|
149
|
+
if (!fps || fps <= 0) return timeSeconds;
|
|
150
|
+
const frameDurationS = 1 / fps;
|
|
151
|
+
return Math.round(timeSeconds / frameDurationS) * frameDurationS;
|
|
152
|
+
}
|
|
153
|
+
|
|
116
154
|
private async runThrottledFrameTask(): Promise<void> {
|
|
117
155
|
if (this.playbackController) {
|
|
118
156
|
return this.playbackController.runThrottledFrameTask();
|
|
@@ -122,6 +160,10 @@ export class EFTimegroup extends EFTargetable(EFTemporal(TWMixin(LitElement))) {
|
|
|
122
160
|
|
|
123
161
|
@property({ type: Number, attribute: "currenttime" })
|
|
124
162
|
set currentTime(time: number) {
|
|
163
|
+
// Quantize time to frame boundaries based on fps
|
|
164
|
+
// Do this BEFORE delegating to playbackController to ensure consistency
|
|
165
|
+
time = this.quantizeToFrameTime(time);
|
|
166
|
+
|
|
125
167
|
if (this.playbackController) {
|
|
126
168
|
this.playbackController.currentTime = time;
|
|
127
169
|
return;
|
|
@@ -120,7 +120,12 @@ export class PlaybackController implements ReactiveController {
|
|
|
120
120
|
}
|
|
121
121
|
|
|
122
122
|
get currentTime(): number {
|
|
123
|
-
|
|
123
|
+
const rawTime = this.#currentTime ?? 0;
|
|
124
|
+
// Quantize to frame boundaries based on host's fps
|
|
125
|
+
const fps = (this.#host as any).fps ?? 30;
|
|
126
|
+
if (!fps || fps <= 0) return rawTime;
|
|
127
|
+
const frameDurationS = 1 / fps;
|
|
128
|
+
return Math.round(rawTime / frameDurationS) * frameDurationS;
|
|
124
129
|
}
|
|
125
130
|
|
|
126
131
|
set currentTime(time: number) {
|
package/tsdown.config.ts
ADDED
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { readFileSync } from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
|
|
4
|
+
import { defineConfig, type Plugin } from "tsdown";
|
|
5
|
+
|
|
6
|
+
import { createTsdownConfig } from "../tsdown.config.base.ts";
|
|
7
|
+
|
|
8
|
+
// Plugin to handle CSS ?inline imports
|
|
9
|
+
const inlineCssPlugin = (): Plugin => ({
|
|
10
|
+
name: "inline-css",
|
|
11
|
+
resolveId(source, importer) {
|
|
12
|
+
if (source.endsWith(".css?inline") && importer) {
|
|
13
|
+
const resolved = path.resolve(
|
|
14
|
+
path.dirname(importer),
|
|
15
|
+
source.replace("?inline", ""),
|
|
16
|
+
);
|
|
17
|
+
return { id: resolved + "?inline", external: false };
|
|
18
|
+
}
|
|
19
|
+
return null;
|
|
20
|
+
},
|
|
21
|
+
load(id) {
|
|
22
|
+
if (id.endsWith("?inline")) {
|
|
23
|
+
const filePath = id.replace("?inline", "");
|
|
24
|
+
const css = readFileSync(filePath, "utf-8");
|
|
25
|
+
return `export default ${JSON.stringify(css)}`;
|
|
26
|
+
}
|
|
27
|
+
return null;
|
|
28
|
+
},
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
export default defineConfig(
|
|
32
|
+
createTsdownConfig({
|
|
33
|
+
plugins: [inlineCssPlugin()],
|
|
34
|
+
external: [/@editframe\/assets/],
|
|
35
|
+
}),
|
|
36
|
+
);
|