@omnimedia/omnitool 1.1.0-7 → 1.1.0-70
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +143 -80
- package/package.json +18 -17
- package/s/context.ts +0 -7
- package/s/demo/demo.bundle.ts +104 -43
- package/s/demo/demo.css +244 -14
- package/s/demo/routines/export-test.ts +16 -0
- package/s/demo/routines/filmstrip-test.ts +22 -18
- package/s/demo/routines/load-video.ts +2 -3
- package/s/demo/routines/playback-test.ts +61 -0
- package/s/demo/routines/timeline-setup.ts +24 -0
- package/s/demo/routines/transcode-test.ts +19 -5
- package/s/demo/routines/transitions-test.ts +2 -2
- package/s/demo/routines/waveform-test.ts +35 -8
- package/s/driver/driver-worker.ts +9 -0
- package/s/driver/driver.test.ts +1 -1
- package/s/driver/driver.ts +43 -42
- package/s/driver/fns/schematic.ts +11 -5
- package/s/driver/fns/work.ts +65 -189
- package/s/driver/parts/compositor.ts +187 -0
- package/s/driver/parts/machina.ts +19 -20
- package/s/index.html.ts +103 -25
- package/s/index.ts +1 -0
- package/s/tests.bundle.ts +11 -0
- package/s/tests.html.ts +28 -0
- package/s/timeline/index.ts +5 -0
- package/s/timeline/parts/filmstrip.ts +43 -16
- package/s/timeline/parts/item.ts +27 -6
- package/s/timeline/parts/media.ts +12 -2
- package/s/timeline/parts/resource-pool.ts +8 -5
- package/s/timeline/parts/resource.ts +3 -0
- package/s/timeline/parts/waveform/parts/collect.ts +72 -0
- package/s/timeline/parts/waveform/parts/render.ts +45 -0
- package/s/timeline/parts/waveform/parts/types.ts +24 -0
- package/s/timeline/parts/waveform/waveform.ts +161 -0
- package/s/timeline/renderers/export/parts/audio-gain.ts +17 -0
- package/s/timeline/renderers/export/parts/audio-mix.ts +133 -0
- package/s/timeline/renderers/export/parts/cursor.ts +129 -0
- package/s/timeline/renderers/export/parts/produce-audio.ts +64 -0
- package/s/timeline/renderers/export/parts/produce-video.ts +49 -0
- package/s/timeline/renderers/export/parts/resamplers.ts +48 -0
- package/s/timeline/renderers/export/produce.ts +28 -0
- package/s/timeline/renderers/parts/handy.ts +360 -0
- package/s/timeline/renderers/parts/samplers/audio/parts/find.ts +19 -0
- package/s/timeline/renderers/parts/samplers/audio/parts/init.ts +60 -0
- package/s/timeline/renderers/parts/samplers/audio/parts/sink.ts +38 -0
- package/s/timeline/renderers/parts/samplers/audio/parts/types.ts +16 -0
- package/s/timeline/renderers/parts/samplers/audio/sampler.ts +35 -0
- package/s/timeline/renderers/parts/samplers/visual/parts/defaults.ts +16 -0
- package/s/timeline/renderers/parts/samplers/visual/parts/sample.ts +59 -0
- package/s/timeline/renderers/parts/samplers/visual/parts/sequence.ts +111 -0
- package/s/timeline/renderers/parts/samplers/visual/parts/sink.ts +38 -0
- package/s/timeline/renderers/parts/samplers/visual/parts/transition.ts +28 -0
- package/s/timeline/renderers/parts/samplers/visual/parts/types.ts +10 -0
- package/s/timeline/renderers/parts/samplers/visual/sampler.ts +28 -0
- package/s/timeline/renderers/parts/schedulers.ts +96 -0
- package/s/timeline/renderers/player/parts/playback.ts +159 -0
- package/s/timeline/renderers/player/player.ts +77 -0
- package/s/timeline/renderers/renderers.test.ts +385 -0
- package/s/timeline/sugar/helpers.ts +85 -0
- package/s/timeline/sugar/o.ts +138 -57
- package/s/timeline/sugar/omni.test.ts +210 -0
- package/s/timeline/sugar/omni.ts +35 -12
- package/s/timeline/utils/checksum.ts +3 -1
- package/s/timeline/utils/datafile.ts +15 -4
- package/s/timeline/utils/dummy-data.ts +3 -3
- package/s/units/fps.ts +8 -0
- package/s/units/ms.ts +8 -0
- package/s/units/seconds.ts +8 -0
- package/x/WebGLRenderer-7X274AYV.js +2 -0
- package/x/WebGLRenderer-7X274AYV.js.map +7 -0
- package/x/WebGPURenderer-XMCMEXAO.js +2 -0
- package/x/WebGPURenderer-XMCMEXAO.js.map +7 -0
- package/x/browserAll-6TVTCHHE.js +2 -0
- package/x/browserAll-6TVTCHHE.js.map +7 -0
- package/x/chunk-4ONWQOPX.js +157 -0
- package/x/chunk-4ONWQOPX.js.map +7 -0
- package/x/chunk-63NSCXPX.js +2 -0
- package/x/chunk-63NSCXPX.js.map +7 -0
- package/x/chunk-A45M2HJC.js +2 -0
- package/x/chunk-A45M2HJC.js.map +7 -0
- package/x/chunk-OTQK6FAJ.js +15 -0
- package/x/chunk-OTQK6FAJ.js.map +7 -0
- package/x/chunk-Q7JBQNE4.js +42 -0
- package/x/chunk-Q7JBQNE4.js.map +7 -0
- package/x/chunk-W33LM336.js +393 -0
- package/x/chunk-W33LM336.js.map +7 -0
- package/x/chunk-W5CN46AR.js +327 -0
- package/x/chunk-W5CN46AR.js.map +7 -0
- package/x/chunk-WFT3KTZG.js +269 -0
- package/x/chunk-WFT3KTZG.js.map +7 -0
- package/x/context.d.ts +1 -4
- package/x/context.js +1 -5
- package/x/context.js.map +1 -1
- package/x/demo/WebGLRenderer-NLGJGAXK.js +2 -0
- package/x/demo/WebGLRenderer-NLGJGAXK.js.map +7 -0
- package/x/demo/WebGPURenderer-RBOFXPL5.js +2 -0
- package/x/demo/WebGPURenderer-RBOFXPL5.js.map +7 -0
- package/x/demo/browserAll-5AZHDDG6.js +2 -0
- package/x/demo/browserAll-5AZHDDG6.js.map +7 -0
- package/x/demo/chunk-5ZZYIILO.js +393 -0
- package/x/demo/chunk-5ZZYIILO.js.map +7 -0
- package/x/demo/chunk-P3PTHHFE.js +42 -0
- package/x/demo/chunk-P3PTHHFE.js.map +7 -0
- package/x/demo/chunk-PYG4RZZ2.js +269 -0
- package/x/demo/chunk-PYG4RZZ2.js.map +7 -0
- package/x/demo/chunk-Q4MWBZHL.js +157 -0
- package/x/demo/chunk-Q4MWBZHL.js.map +7 -0
- package/x/demo/chunk-T3METYEY.js +15 -0
- package/x/demo/chunk-T3METYEY.js.map +7 -0
- package/x/demo/chunk-USLRKDKD.js +2 -0
- package/x/demo/chunk-USLRKDKD.js.map +7 -0
- package/x/demo/chunk-YISSXWBT.js +327 -0
- package/x/demo/chunk-YISSXWBT.js.map +7 -0
- package/x/demo/chunk-YJQWVIHX.js +2 -0
- package/x/demo/chunk-YJQWVIHX.js.map +7 -0
- package/x/demo/demo.bundle.js +94 -40
- package/x/demo/demo.bundle.js.map +1 -1
- package/x/demo/demo.bundle.min.js +2421 -81
- package/x/demo/demo.bundle.min.js.map +4 -4
- package/x/demo/demo.css +244 -14
- package/x/demo/routines/export-test.d.ts +2 -0
- package/x/demo/routines/export-test.js +10 -0
- package/x/demo/routines/export-test.js.map +1 -0
- package/x/demo/routines/filmstrip-test.d.ts +1 -1
- package/x/demo/routines/filmstrip-test.js +20 -17
- package/x/demo/routines/filmstrip-test.js.map +1 -1
- package/x/demo/routines/load-video.d.ts +1 -1
- package/x/demo/routines/load-video.js +1 -2
- package/x/demo/routines/load-video.js.map +1 -1
- package/x/demo/routines/playback-test.d.ts +2 -0
- package/x/demo/routines/playback-test.js +51 -0
- package/x/demo/routines/playback-test.js.map +1 -0
- package/x/demo/routines/timeline-setup.d.ts +6 -0
- package/x/demo/routines/timeline-setup.js +13 -0
- package/x/demo/routines/timeline-setup.js.map +1 -0
- package/x/demo/routines/transcode-test.js +15 -5
- package/x/demo/routines/transcode-test.js.map +1 -1
- package/x/demo/routines/transitions-test.js +2 -2
- package/x/demo/routines/transitions-test.js.map +1 -1
- package/x/demo/routines/waveform-test.d.ts +2 -1
- package/x/demo/routines/waveform-test.js +29 -8
- package/x/demo/routines/waveform-test.js.map +1 -1
- package/x/demo/webworkerAll-QKIC5O27.js +2 -0
- package/x/demo/webworkerAll-QKIC5O27.js.map +7 -0
- package/x/driver/driver-worker.d.ts +1 -0
- package/x/driver/driver-worker.js +6 -0
- package/x/driver/driver-worker.js.map +1 -0
- package/x/driver/driver.d.ts +25 -8
- package/x/driver/driver.js +43 -39
- package/x/driver/driver.js.map +1 -1
- package/x/driver/driver.test.js +1 -1
- package/x/driver/driver.test.js.map +1 -1
- package/x/driver/driver.worker.bundle.min.js +117 -3506
- package/x/driver/driver.worker.bundle.min.js.map +4 -4
- package/x/driver/fns/host.d.ts +3 -2
- package/x/driver/fns/schematic.d.ts +11 -4
- package/x/driver/fns/work.d.ts +4 -4
- package/x/driver/fns/work.js +55 -155
- package/x/driver/fns/work.js.map +1 -1
- package/x/driver/parts/compositor.d.ts +20 -0
- package/x/driver/parts/compositor.js +159 -0
- package/x/driver/parts/compositor.js.map +1 -0
- package/x/driver/parts/machina.d.ts +0 -20
- package/x/driver/parts/machina.js +6 -10
- package/x/driver/parts/machina.js.map +1 -1
- package/x/features/speech/transcribe/parts/prep-audio.d.ts +1 -1
- package/x/features/speech/transcribe/worker.bundle.min.js +899 -899
- package/x/features/speech/transcribe/worker.bundle.min.js.map +4 -4
- package/x/index.d.ts +1 -0
- package/x/index.html +347 -38
- package/x/index.html.js +103 -24
- package/x/index.html.js.map +1 -1
- package/x/index.js +1 -0
- package/x/index.js.map +1 -1
- package/x/tests.bundle.js +8 -0
- package/x/tests.bundle.js.map +1 -0
- package/x/tests.bundle.min.js +2464 -0
- package/x/tests.bundle.min.js.map +7 -0
- package/x/tests.html +316 -0
- package/x/tests.html.d.ts +2 -0
- package/x/tests.html.js +22 -0
- package/x/tests.html.js.map +1 -0
- package/x/timeline/index.d.ts +4 -0
- package/x/timeline/index.js +4 -0
- package/x/timeline/index.js.map +1 -1
- package/x/timeline/parts/filmstrip.d.ts +4 -3
- package/x/timeline/parts/filmstrip.js +29 -10
- package/x/timeline/parts/filmstrip.js.map +1 -1
- package/x/timeline/parts/item.d.ts +20 -3
- package/x/timeline/parts/item.js +1 -0
- package/x/timeline/parts/item.js.map +1 -1
- package/x/timeline/parts/media.d.ts +2 -0
- package/x/timeline/parts/media.js +11 -2
- package/x/timeline/parts/media.js.map +1 -1
- package/x/timeline/parts/resource-pool.d.ts +3 -0
- package/x/timeline/parts/resource-pool.js +7 -4
- package/x/timeline/parts/resource-pool.js.map +1 -1
- package/x/timeline/parts/resource.d.ts +3 -0
- package/x/timeline/parts/waveform/parts/collect.d.ts +11 -0
- package/x/timeline/parts/waveform/parts/collect.js +56 -0
- package/x/timeline/parts/waveform/parts/collect.js.map +1 -0
- package/x/timeline/parts/waveform/parts/render.d.ts +5 -0
- package/x/timeline/parts/waveform/parts/render.js +29 -0
- package/x/timeline/parts/waveform/parts/render.js.map +1 -0
- package/x/timeline/parts/waveform/parts/types.d.ts +21 -0
- package/x/timeline/parts/waveform/parts/types.js.map +1 -0
- package/x/timeline/parts/waveform/waveform.d.ts +19 -0
- package/x/timeline/parts/waveform/waveform.js +133 -0
- package/x/timeline/parts/waveform/waveform.js.map +1 -0
- package/x/timeline/renderers/export/parts/audio-gain.d.ts +1 -0
- package/x/timeline/renderers/export/parts/audio-gain.js +13 -0
- package/x/timeline/renderers/export/parts/audio-gain.js.map +1 -0
- package/x/timeline/renderers/export/parts/audio-mix.d.ts +21 -0
- package/x/timeline/renderers/export/parts/audio-mix.js +89 -0
- package/x/timeline/renderers/export/parts/audio-mix.js.map +1 -0
- package/x/timeline/renderers/export/parts/cursor.d.ts +18 -0
- package/x/timeline/renderers/export/parts/cursor.js +99 -0
- package/x/timeline/renderers/export/parts/cursor.js.map +1 -0
- package/x/timeline/renderers/export/parts/produce-audio.d.ts +6 -0
- package/x/timeline/renderers/export/parts/produce-audio.js +41 -0
- package/x/timeline/renderers/export/parts/produce-audio.js.map +1 -0
- package/x/timeline/renderers/export/parts/produce-video.d.ts +10 -0
- package/x/timeline/renderers/export/parts/produce-video.js +26 -0
- package/x/timeline/renderers/export/parts/produce-video.js.map +1 -0
- package/x/timeline/renderers/export/parts/resamplers.d.ts +12 -0
- package/x/timeline/renderers/export/parts/resamplers.js +29 -0
- package/x/timeline/renderers/export/parts/resamplers.js.map +1 -0
- package/x/timeline/renderers/export/produce.d.ts +13 -0
- package/x/timeline/renderers/export/produce.js +15 -0
- package/x/timeline/renderers/export/produce.js.map +1 -0
- package/x/timeline/renderers/parts/handy.d.ts +30 -0
- package/x/timeline/renderers/parts/handy.js +219 -0
- package/x/timeline/renderers/parts/handy.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/find.d.ts +6 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/find.js +15 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/find.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/init.d.ts +5 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/init.js +40 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/init.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/sink.d.ts +8 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/sink.js +24 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/sink.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/types.d.ts +14 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/types.js +2 -0
- package/x/timeline/renderers/parts/samplers/audio/parts/types.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/audio/sampler.d.ts +11 -0
- package/x/timeline/renderers/parts/samplers/audio/sampler.js +22 -0
- package/x/timeline/renderers/parts/samplers/audio/sampler.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/defaults.d.ts +5 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/defaults.js +10 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/defaults.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/sample.d.ts +5 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/sample.js +38 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/sample.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/sequence.d.ts +5 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/sequence.js +75 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/sequence.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/sink.d.ts +8 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/sink.js +24 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/sink.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/transition.d.ts +3 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/transition.js +18 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/transition.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/types.d.ts +8 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/types.js +2 -0
- package/x/timeline/renderers/parts/samplers/visual/parts/types.js.map +1 -0
- package/x/timeline/renderers/parts/samplers/visual/sampler.d.ts +7 -0
- package/x/timeline/renderers/parts/samplers/visual/sampler.js +17 -0
- package/x/timeline/renderers/parts/samplers/visual/sampler.js.map +1 -0
- package/x/timeline/renderers/parts/schedulers.d.ts +17 -0
- package/x/timeline/renderers/parts/schedulers.js +64 -0
- package/x/timeline/renderers/parts/schedulers.js.map +1 -0
- package/x/timeline/renderers/player/parts/playback.d.ts +36 -0
- package/x/timeline/renderers/player/parts/playback.js +113 -0
- package/x/timeline/renderers/player/parts/playback.js.map +1 -0
- package/x/timeline/renderers/player/player.d.ts +25 -0
- package/x/timeline/renderers/player/player.js +56 -0
- package/x/timeline/renderers/player/player.js.map +1 -0
- package/x/timeline/renderers/renderers.test.d.ts +32 -0
- package/x/timeline/renderers/renderers.test.js +305 -0
- package/x/timeline/renderers/renderers.test.js.map +1 -0
- package/x/timeline/sugar/helpers.d.ts +30 -0
- package/x/timeline/sugar/helpers.js +46 -0
- package/x/timeline/sugar/helpers.js.map +1 -0
- package/x/timeline/sugar/o.d.ts +28 -13
- package/x/timeline/sugar/o.js +108 -51
- package/x/timeline/sugar/o.js.map +1 -1
- package/x/timeline/sugar/omni.d.ts +11 -6
- package/x/timeline/sugar/omni.js +28 -8
- package/x/timeline/sugar/omni.js.map +1 -1
- package/x/timeline/sugar/omni.test.d.ts +27 -0
- package/x/timeline/sugar/omni.test.js +128 -0
- package/x/timeline/sugar/omni.test.js.map +1 -0
- package/x/timeline/utils/checksum.d.ts +3 -2
- package/x/timeline/utils/checksum.js.map +1 -1
- package/x/timeline/utils/datafile.d.ts +5 -3
- package/x/timeline/utils/datafile.js +18 -5
- package/x/timeline/utils/datafile.js.map +1 -1
- package/x/timeline/utils/dummy-data.d.ts +1 -2
- package/x/timeline/utils/dummy-data.js +4 -2
- package/x/timeline/utils/dummy-data.js.map +1 -1
- package/x/units/fps.d.ts +6 -0
- package/x/units/fps.js +2 -0
- package/x/units/fps.js.map +1 -0
- package/x/units/ms.d.ts +6 -0
- package/x/units/ms.js +2 -0
- package/x/units/ms.js.map +1 -0
- package/x/units/seconds.d.ts +6 -0
- package/x/units/seconds.js +2 -0
- package/x/units/seconds.js.map +1 -0
- package/x/webworkerAll-VVIU3M54.js +2 -0
- package/x/webworkerAll-VVIU3M54.js.map +7 -0
- package/s/tests.test.ts +0 -8
- package/s/timeline/parts/compositor/export.ts +0 -77
- package/s/timeline/parts/compositor/parts/html-tree.ts +0 -37
- package/s/timeline/parts/compositor/parts/schedulers.ts +0 -85
- package/s/timeline/parts/compositor/parts/tree-builder.ts +0 -184
- package/s/timeline/parts/compositor/parts/webcodecs-tree.ts +0 -30
- package/s/timeline/parts/compositor/playback.ts +0 -81
- package/s/timeline/parts/compositor/samplers/html.ts +0 -115
- package/s/timeline/parts/compositor/samplers/webcodecs.ts +0 -60
- package/s/timeline/parts/waveform.ts +0 -62
- package/s/timeline/sugar/builders.ts +0 -102
- package/s/timeline/sugar/omni-test.ts +0 -38
- package/s/timeline/timeline.ts +0 -22
- package/s/timeline/utils/audio-stream.ts +0 -15
- package/s/timeline/utils/video-cursor.ts +0 -40
- package/s/tools/common/loader.ts +0 -26
- package/s/tools/common/transformer-pipeline.ts +0 -26
- package/s/tools/speech-recognition/common/model.ts +0 -26
- package/s/tools/speech-recognition/whisper/fns/host.ts +0 -25
- package/s/tools/speech-recognition/whisper/fns/schematic.ts +0 -23
- package/s/tools/speech-recognition/whisper/fns/work.ts +0 -91
- package/s/tools/speech-recognition/whisper/parts/types.ts +0 -38
- package/s/tools/speech-recognition/whisper/parts/worker.bundle.ts +0 -7
- package/s/tools/speech-recognition/whisper/tool.ts +0 -70
- package/x/tests.test.js +0 -6
- package/x/tests.test.js.map +0 -1
- package/x/timeline/parts/compositor/export.d.ts +0 -9
- package/x/timeline/parts/compositor/export.js +0 -64
- package/x/timeline/parts/compositor/export.js.map +0 -1
- package/x/timeline/parts/compositor/parts/html-tree.d.ts +0 -3
- package/x/timeline/parts/compositor/parts/html-tree.js +0 -40
- package/x/timeline/parts/compositor/parts/html-tree.js.map +0 -1
- package/x/timeline/parts/compositor/parts/schedulers.d.ts +0 -15
- package/x/timeline/parts/compositor/parts/schedulers.js +0 -64
- package/x/timeline/parts/compositor/parts/schedulers.js.map +0 -1
- package/x/timeline/parts/compositor/parts/tree-builder.d.ts +0 -37
- package/x/timeline/parts/compositor/parts/tree-builder.js +0 -147
- package/x/timeline/parts/compositor/parts/tree-builder.js.map +0 -1
- package/x/timeline/parts/compositor/parts/webcodecs-tree.d.ts +0 -3
- package/x/timeline/parts/compositor/parts/webcodecs-tree.js +0 -28
- package/x/timeline/parts/compositor/parts/webcodecs-tree.js.map +0 -1
- package/x/timeline/parts/compositor/playback.d.ts +0 -19
- package/x/timeline/parts/compositor/playback.js +0 -71
- package/x/timeline/parts/compositor/playback.js.map +0 -1
- package/x/timeline/parts/compositor/samplers/html.d.ts +0 -3
- package/x/timeline/parts/compositor/samplers/html.js +0 -106
- package/x/timeline/parts/compositor/samplers/html.js.map +0 -1
- package/x/timeline/parts/compositor/samplers/webcodecs.d.ts +0 -2
- package/x/timeline/parts/compositor/samplers/webcodecs.js +0 -55
- package/x/timeline/parts/compositor/samplers/webcodecs.js.map +0 -1
- package/x/timeline/parts/waveform.d.ts +0 -8
- package/x/timeline/parts/waveform.js +0 -51
- package/x/timeline/parts/waveform.js.map +0 -1
- package/x/timeline/sugar/builders.d.ts +0 -96
- package/x/timeline/sugar/builders.js +0 -108
- package/x/timeline/sugar/builders.js.map +0 -1
- package/x/timeline/sugar/omni-test.d.ts +0 -1
- package/x/timeline/sugar/omni-test.js +0 -22
- package/x/timeline/sugar/omni-test.js.map +0 -1
- package/x/timeline/timeline.d.ts +0 -9
- package/x/timeline/timeline.js +0 -22
- package/x/timeline/timeline.js.map +0 -1
- package/x/timeline/utils/audio-stream.d.ts +0 -6
- package/x/timeline/utils/audio-stream.js +0 -17
- package/x/timeline/utils/audio-stream.js.map +0 -1
- package/x/timeline/utils/video-cursor.d.ts +0 -10
- package/x/timeline/utils/video-cursor.js +0 -36
- package/x/timeline/utils/video-cursor.js.map +0 -1
- package/x/tools/common/loader.d.ts +0 -19
- package/x/tools/common/loader.js +0 -18
- package/x/tools/common/loader.js.map +0 -1
- package/x/tools/common/transformer-pipeline.d.ts +0 -8
- package/x/tools/common/transformer-pipeline.js +0 -24
- package/x/tools/common/transformer-pipeline.js.map +0 -1
- package/x/tools/speech-recognition/common/model.d.ts +0 -14
- package/x/tools/speech-recognition/common/model.js +0 -16
- package/x/tools/speech-recognition/common/model.js.map +0 -1
- package/x/tools/speech-recognition/whisper/fns/host.d.ts +0 -13
- package/x/tools/speech-recognition/whisper/fns/host.js +0 -19
- package/x/tools/speech-recognition/whisper/fns/host.js.map +0 -1
- package/x/tools/speech-recognition/whisper/fns/schematic.d.ts +0 -19
- package/x/tools/speech-recognition/whisper/fns/schematic.js +0 -2
- package/x/tools/speech-recognition/whisper/fns/schematic.js.map +0 -1
- package/x/tools/speech-recognition/whisper/fns/work.d.ts +0 -12
- package/x/tools/speech-recognition/whisper/fns/work.js +0 -74
- package/x/tools/speech-recognition/whisper/fns/work.js.map +0 -1
- package/x/tools/speech-recognition/whisper/parts/types.d.ts +0 -31
- package/x/tools/speech-recognition/whisper/parts/types.js.map +0 -1
- package/x/tools/speech-recognition/whisper/parts/worker.bundle.d.ts +0 -1
- package/x/tools/speech-recognition/whisper/parts/worker.bundle.js +0 -4
- package/x/tools/speech-recognition/whisper/parts/worker.bundle.js.map +0 -1
- package/x/tools/speech-recognition/whisper/parts/worker.bundle.min.js +0 -8
- package/x/tools/speech-recognition/whisper/parts/worker.bundle.min.js.map +0 -7
- package/x/tools/speech-recognition/whisper/tool.d.ts +0 -12
- package/x/tools/speech-recognition/whisper/tool.js +0 -63
- package/x/tools/speech-recognition/whisper/tool.js.map +0 -1
- /package/x/{tests.test.d.ts → tests.bundle.d.ts} +0 -0
- /package/x/{tools/speech-recognition/whisper → timeline/parts/waveform}/parts/types.js +0 -0
|
@@ -1,113 +1,2453 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
`)});var er=()=>({stdout:async r=>console.log(r),stderr:async r=>console.error(r)});var fs=()=>dn()?Yt():fn()?Jt():er();var ms=()=>({stdout:async()=>{},stderr:async()=>{}});function hs(){return()=>({stdout:r=>r,stderr:r=>r})}var Xe=class r{static writers={auto:fs,void:ms,deno:Yt,node:Jt,console:er};static colors={auto:mn,colorful:()=>Tt,colorless:()=>St};static themes={auto:cs,basic:Gt};static shapers={auto:ds,none:hs,errors:Qt,timestamp:Zt};writer=r.writers.auto();colors=r.colors.auto();theme=r.themes.auto();shaper=r.shapers.auto();async log(...e){await this.writer.stdout(this.shaper(this).stdout(e).join(" "))}async error(...e){await this.writer.stderr(this.shaper(this).stderr(e).join(" "))}setWriter(e){return this.writer=e,this}setColors(e){return this.colors=e,this}setTheme(e){return this.theme=e,this}setShaper(...e){return this.shaper=Pt(...e),this}};var Ct=class extends Xe{static dummy(){return new this().setWriter(Xe.writers.void())}rpcRequest=async({request:e,...t})=>{let n=this.colors.none;this.log(...this.#e(t),n(`${e.method}()`))};rpcError=async({request:e,error:t,...n})=>{this.error(...this.#e(n),`${e.method}()`,t)};#e({meta:e,label:t,remote:n}){let s=this.colors.mix(this.colors.blue,this.colors.dim),a=this.colors.mix(this.colors.cyan,this.colors.dim);return[e?this.#t(e):void 0,t||void 0,n===void 0?void 0:n?s("<-"):a("->")].filter(Boolean)}#t(e){let{headers:t}=e.request;return[this.colors.yellow(`[${e.ip}]`),this.colors.green(t.origin?t.origin:"(no-origin)")].join(" ")}};var oe=class extends Ct{rpcRequest=async()=>{}};var ce=Object.freeze({eq(r,e){if(r.length!==e.length)return!1;for(let t=0;t<=r.length;t++)if(r.at(t)!==e.at(t))return!1;return!0},random(r){return crypto.getRandomValues(new Uint8Array(r))}});var De=Object.freeze({fromBytes(r){return[...r].map(e=>e.toString(16).padStart(2,"0")).join("")},toBytes(r){if(r.length%2!==0)throw new Error("must have even number of hex characters");let e=new Uint8Array(r.length/2);for(let t=0;t<r.length;t+=2)e[t/2]=parseInt(r.slice(t,t+2),16);return e},random(r=32){return this.fromBytes(ce.random(r))},string(r){return De.fromBytes(r)},bytes(r){return De.toBytes(r)}});var hn=58,tr="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz",pn=Object.freeze({fromBytes(r){let e=BigInt("0x"+De.fromBytes(r)),t="";for(;e>0;){let n=e%BigInt(hn);e=e/BigInt(hn),t=tr[Number(n)]+t}for(let n of r)if(n===0)t=tr[0]+t;else break;return t},toBytes(r){let e=BigInt(0);for(let i of r){let o=tr.indexOf(i);if(o===-1)throw new Error(`Invalid character '${i}' in base58 string`);e=e*BigInt(hn)+BigInt(o)}let t=e.toString(16);t.length%2!==0&&(t="0"+t);let n=De.toBytes(t),s=0;for(let i of r)if(i===tr[0])s++;else break;let a=new Uint8Array(s+n.length);return a.set(n,s),a},random(r=32){return this.fromBytes(ce.random(r))},string(r){return pn.fromBytes(r)},bytes(r){return pn.toBytes(r)}});var ps=class{lexicon;static lexicons=Object.freeze({base2:{characters:"01"},hex:{characters:"0123456789abcdef"},base36:{characters:"0123456789abcdefghijklmnopqrstuvwxyz"},base58:{characters:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"},base62:{characters:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"},base64url:{negativePrefix:"~",characters:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_"},base64:{characters:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",padding:{character:"=",size:4}}});lookup;negativePrefix;constructor(e){this.lexicon=e,this.lookup=Object.fromEntries([...e.characters].map((t,n)=>[t,n])),this.negativePrefix=e.negativePrefix??"-"}toBytes(e){let t=Math.log2(this.lexicon.characters.length);if(Number.isInteger(t)){let o=0,c=0,l=[];for(let u of e){if(u===this.lexicon.padding?.character)continue;let d=this.lookup[u];if(d===void 0)throw new Error(`Invalid character: ${u}`);for(o=o<<t|d,c+=t;c>=8;)c-=8,l.push(o>>c&255)}return new Uint8Array(l)}let n=0n,s=BigInt(this.lexicon.characters.length),a=!1;e.startsWith(this.negativePrefix)&&(e=e.slice(this.negativePrefix.length),a=!0);for(let o of e){let c=this.lookup[o];if(c===void 0)throw new Error(`Invalid character: ${o}`);n=n*s+BigInt(c)}let i=[];for(;n>0n;)i.unshift(Number(n%256n)),n=n/256n;return new Uint8Array(i)}fromBytes(e){let t=Math.log2(this.lexicon.characters.length);if(Number.isInteger(t)){let i=0,o=0,c="";for(let l of e)for(i=i<<8|l,o+=8;o>=t;){o-=t;let u=i>>o&(1<<t)-1;c+=this.lexicon.characters[u]}if(o>0){let l=i<<t-o&(1<<t)-1;c+=this.lexicon.characters[l]}if(this.lexicon.padding)for(;c.length%this.lexicon.padding.size!==0;)c+=this.lexicon.padding.character;return c}let n=0n;for(let i of e)n=(n<<8n)+BigInt(i);if(n===0n)return this.lexicon.characters[0];let s=BigInt(this.lexicon.characters.length),a="";for(;n>0n;)a=this.lexicon.characters[Number(n%s)]+a,n=n/s;return a}toInteger(e){if(!e)return 0;let t=0n,n=!1,s=BigInt(this.lexicon.characters.length);e.startsWith(this.negativePrefix)&&(e=e.slice(this.negativePrefix.length),n=!0);for(let a of e){let i=this.lookup[a];if(i===void 0)throw new Error(`Invalid character: ${a}`);t=t*s+BigInt(i)}return Number(n?-t:t)}fromInteger(e){e=Math.floor(e);let t=e<0,n=BigInt(t?-e:e);if(n===0n)return this.lexicon.characters[0];let s=BigInt(this.lexicon.characters.length),a="";for(;n>0n;)a=this.lexicon.characters[Number(n%s)]+a,n=n/s;return t?`${this.negativePrefix}${a}`:a}random(e=32){return this.fromBytes(ce.random(e))}};var gn=Object.freeze({fromBytes(r){return typeof btoa=="function"?btoa(String.fromCharCode(...r)):Buffer.from(r).toString("base64")},toBytes(r){return typeof atob=="function"?Uint8Array.from(atob(r),e=>e.charCodeAt(0)):Uint8Array.from(Buffer.from(r,"base64"))},random(r=32){return this.fromBytes(ce.random(r))},string(r){return gn.fromBytes(r)},bytes(r){return gn.toBytes(r)}});var gs=Object.freeze({fromBytes(r){return new TextDecoder().decode(r)},toBytes(r){return new TextEncoder().encode(r)},string(r){return gs.fromBytes(r)},bytes(r){return gs.toBytes(r)}});var rr=Object.freeze({set:r=>r!=null,unset:r=>r==null,boolean:r=>typeof r=="boolean",number:r=>typeof r=="number",string:r=>typeof r=="string",bigint:r=>typeof r=="bigint",object:r=>typeof r=="object"&&r!==null,array:r=>Array.isArray(r),fn:r=>typeof r=="function",symbol:r=>typeof r=="symbol"});var vt=class extends Error{milliseconds;name=this.constructor.name;constructor(e){super(`deadline exceeded (${(e/1e3).toFixed(1)} seconds)`),this.milliseconds=e}};function nr(r,e){return r<=0||r===1/0?e():new Promise((t,n)=>{let s=setTimeout(()=>n(new vt(r)),r);e().then(t).catch(n).finally(()=>clearTimeout(s))})}function Be(){let r,e,t=new Promise((s,a)=>{r=s,e=a});function n(s){return s.then(r).catch(e),t}return{promise:t,resolve:r,reject:e,entangle:n}}function bs(r,e){let t=r;for(let n of e)if(t=t[n],rr.unset(t))break;return t}function Qi(r){return{map:e=>ys(r,e),filter:e=>ks(r,e)}}Qi.pipe=Object.freeze({map:r=>e=>ys(e,r),filter:r=>e=>ks(e,r)});var ys=(r,e)=>Object.fromEntries(Object.entries(r).map(([t,n])=>[t,e(n,t)])),ks=(r,e)=>Object.fromEntries(Object.entries(r).filter(([t,n])=>e(n,t)));function Zi(){let r=new Set;function e(a){return r.add(a),()=>{r.delete(a)}}async function t(...a){await Promise.all([...r].map(i=>i(...a)))}async function n(){let{promise:a,resolve:i}=Be(),o=e((...c)=>{i(c),o()});return a}function s(){r.clear()}return e.pub=t,e.sub=e,e.on=e,e.next=n,e.clear=s,t.pub=t,t.sub=e,t.on=e,t.next=n,t.clear=s,[t,e]}function sr(r){let e=Zi()[0];return r&&e.sub(r),e}var fe=class{#e=[];add(...e){return this.#e.push(...e),this}disposable(e){return this.bag(e,()=>e.dispose())}bag(e,t){return this.add(()=>t(e)),e}dispose(){for(let e of this.#e.reverse())e();this.#e=[]}};var Te;(function(r){r.version="2.0";function e(t){return"id"in t?t.id:null}r.getId=e,r.errorCodes={serverError:-32e3,unexposedError:-32001}})(Te||(Te={}));var ir=class extends Error{name=this.constructor.name},Re=class extends Error{name=this.constructor.name};async function xs({tap:r,request:e,action:t}){let n=Te.getId(e);try{let s=await t();return n===null?null:{id:n,result:s,jsonrpc:Te.version}}catch(s){return r.rpcError({request:e,error:s}),n===null?null:{id:n,jsonrpc:Te.version,error:s instanceof ir?{code:Te.errorCodes.serverError,message:s.message}:{code:Te.errorCodes.unexposedError,message:"unexposed error"}}}}function ar(r){let e=r.tap??new oe;return async t=>{let n=t.method.split("."),s=bs(r.fns,n),a=async()=>await s(...t.params);return e.rpcRequest({request:t}),await xs({tap:e,request:t,action:a})}}var Oe=Symbol("tune"),Yi=Symbol("query"),Ji=Symbol("notify"),ea=Symbol("settings");function ws(r){function e(t){let n={notify:void 0};return new Proxy(()=>{},{apply:(s,a,i)=>r(t,i,n),get:(s,a)=>{if(a!=="then")return a===Oe?i=>(...o)=>r(t,o,{...n,...i}):a===Ji?(...i)=>r(t,i,{...n,notify:!0}):a===Yi?(...i)=>r(t,i,{...n,notify:!1}):a===ea?n:(s[a]||(s[a]=e([...t,a])),s[a])},set:(s,a,i)=>(s[a]=i,!0)})}return e([])}function ze(r){let{endpoint:e,tap:t=new oe}=r,n=1;return ws(async(s,a,i)=>{let o=i.notify??r.notify??!1,c=i.transfer,l={jsonrpc:"2.0",method:s.join("."),params:a},u=o?l:{...l,id:n++};t.rpcRequest({request:u});let d=await e(u,{transfer:c});if(o&&!d)return null;if(!d)throw new Re("response was null, but shouldn't be, because the request was not a notification");if("error"in d)throw new Re(r.label?`${r.label}: ${d.error.message}`:d.error.message);return d.result})}function It(r){return ze({endpoint:ar(r),tap:r.tap})}var Me=class{recv=sr();sendRequest=sr();sendResponse=sr();static makeEntangledPair({origin:e="example.e280.org"}={}){let t=new this,n=new this,s=[t.sendRequest.sub(i=>n.recv(i,{origin:e})),t.sendResponse.sub(i=>n.recv(i,{origin:e})),n.sendRequest.sub(i=>t.recv(i,{origin:e})),n.sendResponse.sub(i=>t.recv(i,{origin:e}))];return[t,n,()=>s.forEach(i=>i())]}};function or(r,e){return r.addEventListener("message",e),()=>r.removeEventListener("message",e)}function Ss(r,e){return async(t,{transfer:n}={})=>{if("id"in t){let s=Be();return e(t,n,s.promise),r.wait(t.id,t.method).then(a=>(s.resolve(a),a))}else{let s=Promise.resolve(null);return e(t,n,s),s}}}function Ts(r){let e=[],t=[];for(let n of Array.isArray(r)?r:[r])"method"in n?e.push(n):t.push(n);return{requests:e,responses:t}}async function Ps(r,e){let t=(await Promise.all(e.map(async n=>r(n)))).filter(n=>n!==null);return t.length===0?null:t.length===1?t[0]:t}var Qe=class extends Me{#e=new fe;constructor(e){super(),this.#e.add(this.sendRequest.sub((t,n)=>e.postMessage(t,n)),this.sendResponse.sub((t,n)=>e.postMessage(t,n)),or(e,t=>this.recv(t.data,t)))}dispose(){this.#e.dispose()}};var cr=class{remote;transfer;constructor(e){this.remote=e}};var bn=Object.freeze({timeout:6e4,maxRequestBytes:1e7});var lr=class{timeout;pending=new Map;constructor(e){this.timeout=e}async wait(e,t){let n=Be();return this.pending.set(e,{method:t,deferred:n}),await nr(this.timeout,()=>n.promise).catch(s=>{throw s instanceof vt&&(s.message=`request #${e} ${t}(), ${s.message}`),s})}deliverResponse(e){let t=this.pending.get(e.id);t&&("error"in e?t.deferred.reject(new Re(e.error.message)):t.deferred.resolve(e))}};var Ne=class{options;remote;remoteEndpoint;#e;#t=new fe;constructor(e){this.options=e;let{conduit:t,tap:n}=e;this.#e=new lr(e.timeout??bn.timeout),this.remoteEndpoint=Ss(this.#e,t.sendRequest.pub.bind(t.sendRequest)),this.remote=ze({endpoint:this.remoteEndpoint,tap:n&&un(n,{remote:!0})}),this.#t.add(t.recv.sub(s=>this.recv(s)))}async recv(e){let t=new cr(this.remote),{conduit:n,rpc:s,tap:a}=this.options,{requests:i,responses:o}=Ts(e);for(let d of o)this.#e.deliverResponse(d);if(!s)return;let c=await s(t),l=ar({fns:c,tap:a&&un(a,{remote:!1})}),u=await Ps(l,i);u&&await n.sendResponse(u,t.transfer)}dispose(){this.#t.dispose()}};var me={derive:{host:r=>({host:r.remote.host,get transfer(){return r.transfer},set transfer(e){r.transfer=e}}),work:r=>({work:r.remote,get transfer(){return r.transfer},set transfer(e){r.transfer=e}})},mock:{host:()=>({host:void 0,transfer:void 0}),work:()=>({work:void 0,transfer:void 0})}};var he=new oe;async function Cs(r,e,t={}){let n=t.tap??he,s=new Ne({tap:n,timeout:t.timeout??1/0,conduit:new Qe(r.getSelf()),rpc:async a=>e(me.derive.host(a))});return await s.remote.infra.ready(),s.remote.host}var le=Object.freeze({eq(r,e){if(r.length!==e.length)return!1;for(let t=0;t<=r.length;t++)if(r.at(t)!==e.at(t))return!1;return!0},random(r){return crypto.getRandomValues(new Uint8Array(r))}});var Ve=Object.freeze({fromBytes(r){return[...r].map(e=>e.toString(16).padStart(2,"0")).join("")},toBytes(r){if(r.length%2!==0)throw new Error("must have even number of hex characters");let e=new Uint8Array(r.length/2);for(let t=0;t<r.length;t+=2)e[t/2]=parseInt(r.slice(t,t+2),16);return e},random(r=32){return this.fromBytes(le.random(r))},string(r){return Ve.fromBytes(r)},bytes(r){return Ve.toBytes(r)}});var yn=58,ur="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz",kn=Object.freeze({fromBytes(r){let e=BigInt("0x"+Ve.fromBytes(r)),t="";for(;e>0;){let n=e%BigInt(yn);e=e/BigInt(yn),t=ur[Number(n)]+t}for(let n of r)if(n===0)t=ur[0]+t;else break;return t},toBytes(r){let e=BigInt(0);for(let i of r){let o=ur.indexOf(i);if(o===-1)throw new Error(`Invalid character '${i}' in base58 string`);e=e*BigInt(yn)+BigInt(o)}let t=e.toString(16);t.length%2!==0&&(t="0"+t);let n=Ve.toBytes(t),s=0;for(let i of r)if(i===ur[0])s++;else break;let a=new Uint8Array(s+n.length);return a.set(n,s),a},random(r=32){return this.fromBytes(le.random(r))},string(r){return kn.fromBytes(r)},bytes(r){return kn.toBytes(r)}});var vs=class{lexicon;static lexicons=Object.freeze({base2:{characters:"01"},hex:{characters:"0123456789abcdef"},base36:{characters:"0123456789abcdefghijklmnopqrstuvwxyz"},base58:{characters:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"},base62:{characters:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"},base64url:{negativePrefix:"~",characters:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_"},base64:{characters:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",padding:{character:"=",size:4}}});lookup;negativePrefix;constructor(e){this.lexicon=e,this.lookup=Object.fromEntries([...e.characters].map((t,n)=>[t,n])),this.negativePrefix=e.negativePrefix??"-"}toBytes(e){let t=Math.log2(this.lexicon.characters.length);if(Number.isInteger(t)){let o=0,c=0,l=[];for(let u of e){if(u===this.lexicon.padding?.character)continue;let d=this.lookup[u];if(d===void 0)throw new Error(`Invalid character: ${u}`);for(o=o<<t|d,c+=t;c>=8;)c-=8,l.push(o>>c&255)}return new Uint8Array(l)}let n=0n,s=BigInt(this.lexicon.characters.length),a=!1;e.startsWith(this.negativePrefix)&&(e=e.slice(this.negativePrefix.length),a=!0);for(let o of e){let c=this.lookup[o];if(c===void 0)throw new Error(`Invalid character: ${o}`);n=n*s+BigInt(c)}let i=[];for(;n>0n;)i.unshift(Number(n%256n)),n=n/256n;return new Uint8Array(i)}fromBytes(e){let t=Math.log2(this.lexicon.characters.length);if(Number.isInteger(t)){let i=0,o=0,c="";for(let l of e)for(i=i<<8|l,o+=8;o>=t;){o-=t;let u=i>>o&(1<<t)-1;c+=this.lexicon.characters[u]}if(o>0){let l=i<<t-o&(1<<t)-1;c+=this.lexicon.characters[l]}if(this.lexicon.padding)for(;c.length%this.lexicon.padding.size!==0;)c+=this.lexicon.padding.character;return c}let n=0n;for(let i of e)n=(n<<8n)+BigInt(i);if(n===0n)return this.lexicon.characters[0];let s=BigInt(this.lexicon.characters.length),a="";for(;n>0n;)a=this.lexicon.characters[Number(n%s)]+a,n=n/s;return a}toInteger(e){if(!e)return 0;let t=0n,n=!1,s=BigInt(this.lexicon.characters.length);e.startsWith(this.negativePrefix)&&(e=e.slice(this.negativePrefix.length),n=!0);for(let a of e){let i=this.lookup[a];if(i===void 0)throw new Error(`Invalid character: ${a}`);t=t*s+BigInt(i)}return Number(n?-t:t)}fromInteger(e){e=Math.floor(e);let t=e<0,n=BigInt(t?-e:e);if(n===0n)return this.lexicon.characters[0];let s=BigInt(this.lexicon.characters.length),a="";for(;n>0n;)a=this.lexicon.characters[Number(n%s)]+a,n=n/s;return t?`${this.negativePrefix}${a}`:a}random(e=32){return this.fromBytes(le.random(e))}};var xn=Object.freeze({fromBytes(r){return typeof btoa=="function"?btoa(String.fromCharCode(...r)):Buffer.from(r).toString("base64")},toBytes(r){return typeof atob=="function"?Uint8Array.from(atob(r),e=>e.charCodeAt(0)):Uint8Array.from(Buffer.from(r,"base64"))},random(r=32){return this.fromBytes(le.random(r))},string(r){return xn.fromBytes(r)},bytes(r){return xn.toBytes(r)}});var Is=Object.freeze({fromBytes(r){return new TextDecoder().decode(r)},toBytes(r){return new TextEncoder().encode(r)},string(r){return Is.fromBytes(r)},bytes(r){return Is.toBytes(r)}});var wn=Object.freeze({set:r=>r!=null,unset:r=>r==null,boolean:r=>typeof r=="boolean",number:r=>typeof r=="number",string:r=>typeof r=="string",bigint:r=>typeof r=="bigint",object:r=>typeof r=="object"&&r!==null,array:r=>Array.isArray(r),fn:r=>typeof r=="function",symbol:r=>typeof r=="symbol"});function Es(r){let e=Promise.resolve();return(...t)=>{let n=()=>r(...t),s=e.then(n);return e=s.catch(()=>{}),s}}function _s(...r){return(...e)=>r.forEach(t=>t(...e))}function Ze(){let r,e,t=new Promise((s,a)=>{r=s,e=a});function n(s){return s.then(r).catch(e),t}return{promise:t,resolve:r,reject:e,entangle:n}}function sa(r){return{map:e=>As(r,e),filter:e=>Fs(r,e)}}sa.pipe=Object.freeze({map:r=>e=>As(e,r),filter:r=>e=>Fs(e,r)});var As=(r,e)=>Object.fromEntries(Object.entries(r).map(([t,n])=>[t,e(n,t)])),Fs=(r,e)=>Object.fromEntries(Object.entries(r).filter(([t,n])=>e(n,t)));function ia(){let r=new Set;function e(a){return r.add(a),()=>{r.delete(a)}}async function t(...a){await Promise.all([...r].map(i=>i(...a)))}async function n(){let{promise:a,resolve:i}=Ze(),o=e((...c)=>{i(c),o()});return a}function s(){r.clear()}return e.pub=t,e.sub=e,e.on=e,e.next=n,e.clear=s,t.pub=t,t.sub=e,t.on=e,t.next=n,t.clear=s,[t,e]}function Sn(r){let e=ia()[1];return r&&e.sub(r),e}var Ye=class{worker;messenger;constructor(e,t){this.worker=e,this.messenger=t}static async make(e,t){let n=t.tap??he,s=t.label??"comrade",a=e.loadWorker(t.workerUrl,s),i=Ze(),o={async ready(){i.resolve()}},c=new Ne({tap:n,timeout:t.timeout??1/0,conduit:new Qe(a),rpc:async l=>({infra:o,host:t.setupHost(me.derive.work(l))})});return await i.promise,new this(a,c)}get work(){return this.messenger.remote}terminate(){this.worker.terminate()}};var dr=class{threads;static async make(e,t){let n=t.workerCount??e.guessOptimalThreadCount(),s=await Promise.all([...Array(n)].map(async(a,i)=>Ye.make(e,{...t,label:t.label??`${t.label??"comrade"}_${i+1}`})));return new this(s,{tap:t.tap})}work;#e=new Set;#t=[];constructor(e,t={}){this.threads=e;let n=t.tap??he,s=async(a,i)=>this.#r({request:a,prom:Ze(),transfer:i?.transfer});this.work=ze({tap:n,endpoint:s}),e.forEach(a=>this.#e.add(a))}get threadCount(){return this.threads.length}terminate(){for(let e of this.threads)e.terminate()}#r(e){return this.#t.push(e),this.#n(),e.prom.promise}#n(){for(;this.#e.size>0&&this.#t.length>0;){let e=[...this.#e].pop();this.#e.delete(e);let t=this.#t.shift();this.#e.delete(e);let n=e.messenger.remoteEndpoint(t.request,{transfer:t.transfer});t.prom.entangle(n).finally(()=>{this.#e.add(e),this.#n()})}}};var Ds=r=>({thread:e=>Ye.make(r,e),cluster:e=>dr.make(r,e),worker:(e,t={})=>Cs(r,e,t),work:e=>e,host:e=>e,mocks(e){let{setupWork:t,setupHost:n,tap:s=he}=e,a=me.mock.host(),i=me.mock.work();return i.work=It({tap:s,fns:t(a)}),a.host=It({tap:s,fns:n(i)}),{workShell:i,hostShell:a,work:i.work,host:a.host}},mockWork(e,t=he){let n=me.mock.host(),s=me.mock.work();return s.work=It({tap:t,fns:e(n)}),{workShell:s,hostShell:n,work:s.work,mockHost:a=>(n.host=It({tap:t,fns:a(s)}),{workShell:s,hostShell:n,work:s.work,host:n.host})}}});var Bs=()=>({getSelf(){return self},guessOptimalThreadCount(){let r=navigator.hardwareConcurrency??1;return Math.max(1,r-1)},loadWorker(r,e){return new window.Worker(r,{name:e,type:"module"})},async loadWasm(r){return WebAssembly.instantiateStreaming(fetch(r))}});var aa=Bs(),Je=Ds(aa);function b(r){if(!r)throw new Error("Assertion failed.")}var mr=r=>{let e=(r%360+360)%360;if(e===0||e===90||e===180||e===270)return e;throw new Error(`Invalid rotation ${r}.`)},W=r=>r&&r[r.length-1];var U=class r{constructor(e){this.bytes=e,this.pos=0}seekToByte(e){this.pos=8*e}readBit(){let e=Math.floor(this.pos/8),t=this.bytes[e]??0,n=7-(this.pos&7),s=(t&1<<n)>>n;return this.pos++,s}readBits(e){if(e===1)return this.readBit();let t=0;for(let n=0;n<e;n++)t<<=1,t|=this.readBit();return t}writeBits(e,t){let n=this.pos+e;for(let s=this.pos;s<n;s++){let a=Math.floor(s/8),i=this.bytes[a],o=7-(s&7);i&=~(1<<o),i|=(t&1<<n-s-1)>>n-s-1<<o,this.bytes[a]=i}this.pos=n}readAlignedByte(){if(this.pos%8!==0)throw new Error("Bitstream is not byte-aligned.");let e=this.pos/8,t=this.bytes[e]??0;return this.pos+=8,t}skipBits(e){this.pos+=e}getBitsLeft(){return this.bytes.length*8-this.pos}clone(){let e=new r(this.bytes);return e.pos=this.pos,e}},I=r=>{let e=0;for(;r.readBits(1)===0&&e<32;)e++;if(e>=32)throw new Error("Invalid exponential-Golomb code.");return(1<<e)-1+r.readBits(e)},et=r=>{let e=I(r);return(e&1)===0?-(e>>1):e+1>>1};var Pe=r=>r instanceof Uint8Array?r:r instanceof ArrayBuffer?new Uint8Array(r):new Uint8Array(r.buffer,r.byteOffset,r.byteLength),z=r=>r instanceof DataView?r:r instanceof ArrayBuffer?new DataView(r):new DataView(r.buffer,r.byteOffset,r.byteLength),G=new TextDecoder,oa=new TextEncoder;var Pn=r=>Object.fromEntries(Object.entries(r).map(([e,t])=>[t,e])),Cn={bt709:1,bt470bg:5,smpte170m:6,bt2020:9,smpte432:12},hr=Pn(Cn),vn={bt709:1,smpte170m:6,linear:8,"iec61966-2-1":13,pg:16,hlg:18},pr=Pn(vn),In={rgb:0,bt709:1,bt470bg:5,smpte170m:6,"bt2020-ncl":9},gr=Pn(In);var En=r=>r instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&r instanceof SharedArrayBuffer||ArrayBuffer.isView(r),ee=class{constructor(){this.currentPromise=Promise.resolve()}async acquire(){let e,t=new Promise(s=>{e=s}),n=this.currentPromise;return this.currentPromise=t,await n,e}},_n=r=>[...r].map(e=>e.toString(16).padStart(2,"0")).join(""),An=r=>(r=r>>1&1431655765|(r&1431655765)<<1,r=r>>2&858993459|(r&858993459)<<2,r=r>>4&252645135|(r&252645135)<<4,r=r>>8&16711935|(r&16711935)<<8,r=r>>16&65535|(r&65535)<<16,r>>>0),M=(r,e,t)=>{let n=0,s=r.length-1,a=-1;for(;n<=s;){let i=n+s>>1,o=t(r[i]);o===e?(a=i,s=i-1):o<e?n=i+1:s=i-1}return a},R=(r,e,t)=>{let n=0,s=r.length-1,a=-1;for(;n<=s;){let i=n+(s-n+1)/2|0;t(r[i])<=e?(a=i,n=i+1):s=i-1}return a},te=(r,e,t)=>{let n=R(r,t(e),t);r.splice(n+1,0,e)},X=()=>{let r,e;return{promise:new Promise((n,s)=>{r=n,e=s}),resolve:r,reject:e}};var Fn=(r,e)=>{for(let t=r.length-1;t>=0;t--)if(e(r[t]))return r[t]},br=(r,e)=>{for(let t=r.length-1;t>=0;t--)if(e(r[t]))return t;return-1},Rs=async function*(r){Symbol.iterator in r?yield*r[Symbol.iterator]():yield*r[Symbol.asyncIterator]()},Os=r=>{if(!(Symbol.iterator in r)&&!(Symbol.asyncIterator in r))throw new TypeError("Argument must be an iterable or async iterable.")},Et=r=>{throw new Error(`Unexpected value: ${r}`)};var Dn=(r,e)=>({async next(){let t=await r.next();return t.done?{value:void 0,done:!0}:{value:e(t.value),done:!1}},return(){return r.return()},throw(t){return r.throw(t)},[Symbol.asyncIterator](){return this}}),yr=(r,e,t)=>Math.max(e,Math.min(t,r)),q="und",Ue=(r,e)=>{let t=10**e;return Math.round(r*t)/t},zs=(r,e)=>Math.round(r/e)*e,Ms=r=>{let e=0;for(;r;)e++,r>>=1;return e},ca=/^[a-z]{3}$/,kr=r=>ca.test(r),Ce=1e6*(1+Number.EPSILON),xr=(r,e)=>{let t={...r};for(let n in e)typeof r[n]=="object"&&r[n]!==null&&typeof e[n]=="object"&&e[n]!==null?t[n]=xr(r[n],e[n]):t[n]=e[n];return t},Bn=async(r,e,t)=>{let n=0;for(;;)try{return await fetch(r,e)}catch(s){n++;let a=t(n);if(a===null)throw s;if(console.error("Retrying failed fetch. Error:",s),!Number.isFinite(a)||a<0)throw new TypeError("Retry delay must be a non-negative finite number.");a>0&&await new Promise(i=>setTimeout(i,1e3*a))}};var fr=class{constructor(){this.currentPromise=Promise.resolve()}call(e){return this.currentPromise=this.currentPromise.then(e)}},Tn=null,wr=()=>{if(Tn!==null)return Tn;let r=!!(typeof navigator<"u"&&navigator.vendor?.match(/apple/i)&&!navigator.userAgent?.match(/crios/i)&&!navigator.userAgent?.match(/fxios/i)&&!navigator.userAgent?.match(/Opera|OPT\//));return Tn=r,r},Le=(r,e)=>r!==-1?r:e,Sr=(r,e,t,n)=>r<=n&&t<=e;var Ns=r=>{let e=atob(r),t=new Uint8Array(e.length);for(let n=0;n<e.length;n++)t[n]=e.charCodeAt(n);return t};var ve=class{constructor(e,t){this.data=e,this.mimeType=t}};var At=["pcm-s16","pcm-s16be","pcm-s24","pcm-s24be","pcm-s32","pcm-s32be","pcm-f32","pcm-f32be","pcm-f64","pcm-f64be","pcm-u8","pcm-s8","ulaw","alaw"],la=["aac","opus","mp3","vorbis","flac"],fp=[...la,...At];var He=[{maxPictureSize:36864,maxBitrate:2e5,level:10},{maxPictureSize:73728,maxBitrate:8e5,level:11},{maxPictureSize:122880,maxBitrate:18e5,level:20},{maxPictureSize:245760,maxBitrate:36e5,level:21},{maxPictureSize:552960,maxBitrate:72e5,level:30},{maxPictureSize:983040,maxBitrate:12e6,level:31},{maxPictureSize:2228224,maxBitrate:18e6,level:40},{maxPictureSize:2228224,maxBitrate:3e7,level:41},{maxPictureSize:8912896,maxBitrate:6e7,level:50},{maxPictureSize:8912896,maxBitrate:12e7,level:51},{maxPictureSize:8912896,maxBitrate:18e7,level:52},{maxPictureSize:35651584,maxBitrate:18e7,level:60},{maxPictureSize:35651584,maxBitrate:24e7,level:61},{maxPictureSize:35651584,maxBitrate:48e7,level:62}];var Vs=".01.01.01.01.00",Us=".0.110.01.01.01.0";var Tr=r=>{let{codec:e,codecDescription:t,colorSpace:n,avcCodecInfo:s,hevcCodecInfo:a,vp9CodecInfo:i,av1CodecInfo:o}=r;if(e==="avc"){if(s){let c=new Uint8Array([s.avcProfileIndication,s.profileCompatibility,s.avcLevelIndication]);return`avc1.${_n(c)}`}if(!t||t.byteLength<4)throw new TypeError("AVC decoder description is not provided or is not at least 4 bytes long.");return`avc1.${_n(t.subarray(1,4))}`}else if(e==="hevc"){let c,l,u,d,f,m;if(a)c=a.generalProfileSpace,l=a.generalProfileIdc,u=An(a.generalProfileCompatibilityFlags),d=a.generalTierFlag,f=a.generalLevelIdc,m=[...a.generalConstraintIndicatorFlags];else{if(!t||t.byteLength<23)throw new TypeError("HEVC decoder description is not provided or is not at least 23 bytes long.");let g=z(t),y=g.getUint8(1);c=y>>6&3,l=y&31,u=An(g.getUint32(2)),d=y>>5&1,f=g.getUint8(12),m=[];for(let S=0;S<6;S++)m.push(g.getUint8(6+S))}let h="hev1.";for(h+=["","A","B","C"][c]+l,h+=".",h+=u.toString(16).toUpperCase(),h+=".",h+=d===0?"L":"H",h+=f;m.length>0&&m[m.length-1]===0;)m.pop();return m.length>0&&(h+=".",h+=m.map(g=>g.toString(16).toUpperCase()).join(".")),h}else{if(e==="vp8")return"vp8";if(e==="vp9"){if(!i){let S=r.width*r.height,p=W(He).level;for(let w of He)if(S<=w.maxPictureSize){p=w.level;break}return`vp09.00.${p.toString().padStart(2,"0")}.08`}let c=i.profile.toString().padStart(2,"0"),l=i.level.toString().padStart(2,"0"),u=i.bitDepth.toString().padStart(2,"0"),d=i.chromaSubsampling.toString().padStart(2,"0"),f=i.colourPrimaries.toString().padStart(2,"0"),m=i.transferCharacteristics.toString().padStart(2,"0"),h=i.matrixCoefficients.toString().padStart(2,"0"),g=i.videoFullRangeFlag.toString().padStart(2,"0"),y=`vp09.${c}.${l}.${u}.${d}`;return y+=`.${f}.${m}.${h}.${g}`,y.endsWith(Vs)&&(y=y.slice(0,-Vs.length)),y}else if(e==="av1"){if(!o){let w=r.width*r.height,k=W(He).level;for(let x of He)if(w<=x.maxPictureSize){k=x.level;break}return`av01.0.${k.toString().padStart(2,"0")}M.08`}let c=o.profile,l=o.level.toString().padStart(2,"0"),u=o.tier?"H":"M",d=o.bitDepth.toString().padStart(2,"0"),f=o.monochrome?"1":"0",m=100*o.chromaSubsamplingX+10*o.chromaSubsamplingY+1*(o.chromaSubsamplingX&&o.chromaSubsamplingY?o.chromaSamplePosition:0),h=n?.primaries?Cn[n.primaries]:1,g=n?.transfer?vn[n.transfer]:1,y=n?.matrix?In[n.matrix]:1,S=n?.fullRange?1:0,p=`av01.${c}.${l}${u}.${d}`;return p+=`.${f}.${m.toString().padStart(3,"0")}`,p+=`.${h.toString().padStart(2,"0")}`,p+=`.${g.toString().padStart(2,"0")}`,p+=`.${y.toString().padStart(2,"0")}`,p+=`.${S}`,p.endsWith(Us)&&(p=p.slice(0,-Us.length)),p}}throw new TypeError(`Unhandled codec '${e}'.`)};var Pr=r=>{let{codec:e,codecDescription:t,aacCodecInfo:n}=r;if(e==="aac"){if(!n)throw new TypeError("AAC codec info must be provided.");return n.isMpeg2?"mp4a.67":`mp4a.40.${On(t).objectType}`}else{if(e==="mp3")return"mp3";if(e==="opus")return"opus";if(e==="vorbis")return"vorbis";if(e==="flac")return"flac";if(e&&At.includes(e))return e}throw new TypeError(`Unhandled codec '${e}'.`)},_t=[96e3,88200,64e3,48e3,44100,32e3,24e3,22050,16e3,12e3,11025,8e3,7350],Rn=[-1,1,2,3,4,5,6,8],On=r=>{if(!r||r.byteLength<2)throw new TypeError("AAC description must be at least 2 bytes long.");let e=new U(r),t=e.readBits(5);t===31&&(t=32+e.readBits(6));let n=e.readBits(4),s=null;n===15?s=e.readBits(24):n<_t.length&&(s=_t[n]);let a=e.readBits(4),i=null;return a>=1&&a<=7&&(i=Rn[a]),{objectType:t,frequencyIndex:n,sampleRate:s,channelConfiguration:a,numberOfChannels:i}},Ls=48e3,ua=/^pcm-([usf])(\d+)+(be)?$/,Hs=r=>{if(b(At.includes(r)),r==="ulaw")return{dataType:"ulaw",sampleSize:1,littleEndian:!0,silentValue:255};if(r==="alaw")return{dataType:"alaw",sampleSize:1,littleEndian:!0,silentValue:213};let e=ua.exec(r);b(e);let t;e[1]==="u"?t="unsigned":e[1]==="s"?t="signed":t="float";let n=Number(e[2])/8,s=e[3]!=="be",a=r==="pcm-u8"?2**7:0;return{dataType:t,sampleSize:n,littleEndian:s,silentValue:a}};var tt;(function(r){r[r.IDR=5]="IDR",r[r.SPS=7]="SPS",r[r.PPS=8]="PPS",r[r.SPS_EXT=13]="SPS_EXT"})(tt||(tt={}));var Q;(function(r){r[r.RASL_N=8]="RASL_N",r[r.RASL_R=9]="RASL_R",r[r.BLA_W_LP=16]="BLA_W_LP",r[r.RSV_IRAP_VCL23=23]="RSV_IRAP_VCL23",r[r.VPS_NUT=32]="VPS_NUT",r[r.SPS_NUT=33]="SPS_NUT",r[r.PPS_NUT=34]="PPS_NUT",r[r.PREFIX_SEI_NUT=39]="PREFIX_SEI_NUT",r[r.SUFFIX_SEI_NUT=40]="SUFFIX_SEI_NUT"})(Q||(Q={}));var vr=r=>{let e=[],t=0;for(;t<r.length;){let n=-1,s=0;for(let a=t;a<r.length-3;a++){if(r[a]===0&&r[a+1]===0&&r[a+2]===1){n=a,s=3;break}if(a<r.length-4&&r[a]===0&&r[a+1]===0&&r[a+2]===0&&r[a+3]===1){n=a,s=4;break}}if(n===-1)break;if(t>0&&n>t){let a=r.subarray(t,n);a.length>0&&e.push(a)}t=n+s}if(t<r.length){let n=r.subarray(t);n.length>0&&e.push(n)}return e},qs=(r,e)=>{let t=[],n=0,s=new DataView(r.buffer,r.byteOffset,r.byteLength);for(;n+e<=r.length;){let a;e===1?a=s.getUint8(n):e===2?a=s.getUint16(n,!1):e===3?a=(s.getUint16(n,!1)<<8)+s.getUint8(n+2):e===4?a=s.getUint32(n,!1):(Et(e),b(!1)),n+=e;let i=r.subarray(n,n+a);t.push(i),n+=a}return t},zn=r=>{let e=[],t=r.length;for(let n=0;n<t;n++)n+2<t&&r[n]===0&&r[n+1]===0&&r[n+2]===3?(e.push(0,0),n+=2):e.push(r[n]);return new Uint8Array(e)};var da=(r,e)=>{if(e.description){let s=(Pe(e.description)[4]&3)+1;return qs(r,s)}else return vr(r)},Cr=r=>r[0]&31,js=r=>{try{let e=vr(r),t=e.filter(f=>Cr(f)===tt.SPS),n=e.filter(f=>Cr(f)===tt.PPS),s=e.filter(f=>Cr(f)===tt.SPS_EXT);if(t.length===0||n.length===0)return null;let a=t[0],i=new U(zn(a));if(i.skipBits(1),i.skipBits(2),i.readBits(5)!==7)return console.error("Invalid SPS NAL unit type"),null;let c=i.readAlignedByte(),l=i.readAlignedByte(),u=i.readAlignedByte(),d={configurationVersion:1,avcProfileIndication:c,profileCompatibility:l,avcLevelIndication:u,lengthSizeMinusOne:3,sequenceParameterSets:t,pictureParameterSets:n,chromaFormat:null,bitDepthLumaMinus8:null,bitDepthChromaMinus8:null,sequenceParameterSetExt:null};if(c===100||c===110||c===122||c===144){I(i);let f=I(i);f===3&&i.skipBits(1);let m=I(i),h=I(i);d.chromaFormat=f,d.bitDepthLumaMinus8=m,d.bitDepthChromaMinus8=h,d.sequenceParameterSetExt=s}return d}catch(e){return console.error("Error building AVC Decoder Configuration Record:",e),null}};var Mn=(r,e)=>{if(e.description){let s=(Pe(e.description)[21]&3)+1;return qs(r,s)}else return vr(r)},pe=r=>r[0]>>1&63,$s=r=>{try{let e=vr(r),t=e.filter(_=>pe(_)===Q.VPS_NUT),n=e.filter(_=>pe(_)===Q.SPS_NUT),s=e.filter(_=>pe(_)===Q.PPS_NUT),a=e.filter(_=>pe(_)===Q.PREFIX_SEI_NUT||pe(_)===Q.SUFFIX_SEI_NUT);if(n.length===0||s.length===0)return null;let i=n[0],o=new U(zn(i));o.skipBits(16),o.readBits(4);let c=o.readBits(3),l=o.readBits(1),{general_profile_space:u,general_tier_flag:d,general_profile_idc:f,general_profile_compatibility_flags:m,general_constraint_indicator_flags:h,general_level_idc:g}=fa(o,c);I(o);let y=I(o);y===3&&o.skipBits(1),I(o),I(o),o.readBits(1)&&(I(o),I(o),I(o),I(o));let S=I(o),p=I(o);I(o);let k=o.readBits(1)?0:c;for(let _=k;_<=c;_++)I(o),I(o),I(o);I(o),I(o),I(o),I(o),I(o),I(o),o.readBits(1)&&o.readBits(1)&&ma(o),o.skipBits(1),o.skipBits(1),o.readBits(1)&&(o.skipBits(4),o.skipBits(4),I(o),I(o),o.skipBits(1));let x=I(o);if(ha(o,x),o.readBits(1)){let _=I(o);for(let B=0;B<_;B++)I(o),o.skipBits(1)}o.skipBits(1),o.skipBits(1);let C=0;o.readBits(1)&&(C=ga(o,c));let v=0;if(s.length>0){let _=s[0],B=new U(zn(_));B.skipBits(16),I(B),I(B),B.skipBits(1),B.skipBits(1),B.skipBits(3),B.skipBits(1),B.skipBits(1),I(B),I(B),et(B),B.skipBits(1),B.skipBits(1),B.readBits(1)&&I(B),et(B),et(B),B.skipBits(1),B.skipBits(1),B.skipBits(1),B.skipBits(1);let L=B.readBits(1),Fe=B.readBits(1);!L&&!Fe?v=0:L&&!Fe?v=2:!L&&Fe?v=3:v=0}let F=[...t.length?[{arrayCompleteness:1,nalUnitType:Q.VPS_NUT,nalUnits:t}]:[],...n.length?[{arrayCompleteness:1,nalUnitType:Q.SPS_NUT,nalUnits:n}]:[],...s.length?[{arrayCompleteness:1,nalUnitType:Q.PPS_NUT,nalUnits:s}]:[],...a.length?[{arrayCompleteness:1,nalUnitType:pe(a[0]),nalUnits:a}]:[]];return{configurationVersion:1,generalProfileSpace:u,generalTierFlag:d,generalProfileIdc:f,generalProfileCompatibilityFlags:m,generalConstraintIndicatorFlags:h,generalLevelIdc:g,minSpatialSegmentationIdc:C,parallelismType:v,chromaFormatIdc:y,bitDepthLumaMinus8:S,bitDepthChromaMinus8:p,avgFrameRate:0,constantFrameRate:0,numTemporalLayers:c+1,temporalIdNested:l,lengthSizeMinusOne:3,arrays:F}}catch(e){return console.error("Error building HEVC Decoder Configuration Record:",e),null}},fa=(r,e)=>{let t=r.readBits(2),n=r.readBits(1),s=r.readBits(5),a=0;for(let u=0;u<32;u++)a=a<<1|r.readBits(1);let i=new Uint8Array(6);for(let u=0;u<6;u++)i[u]=r.readBits(8);let o=r.readBits(8),c=[],l=[];for(let u=0;u<e;u++)c.push(r.readBits(1)),l.push(r.readBits(1));if(e>0)for(let u=e;u<8;u++)r.skipBits(2);for(let u=0;u<e;u++)c[u]&&r.skipBits(88),l[u]&&r.skipBits(8);return{general_profile_space:t,general_tier_flag:n,general_profile_idc:s,general_profile_compatibility_flags:a,general_constraint_indicator_flags:i,general_level_idc:o}},ma=r=>{for(let e=0;e<4;e++)for(let t=0;t<(e===3?2:6);t++)if(!r.readBits(1))I(r);else{let s=Math.min(64,1<<4+(e<<1));e>1&&et(r);for(let a=0;a<s;a++)et(r)}},ha=(r,e)=>{let t=[];for(let n=0;n<e;n++)t[n]=pa(r,n,e,t)},pa=(r,e,t,n)=>{let s=0,a=0,i=0;if(e!==0&&(a=r.readBits(1)),a){if(e===t){let c=I(r);i=e-(c+1)}else i=e-1;r.readBits(1),I(r);let o=n[i]??0;for(let c=0;c<=o;c++)r.readBits(1)||r.readBits(1);s=n[i]}else{let o=I(r),c=I(r);for(let l=0;l<o;l++)I(r),r.readBits(1);for(let l=0;l<c;l++)I(r),r.readBits(1);s=o+c}return s},ga=(r,e)=>{if(r.readBits(1)&&r.readBits(8)===255&&(r.readBits(16),r.readBits(16)),r.readBits(1)&&r.readBits(1),r.readBits(1)&&(r.readBits(3),r.readBits(1),r.readBits(1)&&(r.readBits(8),r.readBits(8),r.readBits(8))),r.readBits(1)&&(I(r),I(r)),r.readBits(1),r.readBits(1),r.readBits(1),r.readBits(1)&&(I(r),I(r),I(r),I(r)),r.readBits(1)&&(r.readBits(32),r.readBits(32),r.readBits(1)&&I(r),r.readBits(1)&&ba(r,!0,e)),r.readBits(1)){r.readBits(1),r.readBits(1),r.readBits(1);let t=I(r);return I(r),I(r),I(r),I(r),t}return 0},ba=(r,e,t)=>{let n=!1,s=!1,a=!1;e&&(n=r.readBits(1)===1,s=r.readBits(1)===1,(n||s)&&(a=r.readBits(1)===1,a&&(r.readBits(8),r.readBits(5),r.readBits(1),r.readBits(5)),r.readBits(4),r.readBits(4),a&&r.readBits(4),r.readBits(5),r.readBits(5),r.readBits(5)));for(let i=0;i<=t;i++){let o=r.readBits(1)===1,c=!0;o||(c=r.readBits(1)===1);let l=!1;c?I(r):l=r.readBits(1)===1;let u=1;l||(u=I(r)+1),n&&Ws(r,u,a),s&&Ws(r,u,a)}},Ws=(r,e,t)=>{for(let n=0;n<e;n++)I(r),I(r),t&&(I(r),I(r)),r.readBits(1)};var Ir=r=>{let e=new U(r);if(e.readBits(2)!==2)return null;let n=e.readBits(1),a=(e.readBits(1)<<1)+n;if(a===3&&e.skipBits(1),e.readBits(1)===1||e.readBits(1)!==0||(e.skipBits(2),e.readBits(24)!==4817730))return null;let l=8;a>=2&&(l=e.readBits(1)?12:10);let u=e.readBits(3),d=0,f=0;if(u!==7)if(f=e.readBits(1),a===1||a===3){let v=e.readBits(1),F=e.readBits(1);d=!v&&!F?3:v&&!F?2:1,e.skipBits(1)}else d=1;else d=3,f=1;let m=e.readBits(16),h=e.readBits(16),g=m+1,y=h+1,S=g*y,p=W(He).level;for(let C of He)if(S<=C.maxPictureSize){p=C.level;break}return{profile:a,level:p,bitDepth:l,chromaSubsampling:d,videoFullRangeFlag:f,colourPrimaries:u===2?1:u===1?6:2,transferCharacteristics:u===2?1:u===1?6:2,matrixCoefficients:u===7?0:u===2?1:u===1?6:2}},Ks=function*(r){let e=new U(r),t=()=>{let n=0;for(let s=0;s<8;s++){let a=e.readAlignedByte();if(n|=(a&127)<<s*7,!(a&128))break;if(s===7&&a&128)return null}return n>=2**32-1?null:n};for(;e.getBitsLeft()>=8;){e.skipBits(1);let n=e.readBits(4),s=e.readBits(1),a=e.readBits(1);e.skipBits(1),s&&e.skipBits(8);let i;if(a){let o=t();if(o===null)return;i=o}else i=Math.floor(e.getBitsLeft()/8);b(e.pos%8===0),yield{type:n,data:r.subarray(e.pos/8,e.pos/8+i)},e.skipBits(i*8)}},Er=r=>{for(let{type:e,data:t}of Ks(r)){if(e!==1)continue;let n=new U(t),s=n.readBits(3),a=n.readBits(1),i=n.readBits(1),o=0,c=0,l=0;if(i)o=n.readBits(5);else{if(n.readBits(1)&&(n.skipBits(32),n.skipBits(32),n.readBits(1)))return null;let S=n.readBits(1);S&&(l=n.readBits(5),n.skipBits(32),n.skipBits(5),n.skipBits(5));let p=n.readBits(5);for(let w=0;w<=p;w++){n.skipBits(12);let k=n.readBits(5);if(w===0&&(o=k),k>7){let C=n.readBits(1);w===0&&(c=C)}if(S&&n.readBits(1)){let v=l+1;n.skipBits(v),n.skipBits(v),n.skipBits(1)}n.readBits(1)&&n.skipBits(4)}}let u=n.readBits(1),d=8;s===2&&u?d=n.readBits(1)?12:10:s<=2&&(d=u?10:8);let f=0;s!==1&&(f=n.readBits(1));let m=1,h=1,g=0;return f||(s===0?(m=1,h=1):s===1?(m=0,h=0):d===12&&(m=n.readBits(1),m&&(h=n.readBits(1))),m&&h&&(g=n.readBits(2))),{profile:s,level:o,tier:c,bitDepth:d,monochrome:f,chromaSubsamplingX:m,chromaSubsamplingY:h,chromaSamplePosition:g}}return null},Gs=r=>{let e=z(r),t=e.getUint8(9),n=e.getUint16(10,!0),s=e.getUint32(12,!0),a=e.getInt16(16,!0),i=e.getUint8(18),o=null;return i&&(o=r.subarray(19,21+t)),{outputChannelCount:t,preSkip:n,inputSampleRate:s,outputGain:a,channelMappingFamily:i,channelMappingTable:o}},ya=[480,960,1920,2880,480,960,1920,2880,480,960,1920,2880,480,960,480,960,120,240,480,960,120,240,480,960,120,240,480,960,120,240,480,960],Xs=r=>{let e=r[0]>>3;return{durationInSamples:ya[e]}},Qs=r=>{if(r.length<7)throw new Error("Setup header is too short.");if(r[0]!==5)throw new Error("Wrong packet type in Setup header.");if(String.fromCharCode(...r.slice(1,7))!=="vorbis")throw new Error("Invalid packet signature in Setup header.");let t=r.length,n=new Uint8Array(t);for(let d=0;d<t;d++)n[d]=r[t-1-d];let s=new U(n),a=0;for(;s.getBitsLeft()>97;)if(s.readBits(1)===1){a=s.pos;break}if(a===0)throw new Error("Invalid Setup header: framing bit not found.");let i=0,o=!1,c=0;for(;s.getBitsLeft()>=97;){let d=s.pos,f=s.readBits(8),m=s.readBits(16),h=s.readBits(16);if(f>63||m!==0||h!==0){s.pos=d;break}if(s.skipBits(1),i++,i>64)break;s.clone().readBits(6)+1===i&&(o=!0,c=i)}if(!o)throw new Error("Invalid Setup header: mode header not found.");if(c>63)throw new Error(`Unsupported mode count: ${c}.`);let l=c;s.pos=0,s.skipBits(a);let u=Array(l).fill(0);for(let d=l-1;d>=0;d--)s.skipBits(40),u[d]=s.readBits(1);return{modeBlockflags:u}},Zs=async(r,e)=>{switch(b(r.codec),r.codec){case"avc":{let t=await r.getDecoderConfig();return b(t),da(e.data,t).some(a=>Cr(a)===tt.IDR)?"key":"delta"}case"hevc":{let t=await r.getDecoderConfig();return b(t),Mn(e.data,t).some(a=>{let i=pe(a);return Q.BLA_W_LP<=i&&i<=Q.RSV_IRAP_VCL23})?"key":"delta"}case"vp8":return(e.data[0]&1)===0?"key":"delta";case"vp9":{let t=new U(e.data);if(t.readBits(2)!==2)return null;let n=t.readBits(1);return(t.readBits(1)<<1)+n===3&&t.skipBits(1),t.readBits(1)?null:t.readBits(1)===0?"key":"delta"}case"av1":{let t=!1;for(let{type:n,data:s}of Ks(e.data))if(n===1){let a=new U(s);a.skipBits(4),t=!!a.readBits(1)}else if(n===3||n===6||n===7){if(t)return"key";let a=new U(s);return a.readBits(1)?null:a.readBits(2)===0?"key":"delta"}return null}default:Et(r.codec),b(!1)}};var Ys=r=>{let t=(r.hasVideo?"video/":r.hasAudio?"audio/":"application/")+(r.isQuickTime?"quicktime":"mp4");if(r.codecStrings.length>0){let n=[...new Set(r.codecStrings)];t+=`; codecs="${n.join(", ")}"`}return t};var _r=class{constructor(e){this.source=e}requestSlice(e,t){if(this.fileSize!==null&&e+t>this.fileSize)return null;let n=e+t,s=this.source._read(e,n);return s instanceof Promise?s.then(a=>a?new rt(a.bytes,a.view,a.offset,e,n):null):s?new rt(s.bytes,s.view,s.offset,e,n):null}requestSliceRange(e,t,n){if(this.fileSize!==null)return this.requestSlice(e,yr(this.fileSize-e,t,n));{let s=this.requestSlice(e,n),a=i=>{if(i)return i;let o=l=>(b(l!==null),this.requestSlice(e,yr(l-e,t,n))),c=this.source._retrieveSize();return c instanceof Promise?c.then(o):o(c)};return s instanceof Promise?s.then(a):a(s)}}},rt=class r{constructor(e,t,n,s,a){this.bytes=e,this.view=t,this.offset=n,this.start=s,this.end=a,this.bufferPos=s-n}static tempFromBytes(e){return new r(e,z(e),0,0,e.length)}get length(){return this.end-this.start}get filePos(){return this.offset+this.bufferPos}set filePos(e){this.bufferPos=e-this.offset}skip(e){this.bufferPos+=e}slice(e,t=this.end-e){if(e<this.start||e+t>this.end)throw new RangeError("Slicing outside of original slice.");return new r(this.bytes,this.view,this.offset,e,e+t)}},D=(r,e)=>{let t=r.bytes.subarray(r.bufferPos,r.bufferPos+e);return r.bufferPos+=e,t},E=r=>r.view.getUint8(r.bufferPos++),nt=(r,e)=>{let t=r.view.getUint16(r.bufferPos,e);return r.bufferPos+=2,t},j=r=>{let e=r.view.getUint16(r.bufferPos,!1);return r.bufferPos+=2,e},st=r=>{let e=j(r),t=E(r);return e*256+t},Ft=r=>{let e=r.view.getInt16(r.bufferPos,!1);return r.bufferPos+=2,e},ge=(r,e)=>{let t=r.view.getUint32(r.bufferPos,e);return r.bufferPos+=4,t},P=r=>{let e=r.view.getUint32(r.bufferPos,!1);return r.bufferPos+=4,e},We=r=>{let e=r.view.getUint32(r.bufferPos,!0);return r.bufferPos+=4,e},be=r=>{let e=r.view.getInt32(r.bufferPos,!1);return r.bufferPos+=4,e},ka=r=>{let e=r.view.getInt32(r.bufferPos,!0);return r.bufferPos+=4,e},Nn=(r,e)=>{let t,n;return e?(t=ge(r,!0),n=ge(r,!0)):(n=ge(r,!1),t=ge(r,!1)),n*4294967296+t},J=r=>{let e=P(r),t=P(r);return e*4294967296+t},Js=r=>{let e=be(r),t=P(r);return e*4294967296+t},ei=r=>{let e=We(r);return ka(r)*4294967296+e},ti=r=>{let e=r.view.getFloat32(r.bufferPos,!1);return r.bufferPos+=4,e},Ar=r=>{let e=r.view.getFloat64(r.bufferPos,!1);return r.bufferPos+=8,e},V=(r,e)=>{if(r.bufferPos+e>r.bytes.length)throw new RangeError("Reading past end of slice.");let t="";for(let n=0;n<e;n++)t+=String.fromCharCode(r.bytes[r.bufferPos++]);return t};var ye=8,qe=16,ue=r=>{let e=P(r),t=V(r,4),n=8;e===1&&(e=J(r),n=16);let a=e-n;return a<0?null:{name:t,totalSize:e,headerSize:n,contentSize:a}},Ie=r=>be(r)/65536,Fr=r=>be(r)/1073741824,Dr=r=>{let e=0;for(let t=0;t<4;t++){e<<=7;let n=E(r);if(e|=n&127,(n&128)===0)break}return e},re=r=>{let e=j(r);return r.skip(2),G.decode(D(r,e))},ri=r=>{let e=ue(r);if(!e||e.name!=="data")return null;let t=P(r);r.skip(4);let n=D(r,e.contentSize-8);switch(t){case 1:return G.decode(n);case 2:return new TextDecoder("utf-16be").decode(n);case 13:return new ve(n,"image/jpeg");case 14:return new ve(n,"image/png");case 27:return new ve(n,"image/bmp");default:return n}};var T;(function(r){r[r.EBML=440786851]="EBML",r[r.EBMLVersion=17030]="EBMLVersion",r[r.EBMLReadVersion=17143]="EBMLReadVersion",r[r.EBMLMaxIDLength=17138]="EBMLMaxIDLength",r[r.EBMLMaxSizeLength=17139]="EBMLMaxSizeLength",r[r.DocType=17026]="DocType",r[r.DocTypeVersion=17031]="DocTypeVersion",r[r.DocTypeReadVersion=17029]="DocTypeReadVersion",r[r.Void=236]="Void",r[r.Segment=408125543]="Segment",r[r.SeekHead=290298740]="SeekHead",r[r.Seek=19899]="Seek",r[r.SeekID=21419]="SeekID",r[r.SeekPosition=21420]="SeekPosition",r[r.Duration=17545]="Duration",r[r.Info=357149030]="Info",r[r.TimestampScale=2807729]="TimestampScale",r[r.MuxingApp=19840]="MuxingApp",r[r.WritingApp=22337]="WritingApp",r[r.Tracks=374648427]="Tracks",r[r.TrackEntry=174]="TrackEntry",r[r.TrackNumber=215]="TrackNumber",r[r.TrackUID=29637]="TrackUID",r[r.TrackType=131]="TrackType",r[r.FlagEnabled=185]="FlagEnabled",r[r.FlagDefault=136]="FlagDefault",r[r.FlagForced=21930]="FlagForced",r[r.FlagLacing=156]="FlagLacing",r[r.Name=21358]="Name",r[r.Language=2274716]="Language",r[r.LanguageBCP47=2274717]="LanguageBCP47",r[r.CodecID=134]="CodecID",r[r.CodecPrivate=25506]="CodecPrivate",r[r.CodecDelay=22186]="CodecDelay",r[r.SeekPreRoll=22203]="SeekPreRoll",r[r.DefaultDuration=2352003]="DefaultDuration",r[r.Video=224]="Video",r[r.PixelWidth=176]="PixelWidth",r[r.PixelHeight=186]="PixelHeight",r[r.Audio=225]="Audio",r[r.SamplingFrequency=181]="SamplingFrequency",r[r.Channels=159]="Channels",r[r.BitDepth=25188]="BitDepth",r[r.SimpleBlock=163]="SimpleBlock",r[r.BlockGroup=160]="BlockGroup",r[r.Block=161]="Block",r[r.BlockAdditions=30113]="BlockAdditions",r[r.BlockMore=166]="BlockMore",r[r.BlockAdditional=165]="BlockAdditional",r[r.BlockAddID=238]="BlockAddID",r[r.BlockDuration=155]="BlockDuration",r[r.ReferenceBlock=251]="ReferenceBlock",r[r.Cluster=524531317]="Cluster",r[r.Timestamp=231]="Timestamp",r[r.Cues=475249515]="Cues",r[r.CuePoint=187]="CuePoint",r[r.CueTime=179]="CueTime",r[r.CueTrackPositions=183]="CueTrackPositions",r[r.CueTrack=247]="CueTrack",r[r.CueClusterPosition=241]="CueClusterPosition",r[r.Colour=21936]="Colour",r[r.MatrixCoefficients=21937]="MatrixCoefficients",r[r.TransferCharacteristics=21946]="TransferCharacteristics",r[r.Primaries=21947]="Primaries",r[r.Range=21945]="Range",r[r.Projection=30320]="Projection",r[r.ProjectionType=30321]="ProjectionType",r[r.ProjectionPoseRoll=30325]="ProjectionPoseRoll",r[r.Attachments=423732329]="Attachments",r[r.AttachedFile=24999]="AttachedFile",r[r.FileDescription=18046]="FileDescription",r[r.FileName=18030]="FileName",r[r.FileMediaType=18016]="FileMediaType",r[r.FileData=18012]="FileData",r[r.FileUID=18094]="FileUID",r[r.Chapters=272869232]="Chapters",r[r.Tags=307544935]="Tags",r[r.Tag=29555]="Tag",r[r.Targets=25536]="Targets",r[r.TargetTypeValue=26826]="TargetTypeValue",r[r.TargetType=25546]="TargetType",r[r.TagTrackUID=25541]="TagTrackUID",r[r.TagEditionUID=25545]="TagEditionUID",r[r.TagChapterUID=25540]="TagChapterUID",r[r.TagAttachmentUID=25542]="TagAttachmentUID",r[r.SimpleTag=26568]="SimpleTag",r[r.TagName=17827]="TagName",r[r.TagLanguage=17530]="TagLanguage",r[r.TagString=17543]="TagString",r[r.TagBinary=17541]="TagBinary"})(T||(T={}));var xa=[T.EBML,T.Segment],it=[T.SeekHead,T.Info,T.Cluster,T.Tracks,T.Cues,T.Attachments,T.Chapters,T.Tags],Br=[...xa,...it];var Vn=8,Z=2,ne=2*Vn,Un=r=>{let e=E(r);if(r.skip(-1),e===0)return null;let t=1,n=128;for(;(e&n)===0;)t++,n>>=1;return t},at=r=>{let e=E(r);if(e===0)return null;let t=1,n=128;for(;(e&n)===0;)t++,n>>=1;let s=e&n-1;for(let a=1;a<t;a++)s*=256,s+=E(r);return s},O=(r,e)=>{if(e<1||e>8)throw new Error("Bad unsigned int size "+e);let t=0;for(let n=0;n<e;n++)t*=256,t+=E(r);return t},ni=(r,e)=>{let t=O(r,e);return t&1<<e*8-1&&(t-=2**(e*8)),t},Rr=r=>{let e=Un(r);return e===null?null:O(r,e)},Ln=r=>{let e=E(r);return e===255?e=null:(r.skip(-1),e=at(r),e===72057594037927940&&(e=null)),e},se=r=>{let e=Rr(r);if(e===null)return null;let t=Ln(r);return{id:e,size:t}},Ee=(r,e)=>{let t=D(r,e),n=0;for(;n<e&&t[n]!==0;)n+=1;return String.fromCharCode(...t.subarray(0,n))},ot=(r,e)=>{let t=D(r,e),n=0;for(;n<e&&t[n]!==0;)n+=1;return G.decode(t.subarray(0,n))},Or=(r,e)=>{if(e===0)return 0;if(e!==4&&e!==8)throw new Error("Bad float size "+e);return e===4?ti(r):Ar(r)},zr=async(r,e,t,n)=>{let s=new Set(t),a=e;for(;n===null||a<n;){let i=r.requestSliceRange(a,Z,ne);if(i instanceof Promise&&(i=await i),!i)break;let o=se(i);if(!o)break;if(s.has(o.id))return{pos:a,found:!0};ke(o.size),a=i.filePos+o.size}return{pos:n!==null&&n>a?n:a,found:!1}},Hn=async(r,e,t,n)=>{let a=new Set(t),i=e;for(;i<n;){let o=r.requestSliceRange(i,0,Math.min(65536,n-i));if(o instanceof Promise&&(o=await o),!o||o.length<Vn)break;for(let c=0;c<o.length-Vn;c++){o.filePos=i;let l=Rr(o);if(l!==null&&a.has(l))return i;i++}}return null},ie={avc:"V_MPEG4/ISO/AVC",hevc:"V_MPEGH/ISO/HEVC",vp8:"V_VP8",vp9:"V_VP9",av1:"V_AV1",aac:"A_AAC",mp3:"A_MPEG/L3",opus:"A_OPUS",vorbis:"A_VORBIS",flac:"A_FLAC","pcm-u8":"A_PCM/INT/LIT","pcm-s16":"A_PCM/INT/LIT","pcm-s16be":"A_PCM/INT/BIG","pcm-s24":"A_PCM/INT/LIT","pcm-s24be":"A_PCM/INT/BIG","pcm-s32":"A_PCM/INT/LIT","pcm-s32be":"A_PCM/INT/BIG","pcm-f32":"A_PCM/FLOAT/IEEE","pcm-f64":"A_PCM/FLOAT/IEEE",webvtt:"S_TEXT/WEBVTT"};function ke(r){if(r===null)throw new Error("Undefined element size is used in a place where it is not supported.")}var si=r=>{let t=(r.hasVideo?"video/":r.hasAudio?"audio/":"application/")+(r.isWebM?"webm":"x-matroska");if(r.codecStrings.length>0){let n=[...new Set(r.codecStrings.filter(Boolean))];t+=`; codecs="${n.join(", ")}"`}return t};var wa={1:[-1,32,40,48,56,64,80,96,112,128,160,192,224,256,320,-1],2:[-1,32,48,56,64,80,96,112,128,160,192,224,256,320,384,-1],3:[-1,32,64,96,128,160,192,224,256,288,320,352,384,416,448,-1]},Sa={1:[-1,32,48,56,64,80,96,112,128,144,160,176,192,224,256,-1],2:[-1,8,16,24,32,40,48,56,64,80,96,112,128,144,160,-1],3:[-1,8,16,24,32,40,48,56,64,80,96,112,128,144,160,-1]},Ta={0:[11025,12e3,8e3,-1],2:[22050,24e3,16e3,-1],3:[44100,48e3,32e3,-1]},ii=1483304551,ai=1231971951,Pa=(r,e,t,n)=>Math.floor(r===3?(12*e/t+n)*4:144*e/t+n),oi=(r,e)=>r===3?e===3?21:36:e===3?13:21,ci=(r,e)=>{let t=r>>>24,n=r>>>16&255,s=r>>>8&255,a=r&255;if(t!==255&&n!==255&&s!==255&&a!==255)return{header:null,bytesAdvanced:4};if(t!==255)return{header:null,bytesAdvanced:1};if((n&224)!==224)return{header:null,bytesAdvanced:1};let i=n>>3&3,o=n>>1&3,c=s>>4&15,l=s>>2&3,u=s>>1&1,d=a>>6&3,f=a>>4&3,m=a>>3&1,h=a>>2&1,g=a&3,y=i===3?wa[o]?.[c]:Sa[o]?.[c];if(!y||y===-1)return{header:null,bytesAdvanced:1};let S=y*1e3,p=Ta[i]?.[l];if(!p||p===-1)return{header:null,bytesAdvanced:1};let w=Pa(o,S,p,u);if(e!==null&&e<w)return{header:null,bytesAdvanced:1};let k;return i===3?k=o===3?384:1152:o===3?k=384:o===2?k=1152:k=576,{header:{totalSize:w,mpegVersionId:i,layer:o,bitrate:S,frequencyIndex:l,sampleRate:p,channel:d,modeExtension:f,copyright:m,original:h,emphasis:g,audioSamplesInFrame:k},bytesAdvanced:1}};var Mr=r=>{let e=2130706432,t=0;for(;e!==0;)t>>=1,t|=r&e,e>>=8;return t};var lt;(function(r){r[r.Unsynchronisation=128]="Unsynchronisation",r[r.ExtendedHeader=64]="ExtendedHeader",r[r.ExperimentalIndicator=32]="ExperimentalIndicator",r[r.Footer=16]="Footer"})(lt||(lt={}));var ut;(function(r){r[r.ISO_8859_1=0]="ISO_8859_1",r[r.UTF_16_WITH_BOM=1]="UTF_16_WITH_BOM",r[r.UTF_16_BE_NO_BOM=2]="UTF_16_BE_NO_BOM",r[r.UTF_8=3]="UTF_8"})(ut||(ut={}));var Dt=128,ft=10,dt=["Blues","Classic rock","Country","Dance","Disco","Funk","Grunge","Hip-hop","Jazz","Metal","New age","Oldies","Other","Pop","Rhythm and blues","Rap","Reggae","Rock","Techno","Industrial","Alternative","Ska","Death metal","Pranks","Soundtrack","Euro-techno","Ambient","Trip-hop","Vocal","Jazz & funk","Fusion","Trance","Classical","Instrumental","Acid","House","Game","Sound clip","Gospel","Noise","Alternative rock","Bass","Soul","Punk","Space","Meditative","Instrumental pop","Instrumental rock","Ethnic","Gothic","Darkwave","Techno-industrial","Electronic","Pop-folk","Eurodance","Dream","Southern rock","Comedy","Cult","Gangsta","Top 40","Christian rap","Pop/funk","Jungle music","Native US","Cabaret","New wave","Psychedelic","Rave","Showtunes","Trailer","Lo-fi","Tribal","Acid punk","Acid jazz","Polka","Retro","Musical","Rock 'n' roll","Hard rock","Folk","Folk rock","National folk","Swing","Fast fusion","Bebop","Latin","Revival","Celtic","Bluegrass","Avantgarde","Gothic rock","Progressive rock","Psychedelic rock","Symphonic rock","Slow rock","Big band","Chorus","Easy listening","Acoustic","Humour","Speech","Chanson","Opera","Chamber music","Sonata","Symphony","Booty bass","Primus","Porn groove","Satire","Slow jam","Club","Tango","Samba","Folklore","Ballad","Power ballad","Rhythmic Soul","Freestyle","Duet","Punk rock","Drum solo","A cappella","Euro-house","Dance hall","Goa music","Drum & bass","Club-house","Hardcore techno","Terror","Indie","Britpop","Negerpunk","Polsk punk","Beat","Christian gangsta rap","Heavy metal","Black metal","Crossover","Contemporary Christian","Christian rock","Merengue","Salsa","Thrash metal","Anime","Jpop","Synthpop","Christmas","Art rock","Baroque","Bhangra","Big beat","Breakbeat","Chillout","Downtempo","Dub","EBM","Eclectic","Electro","Electroclash","Emo","Experimental","Garage","Global","IDM","Illbient","Industro-Goth","Jam Band","Krautrock","Leftfield","Lounge","Math rock","New romantic","Nu-breakz","Post-punk","Post-rock","Psytrance","Shoegaze","Space rock","Trop rock","World music","Neoclassical","Audiobook","Audio theatre","Neue Deutsche Welle","Podcast","Indie rock","G-Funk","Dubstep","Garage rock","Psybient"],Bt=async(r,e,t)=>{let n=e;for(;t===null||n<t;){let s=r.requestSlice(n,4);if(s instanceof Promise&&(s=await s),!s)break;let a=P(s),i=ci(a,r.fileSize!==null?r.fileSize-n:null);if(i.header)return{header:i.header,startPos:n};n+=i.bytesAdvanced}return null},ui=(r,e)=>{let t=r.filePos;e.raw??={},e.raw.TAG??=D(r,Dt-3),r.filePos=t;let n=ct(r,30);n&&(e.title??=n);let s=ct(r,30);s&&(e.artist??=s);let a=ct(r,30);a&&(e.album??=a);let i=ct(r,4),o=Number.parseInt(i,10);Number.isInteger(o)&&o>0&&(e.date??=new Date(o,0,1));let c=D(r,30),l;if(c[28]===0&&c[29]!==0){let d=c[29];d>0&&(e.trackNumber??=d),r.skip(-30),l=ct(r,28),r.skip(2)}else r.skip(-30),l=ct(r,30);l&&(e.comment??=l);let u=E(r);u<dt.length&&(e.genre??=dt[u])},ct=(r,e)=>{let t=D(r,e),n=Le(t.indexOf(0),t.length),s=t.subarray(0,n),a="";for(let i=0;i<s.length;i++)a+=String.fromCharCode(s[i]);return a.trimEnd()},Rt=r=>{let e=r.filePos,t=V(r,3),n=E(r),s=E(r),a=E(r),i=P(r);if(t!=="ID3"||n===255||s===255||(i&2155905152)!==0)return r.filePos=e,null;let o=Mr(i);return{majorVersion:n,revision:s,flags:a,size:o}},di=(r,e,t)=>{if(![2,3,4].includes(e.majorVersion)){console.warn(`Unsupported ID3v2 major version: ${e.majorVersion}`);return}let n=D(r,e.size),s=new Wn(e,n);if(e.flags<.Footer&&s.removeFooter(),e.flags<.Unsynchronisation&&e.majorVersion===3&&s.ununsynchronizeAll(),e.flags<.ExtendedHeader){let a=s.readU32();e.majorVersion===3?s.pos+=a:s.pos+=a-4}for(;s.pos<=s.bytes.length-s.frameHeaderSize();){let a=s.readId3V2Frame();if(!a)break;let i=s.pos,o=s.pos+a.size,c=!1,l=!1,u=!1;if(e.majorVersion===3?(c=!!(a.flags&64),l=!!(a.flags&128)):e.majorVersion===4&&(c=!!(a.flags&4),l=!!(a.flags&8),u=!!(a.flags&2)||!!(e.flags<.Unsynchronisation)),c){console.warn(`Skipping encrypted ID3v2 frame ${a.id}`),s.pos=o;continue}if(l){console.warn(`Skipping compressed ID3v2 frame ${a.id}`),s.pos=o;continue}switch(u&&s.ununsynchronizeRegion(s.pos,o),t.raw??={},a.id[0]==="T"?t.raw[a.id]??=s.readId3V2EncodingAndText(o):t.raw[a.id]??=s.readBytes(a.size),s.pos=i,a.id){case"TIT2":case"TT2":t.title??=s.readId3V2EncodingAndText(o);break;case"TIT3":case"TT3":t.description??=s.readId3V2EncodingAndText(o);break;case"TPE1":case"TP1":t.artist??=s.readId3V2EncodingAndText(o);break;case"TALB":case"TAL":t.album??=s.readId3V2EncodingAndText(o);break;case"TPE2":case"TP2":t.albumArtist??=s.readId3V2EncodingAndText(o);break;case"TRCK":case"TRK":{let f=s.readId3V2EncodingAndText(o).split("/"),m=Number.parseInt(f[0],10),h=f[1]&&Number.parseInt(f[1],10);Number.isInteger(m)&&m>0&&(t.trackNumber??=m),h&&Number.isInteger(h)&&h>0&&(t.tracksTotal??=h)}break;case"TPOS":case"TPA":{let f=s.readId3V2EncodingAndText(o).split("/"),m=Number.parseInt(f[0],10),h=f[1]&&Number.parseInt(f[1],10);Number.isInteger(m)&&m>0&&(t.discNumber??=m),h&&Number.isInteger(h)&&h>0&&(t.discsTotal??=h)}break;case"TCON":case"TCO":{let d=s.readId3V2EncodingAndText(o),f=/^\((\d+)\)/.exec(d);if(f){let m=Number.parseInt(f[1]);if(dt[m]!==void 0){t.genre??=dt[m];break}}if(f=/^\d+$/.exec(d),f){let m=Number.parseInt(f[0]);if(dt[m]!==void 0){t.genre??=dt[m];break}}t.genre??=d}break;case"TDRC":case"TDAT":{let d=s.readId3V2EncodingAndText(o),f=new Date(d);Number.isNaN(f.getTime())||(t.date??=f)}break;case"TYER":case"TYE":{let d=s.readId3V2EncodingAndText(o),f=Number.parseInt(d,10);Number.isInteger(f)&&(t.date??=new Date(f,0,1))}break;case"USLT":case"ULT":{let d=s.readU8();s.pos+=3,s.readId3V2Text(d,o),t.lyrics??=s.readId3V2Text(d,o)}break;case"COMM":case"COM":{let d=s.readU8();s.pos+=3,s.readId3V2Text(d,o),t.comment??=s.readId3V2Text(d,o)}break;case"APIC":case"PIC":{let d=s.readId3V2TextEncoding(),f;if(e.majorVersion===2){let y=s.readAscii(3);f=y==="PNG"?"image/png":y==="JPG"?"image/jpeg":"image/*"}else f=s.readId3V2Text(d,o);let m=s.readU8(),h=s.readId3V2Text(d,o).trimEnd(),g=o-s.pos;if(g>=0){let y=s.readBytes(g);t.images||(t.images=[]),t.images.push({data:y,mimeType:f,kind:m===3?"coverFront":m===4?"coverBack":"unknown",description:h})}}break;default:s.pos+=a.size;break}s.pos=o}},Wn=class{constructor(e,t){this.header=e,this.bytes=t,this.pos=0,this.view=new DataView(t.buffer,t.byteOffset,t.byteLength)}frameHeaderSize(){return this.header.majorVersion===2?6:10}ununsynchronizeAll(){let e=[];for(let t=0;t<this.bytes.length;t++){let n=this.bytes[t];e.push(n),n===255&&t!==this.bytes.length-1&&this.bytes[t]===0&&t++}this.bytes=new Uint8Array(e),this.view=new DataView(this.bytes.buffer)}ununsynchronizeRegion(e,t){let n=[];for(let i=e;i<t;i++){let o=this.bytes[i];n.push(o),o===255&&i!==t-1&&this.bytes[i+1]===0&&i++}let s=this.bytes.subarray(0,e),a=this.bytes.subarray(t);this.bytes=new Uint8Array(s.length+n.length+a.length),this.bytes.set(s,0),this.bytes.set(n,s.length),this.bytes.set(a,s.length+n.length),this.view=new DataView(this.bytes.buffer)}removeFooter(){this.bytes=this.bytes.subarray(0,this.bytes.length-ft),this.view=new DataView(this.bytes.buffer)}readBytes(e){let t=this.bytes.subarray(this.pos,this.pos+e);return this.pos+=e,t}readU8(){let e=this.view.getUint8(this.pos);return this.pos+=1,e}readU16(){let e=this.view.getUint16(this.pos,!1);return this.pos+=2,e}readU24(){let e=this.view.getUint16(this.pos,!1),t=this.view.getUint8(this.pos+1);return this.pos+=3,e*256+t}readU32(){let e=this.view.getUint32(this.pos,!1);return this.pos+=4,e}readAscii(e){let t="";for(let n=0;n<e;n++)t+=String.fromCharCode(this.view.getUint8(this.pos+n));return this.pos+=e,t}readId3V2Frame(){if(this.header.majorVersion===2){let e=this.readAscii(3);if(e==="\0\0\0")return null;let t=this.readU24();return{id:e,size:t,flags:0}}else{let e=this.readAscii(4);if(e==="\0\0\0\0")return null;let t=this.readU32(),n=this.header.majorVersion===4?Mr(t):t,s=this.readU16(),a=this.pos,i=o=>{let c=this.pos+o;if(c>this.bytes.length)return!1;if(c<=this.bytes.length-this.frameHeaderSize()){this.pos+=o;let l=this.readAscii(4);if(l!=="\0\0\0\0"&&!/[0-9A-Z]{4}/.test(l))return!1}return!0};if(!i(n)){let o=this.header.majorVersion===4?t:Mr(t);i(o)&&(n=o)}return this.pos=a,{id:e,size:n,flags:s}}}readId3V2TextEncoding(){let e=this.readU8();if(e>3)throw new Error(`Unsupported text encoding: ${e}`);return e}readId3V2Text(e,t){let n=this.pos,s=this.readBytes(t);switch(e){case ut.ISO_8859_1:{let a="";for(let i=0;i<s.length;i++){let o=s[i];if(o===0){this.pos=n+i+1;break}a+=String.fromCharCode(o)}return a}case ut.UTF_16_WITH_BOM:if(s[0]===255&&s[1]===254){let a=new TextDecoder("utf-16le"),i=Le(s.findIndex((o,c)=>o===0&&s[c+1]===0&&c%2===0),s.length);return this.pos=n+Math.min(i+2,s.length),a.decode(s.subarray(2,i))}else if(s[0]===254&&s[1]===255){let a=new TextDecoder("utf-16be"),i=Le(s.findIndex((o,c)=>o===0&&s[c+1]===0&&c%2===0),s.length);return this.pos=n+Math.min(i+2,s.length),a.decode(s.subarray(2,i))}else{let a=Le(s.findIndex(i=>i===0),s.length);return this.pos=n+Math.min(a+1,s.length),G.decode(s.subarray(0,a))}case ut.UTF_16_BE_NO_BOM:{let a=new TextDecoder("utf-16be"),i=Le(s.findIndex((o,c)=>o===0&&s[c+1]===0&&c%2===0),s.length);return this.pos=n+Math.min(i+2,s.length),a.decode(s.subarray(0,i))}case ut.UTF_8:{let a=Le(s.findIndex(i=>i===0),s.length);return this.pos=n+Math.min(a+1,s.length),G.decode(s.subarray(0,a))}}}readId3V2EncodingAndText(e){if(this.pos>=e)return"";let t=this.readId3V2TextEncoding();return this.readId3V2Text(t,e)}};var qn=1399285583,Ca=79764919,fi=new Uint32Array(256);for(let r=0;r<256;r++){let e=r<<24;for(let t=0;t<8;t++)e=e&2147483648?e<<1^Ca:e<<1;fi[r]=e>>>0&4294967295}var mi=r=>{let e=z(r),t=e.getUint32(22,!0);e.setUint32(22,0,!0);let n=0;for(let s=0;s<r.length;s++){let a=r[s];n=(n<<8^fi[n>>>24^a])>>>0}return e.setUint32(22,t,!0),n},hi=(r,e,t)=>{let n=0,s=null;if(r.length>0)if(e.codec==="vorbis"){b(e.vorbisInfo);let a=e.vorbisInfo.modeBlockflags.length,o=(1<<Ms(a-1))-1<<1,c=(r[0]&o)>>1;if(c>=e.vorbisInfo.modeBlockflags.length)throw new Error("Invalid mode number.");let l=t,u=e.vorbisInfo.modeBlockflags[c];if(s=e.vorbisInfo.blocksizes[u],u===1){let d=(o|1)+1,f=r[0]&d?1:0;l=e.vorbisInfo.blocksizes[f]}n=l!==null?l+s>>2:0}else e.codec==="opus"&&(n=Xs(r).durationInSamples);return{durationInSamples:n,vorbisBlockSize:s}},pi=r=>{let e="audio/ogg";if(r.codecStrings){let t=[...new Set(r.codecStrings)];e+=`; codecs="${t.join(", ")}"`}return e};var _e=27,je=282,gi=je+65025,mt=r=>{let e=r.filePos;if(We(r)!==qn)return null;r.skip(1);let n=E(r),s=ei(r),a=We(r),i=We(r),o=We(r),c=E(r),l=new Uint8Array(c);for(let m=0;m<c;m++)l[m]=E(r);let u=27+c,d=l.reduce((m,h)=>m+h,0),f=u+d;return{headerStartPos:e,totalSize:f,dataStartPos:e+u,dataSize:d,headerType:n,granulePosition:s,serialNumber:a,sequenceNumber:i,checksum:o,lacingValues:l}},bi=(r,e)=>{for(;r.filePos<e-3;){let t=We(r),n=t&255,s=t>>>8&255,a=t>>>16&255,i=t>>>24&255,o=79;if(!(n!==o&&s!==o&&a!==o&&i!==o)){if(r.skip(-4),t===qn)return!0;r.skip(1)}}return!1};var Y=class{constructor(e){this.input=e}};var Nr=[],jn=[];var $=new Uint8Array(0),N=class r{constructor(e,t,n,s,a=-1,i){if(this.data=e,this.type=t,this.timestamp=n,this.duration=s,this.sequenceNumber=a,e===$&&i===void 0)throw new Error("Internal error: byteLength must be explicitly provided when constructing metadata-only packets.");if(i===void 0&&(i=e.byteLength),!(e instanceof Uint8Array))throw new TypeError("data must be a Uint8Array.");if(t!=="key"&&t!=="delta")throw new TypeError('type must be either "key" or "delta".');if(!Number.isFinite(n))throw new TypeError("timestamp must be a number.");if(!Number.isFinite(s)||s<0)throw new TypeError("duration must be a non-negative number.");if(!Number.isFinite(a))throw new TypeError("sequenceNumber must be a number.");if(!Number.isInteger(i)||i<0)throw new TypeError("byteLength must be a non-negative integer.");this.byteLength=i}get isMetadataOnly(){return this.data===$}get microsecondTimestamp(){return Math.trunc(Ce*this.timestamp)}get microsecondDuration(){return Math.trunc(Ce*this.duration)}toEncodedVideoChunk(){if(this.isMetadataOnly)throw new TypeError("Metadata-only packets cannot be converted to a video chunk.");if(typeof EncodedVideoChunk>"u")throw new Error("Your browser does not support EncodedVideoChunk.");return new EncodedVideoChunk({data:this.data,type:this.type,timestamp:this.microsecondTimestamp,duration:this.microsecondDuration})}toEncodedAudioChunk(){if(this.isMetadataOnly)throw new TypeError("Metadata-only packets cannot be converted to an audio chunk.");if(typeof EncodedAudioChunk>"u")throw new Error("Your browser does not support EncodedAudioChunk.");return new EncodedAudioChunk({data:this.data,type:this.type,timestamp:this.microsecondTimestamp,duration:this.microsecondDuration})}static fromEncodedChunk(e){if(!(e instanceof EncodedVideoChunk||e instanceof EncodedAudioChunk))throw new TypeError("chunk must be an EncodedVideoChunk or EncodedAudioChunk.");let t=new Uint8Array(e.byteLength);return e.copyTo(t),new r(t,e.type,e.timestamp/1e6,(e.duration??0)/1e6)}clone(e){if(e!==void 0&&(typeof e!="object"||e===null))throw new TypeError("options, when provided, must be an object.");if(e?.timestamp!==void 0&&!Number.isFinite(e.timestamp))throw new TypeError("options.timestamp, when provided, must be a number.");if(e?.duration!==void 0&&!Number.isFinite(e.duration))throw new TypeError("options.duration, when provided, must be a number.");return new r(this.data,this.type,e?.timestamp??this.timestamp,e?.duration??this.duration,this.sequenceNumber,this.byteLength)}};var zt=class r{get displayWidth(){return this.rotation%180===0?this.codedWidth:this.codedHeight}get displayHeight(){return this.rotation%180===0?this.codedHeight:this.codedWidth}get microsecondTimestamp(){return Math.trunc(Ce*this.timestamp)}get microsecondDuration(){return Math.trunc(Ce*this.duration)}constructor(e,t){if(this._closed=!1,e instanceof ArrayBuffer||ArrayBuffer.isView(e)){if(!t||typeof t!="object")throw new TypeError("init must be an object.");if(!("format"in t)||typeof t.format!="string")throw new TypeError("init.format must be a string.");if(!Number.isInteger(t.codedWidth)||t.codedWidth<=0)throw new TypeError("init.codedWidth must be a positive integer.");if(!Number.isInteger(t.codedHeight)||t.codedHeight<=0)throw new TypeError("init.codedHeight must be a positive integer.");if(t.rotation!==void 0&&![0,90,180,270].includes(t.rotation))throw new TypeError("init.rotation, when provided, must be 0, 90, 180, or 270.");if(!Number.isFinite(t.timestamp))throw new TypeError("init.timestamp must be a number.");if(t.duration!==void 0&&(!Number.isFinite(t.duration)||t.duration<0))throw new TypeError("init.duration, when provided, must be a non-negative number.");this._data=Pe(e).slice(),this.format=t.format,this.codedWidth=t.codedWidth,this.codedHeight=t.codedHeight,this.rotation=t.rotation??0,this.timestamp=t.timestamp,this.duration=t.duration??0,this.colorSpace=new VideoColorSpace(t.colorSpace)}else if(typeof VideoFrame<"u"&&e instanceof VideoFrame){if(t?.rotation!==void 0&&![0,90,180,270].includes(t.rotation))throw new TypeError("init.rotation, when provided, must be 0, 90, 180, or 270.");if(t?.timestamp!==void 0&&!Number.isFinite(t?.timestamp))throw new TypeError("init.timestamp, when provided, must be a number.");if(t?.duration!==void 0&&(!Number.isFinite(t.duration)||t.duration<0))throw new TypeError("init.duration, when provided, must be a non-negative number.");this._data=e,this.format=e.format,this.codedWidth=e.displayWidth,this.codedHeight=e.displayHeight,this.rotation=t?.rotation??0,this.timestamp=t?.timestamp??e.timestamp/1e6,this.duration=t?.duration??(e.duration??0)/1e6,this.colorSpace=e.colorSpace}else if(typeof HTMLImageElement<"u"&&e instanceof HTMLImageElement||typeof SVGImageElement<"u"&&e instanceof SVGImageElement||typeof ImageBitmap<"u"&&e instanceof ImageBitmap||typeof HTMLVideoElement<"u"&&e instanceof HTMLVideoElement||typeof HTMLCanvasElement<"u"&&e instanceof HTMLCanvasElement||typeof OffscreenCanvas<"u"&&e instanceof OffscreenCanvas){if(!t||typeof t!="object")throw new TypeError("init must be an object.");if(t.rotation!==void 0&&![0,90,180,270].includes(t.rotation))throw new TypeError("init.rotation, when provided, must be 0, 90, 180, or 270.");if(!Number.isFinite(t.timestamp))throw new TypeError("init.timestamp must be a number.");if(t.duration!==void 0&&(!Number.isFinite(t.duration)||t.duration<0))throw new TypeError("init.duration, when provided, must be a non-negative number.");if(typeof VideoFrame<"u")return new r(new VideoFrame(e,{timestamp:Math.trunc(t.timestamp*Ce),duration:Math.trunc((t.duration??0)*Ce)}),t);let n=0,s=0;if("naturalWidth"in e?(n=e.naturalWidth,s=e.naturalHeight):"videoWidth"in e?(n=e.videoWidth,s=e.videoHeight):"width"in e&&(n=Number(e.width),s=Number(e.height)),!n||!s)throw new TypeError("Could not determine dimensions.");let a=new OffscreenCanvas(n,s),i=a.getContext("2d",{alpha:!1,willReadFrequently:!0});b(i),i.drawImage(e,0,0),this._data=a,this.format="RGBX",this.codedWidth=n,this.codedHeight=s,this.rotation=t.rotation??0,this.timestamp=t.timestamp,this.duration=t.duration??0,this.colorSpace=new VideoColorSpace({matrix:"rgb",primaries:"bt709",transfer:"iec61966-2-1",fullRange:!0})}else throw new TypeError("Invalid data type: Must be a BufferSource or CanvasImageSource.")}clone(){if(this._closed)throw new Error("VideoSample is closed.");return b(this._data!==null),Ot(this._data)?new r(this._data.clone(),{timestamp:this.timestamp,duration:this.duration,rotation:this.rotation}):this._data instanceof Uint8Array?new r(this._data.slice(),{format:this.format,codedWidth:this.codedWidth,codedHeight:this.codedHeight,timestamp:this.timestamp,duration:this.duration,colorSpace:this.colorSpace,rotation:this.rotation}):new r(this._data,{format:this.format,codedWidth:this.codedWidth,codedHeight:this.codedHeight,timestamp:this.timestamp,duration:this.duration,colorSpace:this.colorSpace,rotation:this.rotation})}close(){this._closed||(Ot(this._data)?this._data.close():this._data=null,this._closed=!0)}allocationSize(){if(this._closed)throw new Error("VideoSample is closed.");return b(this._data!==null),Ot(this._data)?this._data.allocationSize():this._data instanceof Uint8Array?this._data.byteLength:this.codedWidth*this.codedHeight*4}async copyTo(e){if(!En(e))throw new TypeError("destination must be an ArrayBuffer or an ArrayBuffer view.");if(this._closed)throw new Error("VideoSample is closed.");if(b(this._data!==null),Ot(this._data))await this._data.copyTo(e);else if(this._data instanceof Uint8Array)Pe(e).set(this._data);else{let n=this._data.getContext("2d",{alpha:!1});b(n);let s=n.getImageData(0,0,this.codedWidth,this.codedHeight);Pe(e).set(s.data)}}toVideoFrame(){if(this._closed)throw new Error("VideoSample is closed.");return b(this._data!==null),Ot(this._data)?new VideoFrame(this._data,{timestamp:this.microsecondTimestamp,duration:this.microsecondDuration||void 0}):this._data instanceof Uint8Array?new VideoFrame(this._data,{format:this.format,codedWidth:this.codedWidth,codedHeight:this.codedHeight,timestamp:this.microsecondTimestamp,duration:this.microsecondDuration,colorSpace:this.colorSpace}):new VideoFrame(this._data,{timestamp:this.microsecondTimestamp,duration:this.microsecondDuration})}draw(e,t,n,s,a,i,o,c,l){let u=0,d=0,f=this.displayWidth,m=this.displayHeight,h=0,g=0,y=this.displayWidth,S=this.displayHeight;if(i!==void 0?(u=t,d=n,f=s,m=a,h=i,g=o,c!==void 0?(y=c,S=l):(y=f,S=m)):(h=t,g=n,s!==void 0&&(y=s,S=a)),!(typeof CanvasRenderingContext2D<"u"&&e instanceof CanvasRenderingContext2D||typeof OffscreenCanvasRenderingContext2D<"u"&&e instanceof OffscreenCanvasRenderingContext2D))throw new TypeError("context must be a CanvasRenderingContext2D or OffscreenCanvasRenderingContext2D.");if(!Number.isFinite(u))throw new TypeError("sx must be a number.");if(!Number.isFinite(d))throw new TypeError("sy must be a number.");if(!Number.isFinite(f)||f<0)throw new TypeError("sWidth must be a non-negative number.");if(!Number.isFinite(m)||m<0)throw new TypeError("sHeight must be a non-negative number.");if(!Number.isFinite(h))throw new TypeError("dx must be a number.");if(!Number.isFinite(g))throw new TypeError("dy must be a number.");if(!Number.isFinite(y)||y<0)throw new TypeError("dWidth must be a non-negative number.");if(!Number.isFinite(S)||S<0)throw new TypeError("dHeight must be a non-negative number.");if(this._closed)throw new Error("VideoSample is closed.");this.rotation===90?[u,d,f,m]=[d,this.codedHeight-u-f,m,f]:this.rotation===180?[u,d]=[this.codedWidth-u-f,this.codedHeight-d-m]:this.rotation===270&&([u,d,f,m]=[this.codedWidth-d-m,u,m,f]);let p=this.toCanvasImageSource();e.save();let w=h+y/2,k=g+S/2;e.translate(w,k),e.rotate(this.rotation*Math.PI/180);let x=this.rotation%180===0?1:y/S;e.scale(1/x,x),e.drawImage(p,u,d,f,m,-y/2,-S/2,y,S),e.restore()}drawWithFit(e,t){let n=e.canvas.width,s=e.canvas.height,a=t.rotation??this.rotation,i,o,c,l;if(t.fit==="fill")i=0,o=0,c=n,l=s;else{let[d,f]=a%180===0?[this.codedWidth,this.codedHeight]:[this.codedHeight,this.codedWidth],m=t.fit==="contain"?Math.min(n/d,s/f):Math.max(n/d,s/f);c=d*m,l=f*m,i=(n-c)/2,o=(s-l)/2}let u=a%180===0?1:c/l;e.translate(n/2,s/2),e.rotate(a*Math.PI/180),e.scale(1/u,u),e.translate(-n/2,-s/2),e.drawImage(this.toCanvasImageSource(),i,o,c,l)}toCanvasImageSource(){if(this._closed)throw new Error("VideoSample is closed.");if(b(this._data!==null),this._data instanceof Uint8Array){let e=this.toVideoFrame();return queueMicrotask(()=>e.close()),e}else return this._data}setRotation(e){if(![0,90,180,270].includes(e))throw new TypeError("newRotation must be 0, 90, 180, or 270.");this.rotation=e}setTimestamp(e){if(!Number.isFinite(e))throw new TypeError("newTimestamp must be a number.");this.timestamp=e}setDuration(e){if(!Number.isFinite(e)||e<0)throw new TypeError("newDuration must be a non-negative number.");this.duration=e}},Ot=r=>typeof VideoFrame<"u"&&r instanceof VideoFrame;var ht=r=>{if(!r||typeof r!="object")throw new TypeError("options must be an object.");if(r.metadataOnly!==void 0&&typeof r.metadataOnly!="boolean")throw new TypeError("options.metadataOnly, when defined, must be a boolean.");if(r.verifyKeyPackets!==void 0&&typeof r.verifyKeyPackets!="boolean")throw new TypeError("options.verifyKeyPackets, when defined, must be a boolean.");if(r.verifyKeyPackets&&r.metadataOnly)throw new TypeError("options.verifyKeyPackets and options.metadataOnly cannot be enabled together.")},$e=r=>{if(typeof r!="number"||Number.isNaN(r))throw new TypeError("timestamp must be a number.")},$n=(r,e,t)=>t.verifyKeyPackets?e.then(async n=>{if(!n||n.type==="delta")return n;let s=await r.determinePacketType(n);return s&&(n.type=s),n}):e,pt=class{constructor(e){if(!(e instanceof gt))throw new TypeError("track must be an InputTrack.");this._track=e}getFirstPacket(e={}){return ht(e),$n(this._track,this._track._backing.getFirstPacket(e),e)}getPacket(e,t={}){return $e(e),ht(t),$n(this._track,this._track._backing.getPacket(e,t),t)}getNextPacket(e,t={}){if(!(e instanceof N))throw new TypeError("packet must be an EncodedPacket.");return ht(t),$n(this._track,this._track._backing.getNextPacket(e,t),t)}async getKeyPacket(e,t={}){if($e(e),ht(t),!t.verifyKeyPackets)return this._track._backing.getKeyPacket(e,t);let n=await this._track._backing.getKeyPacket(e,t);return!n||n.type==="delta"?n:await this._track.determinePacketType(n)==="delta"?this.getKeyPacket(n.timestamp-1/this._track.timeResolution,t):n}async getNextKeyPacket(e,t={}){if(!(e instanceof N))throw new TypeError("packet must be an EncodedPacket.");if(ht(t),!t.verifyKeyPackets)return this._track._backing.getNextKeyPacket(e,t);let n=await this._track._backing.getNextKeyPacket(e,t);return!n||n.type==="delta"?n:await this._track.determinePacketType(n)==="delta"?this.getNextKeyPacket(n,t):n}packets(e,t,n={}){if(e!==void 0&&!(e instanceof N))throw new TypeError("startPacket must be an EncodedPacket.");if(e!==void 0&&e.isMetadataOnly&&!n?.metadataOnly)throw new TypeError("startPacket can only be metadata-only if options.metadataOnly is enabled.");if(t!==void 0&&!(t instanceof N))throw new TypeError("endPacket must be an EncodedPacket.");ht(n);let s=[],{promise:a,resolve:i}=X(),{promise:o,resolve:c}=X(),l=!1,u=!1,d=null,f=[],m=()=>Math.max(2,f.length);return(async()=>{let h=e??await this.getFirstPacket(n);for(;h&&!u&&!(t&&h.sequenceNumber>=t?.sequenceNumber);){if(s.length>m()){({promise:o,resolve:c}=X()),await o;continue}s.push(h),i(),{promise:a,resolve:i}=X(),h=await this.getNextPacket(h,n)}l=!0,i()})().catch(h=>{d||(d=h,i())}),{async next(){for(;;){if(u)return{value:void 0,done:!0};if(d)throw d;if(s.length>0){let h=s.shift(),g=performance.now();for(f.push(g);f.length>0&&g-f[0]>=1e3;)f.shift();return c(),{value:h,done:!1}}else{if(l)return{value:void 0,done:!0};await a}}},async return(){return u=!0,c(),i(),{value:void 0,done:!0}},async throw(h){throw h},[Symbol.asyncIterator](){return this}}}},Kn=class{constructor(e,t){this.onSample=e,this.onError=t}},Vr=class{mediaSamplesInRange(e=0,t=1/0){$e(e),$e(t);let n=[],s=!1,a=null,{promise:i,resolve:o}=X(),{promise:c,resolve:l}=X(),u=!1,d=!1,f=!1,m=null;return(async()=>{let h=new Error,g=await this._createDecoder(x=>{if(l(),x.timestamp>=t&&(d=!0),d){x.close();return}a&&(x.timestamp>e?(n.push(a),s=!0):a.close()),x.timestamp>=e&&(n.push(x),s=!0),a=s?null:x,n.length>0&&(o(),{promise:i,resolve:o}=X())},x=>{m||(x.stack=h.stack,m=x,o())}),y=this._createPacketSink(),S=await y.getKeyPacket(e,{verifyKeyPackets:!0})??await y.getFirstPacket();if(!S)return;let p=S,w;if(t<1/0){let x=await y.getPacket(t),C=x?x.type==="key"&&x.timestamp===t?x:await y.getNextKeyPacket(x,{verifyKeyPackets:!0}):null;C&&(w=C)}let k=y.packets(S,w);for(await k.next();p&&!d;){let x=yi(n.length);if(n.length+g.getDecodeQueueSize()>x){({promise:c,resolve:l}=X()),await c;continue}g.decode(p);let C=await k.next();if(C.done)break;p=C.value}await k.return(),f||await g.flush(),g.close(),!s&&a&&n.push(a),u=!0,o()})().catch(h=>{m||(m=h,o())}),{async next(){for(;;){if(f)return{value:void 0,done:!0};if(m)throw m;if(n.length>0){let h=n.shift();return l(),{value:h,done:!1}}else if(!u)await i;else return{value:void 0,done:!0}}},async return(){f=!0,d=!0,l(),o(),a?.close();for(let h of n)h.close();return{value:void 0,done:!0}},async throw(h){throw h},[Symbol.asyncIterator](){return this}}}mediaSamplesAtTimestamps(e){Os(e);let t=Rs(e),n=[],s=[],{promise:a,resolve:i}=X(),{promise:o,resolve:c}=X(),l=!1,u=!1,d=null,f=m=>{s.push(m),i(),{promise:a,resolve:i}=X()};return(async()=>{let m=new Error,h=await this._createDecoder(x=>{if(c(),u){x.close();return}let C=0;for(;n.length>0&&x.timestamp-n[0]>-1e-10;)C++,n.shift();if(C>0)for(let v=0;v<C;v++)f(v<C-1?x.clone():x);else x.close()},x=>{d||(x.stack=m.stack,d=x,i())}),g=this._createPacketSink(),y=null,S=null,p=-1,w=async()=>{b(S);let x=S;for(h.decode(x);x.sequenceNumber<p;){let C=yi(s.length);for(;s.length+h.getDecodeQueueSize()>C&&!u;)({promise:o,resolve:c}=X()),await o;if(u)break;let v=await g.getNextPacket(x);b(v),h.decode(v),x=v}p=-1},k=async()=>{await h.flush();for(let x=0;x<n.length;x++)f(null);n.length=0};for await(let x of t){if($e(x),u)break;let C=await g.getPacket(x),v=C&&await g.getKeyPacket(x,{verifyKeyPackets:!0});if(!v){p!==-1&&(await w(),await k()),f(null),y=null;continue}y&&(v.sequenceNumber!==S.sequenceNumber||C.timestamp<y.timestamp)&&(await w(),await k()),n.push(C.timestamp),p=Math.max(C.sequenceNumber,p),y=C,S=v}u||(p!==-1&&await w(),await k()),h.close(),l=!0,i()})().catch(m=>{d||(d=m,i())}),{async next(){for(;;){if(u)return{value:void 0,done:!0};if(d)throw d;if(s.length>0){let m=s.shift();return b(m!==void 0),c(),{value:m,done:!1}}else if(!l)await a;else return{value:void 0,done:!0}}},async return(){u=!0,c(),i();for(let m of s)m?.close();return{value:void 0,done:!0}},async throw(m){throw m},[Symbol.asyncIterator](){return this}}}},yi=r=>r===0?40:8,Gn=class extends Kn{constructor(e,t,n,s,a,i){super(e,t),this.codec=n,this.decoderConfig=s,this.rotation=a,this.timeResolution=i,this.decoder=null,this.customDecoder=null,this.customDecoderCallSerializer=new fr,this.customDecoderQueueSize=0,this.inputTimestamps=[],this.sampleQueue=[],this.currentPacketIndex=0,this.raslSkipped=!1;let o=Nr.find(c=>c.supports(n,s));if(o)this.customDecoder=new o,this.customDecoder.codec=n,this.customDecoder.config=s,this.customDecoder.onSample=c=>{if(!(c instanceof zt))throw new TypeError("The argument passed to onSample must be a VideoSample.");this.finalizeAndEmitSample(c)},this.customDecoderCallSerializer.call(()=>this.customDecoder.init());else{let c=l=>{if(wr()){if(this.sampleQueue.length>0&&l.timestamp>=W(this.sampleQueue).timestamp){for(let u of this.sampleQueue)this.finalizeAndEmitSample(u);this.sampleQueue.length=0}te(this.sampleQueue,l,u=>u.timestamp)}else{let u=this.inputTimestamps.shift();b(u!==void 0),l.setTimestamp(u),this.finalizeAndEmitSample(l)}};this.decoder=new VideoDecoder({output:l=>c(new zt(l)),error:t}),this.decoder.configure(s)}}finalizeAndEmitSample(e){e.setTimestamp(Math.round(e.timestamp*this.timeResolution)/this.timeResolution),e.setDuration(Math.round(e.duration*this.timeResolution)/this.timeResolution),e.setRotation(this.rotation),this.onSample(e)}getDecodeQueueSize(){return this.customDecoder?this.customDecoderQueueSize:(b(this.decoder),this.decoder.decodeQueueSize)}decode(e){if(this.codec==="hevc"&&this.currentPacketIndex>0&&!this.raslSkipped){if(Mn(e.data,this.decoderConfig).some(s=>{let a=pe(s);return a===Q.RASL_N||a===Q.RASL_R}))return;this.raslSkipped=!0}this.currentPacketIndex++,this.customDecoder?(this.customDecoderQueueSize++,this.customDecoderCallSerializer.call(()=>this.customDecoder.decode(e)).then(()=>this.customDecoderQueueSize--)):(b(this.decoder),wr()||te(this.inputTimestamps,e.timestamp,t=>t),this.decoder.decode(e.toEncodedVideoChunk()))}async flush(){if(this.customDecoder?await this.customDecoderCallSerializer.call(()=>this.customDecoder.flush()):(b(this.decoder),await this.decoder.flush()),wr()){for(let e of this.sampleQueue)this.finalizeAndEmitSample(e);this.sampleQueue.length=0}this.currentPacketIndex=0,this.raslSkipped=!1}close(){this.customDecoder?this.customDecoderCallSerializer.call(()=>this.customDecoder.close()):(b(this.decoder),this.decoder.close());for(let e of this.sampleQueue)e.close();this.sampleQueue.length=0}},Ur=class extends Vr{constructor(e){if(!(e instanceof de))throw new TypeError("videoTrack must be an InputVideoTrack.");super(),this._videoTrack=e}async _createDecoder(e,t){if(!await this._videoTrack.canDecode())throw new Error("This video track cannot be decoded by this browser. Make sure to check decodability before using a track.");let n=this._videoTrack.codec,s=this._videoTrack.rotation,a=await this._videoTrack.getDecoderConfig(),i=this._videoTrack.timeResolution;return b(n&&a),new Gn(e,t,n,a,s,i)}_createPacketSink(){return new pt(this._videoTrack)}async getSample(e){$e(e);for await(let t of this.mediaSamplesAtTimestamps([e]))return t;throw new Error("Internal error: Iterator returned nothing.")}samples(e=0,t=1/0){return this.mediaSamplesInRange(e,t)}samplesAtTimestamps(e){return this.mediaSamplesAtTimestamps(e)}},Mt=class{constructor(e,t={}){if(this._nextCanvasIndex=0,!(e instanceof de))throw new TypeError("videoTrack must be an InputVideoTrack.");if(t&&typeof t!="object")throw new TypeError("options must be an object.");if(t.width!==void 0&&(!Number.isInteger(t.width)||t.width<=0))throw new TypeError("options.width, when defined, must be a positive integer.");if(t.height!==void 0&&(!Number.isInteger(t.height)||t.height<=0))throw new TypeError("options.height, when defined, must be a positive integer.");if(t.fit!==void 0&&!["fill","contain","cover"].includes(t.fit))throw new TypeError('options.fit, when provided, must be one of "fill", "contain", or "cover".');if(t.width!==void 0&&t.height!==void 0&&t.fit===void 0)throw new TypeError("When both options.width and options.height are provided, options.fit must also be provided.");if(t.rotation!==void 0&&![0,90,180,270].includes(t.rotation))throw new TypeError("options.rotation, when provided, must be 0, 90, 180 or 270.");if(t.poolSize!==void 0&&(typeof t.poolSize!="number"||!Number.isInteger(t.poolSize)||t.poolSize<0))throw new TypeError("poolSize must be a non-negative integer.");let n=t.rotation??e.rotation,[s,a]=n%180===0?[e.codedWidth,e.codedHeight]:[e.codedHeight,e.codedWidth],i=s/a;t.width!==void 0&&t.height===void 0?(s=t.width,a=Math.round(s/i)):t.width===void 0&&t.height!==void 0?(a=t.height,s=Math.round(a*i)):t.width!==void 0&&t.height!==void 0&&(s=t.width,a=t.height),this._videoTrack=e,this._width=s,this._height=a,this._rotation=n,this._fit=t.fit??"fill",this._videoSampleSink=new Ur(e),this._canvasPool=Array.from({length:t.poolSize??0},()=>null)}_videoSampleToWrappedCanvas(e){let t=this._canvasPool[this._nextCanvasIndex],n=!1;t||(typeof document<"u"?(t=document.createElement("canvas"),t.width=this._width,t.height=this._height):t=new OffscreenCanvas(this._width,this._height),this._canvasPool.length>0&&(this._canvasPool[this._nextCanvasIndex]=t),n=!0),this._canvasPool.length>0&&(this._nextCanvasIndex=(this._nextCanvasIndex+1)%this._canvasPool.length);let s=t.getContext("2d",{alpha:!1});b(s),s.resetTransform(),n||s.clearRect(0,0,this._width,this._height),e.drawWithFit(s,{fit:this._fit,rotation:this._rotation});let a={canvas:t,timestamp:e.timestamp,duration:e.duration};return e.close(),a}async getCanvas(e){$e(e);let t=await this._videoSampleSink.getSample(e);return t&&this._videoSampleToWrappedCanvas(t)}canvases(e=0,t=1/0){return Dn(this._videoSampleSink.samples(e,t),n=>this._videoSampleToWrappedCanvas(n))}canvasesAtTimestamps(e){return Dn(this._videoSampleSink.samplesAtTimestamps(e),t=>t&&this._videoSampleToWrappedCanvas(t))}};var gt=class{constructor(e){this._backing=e}isVideoTrack(){return this instanceof de}isAudioTrack(){return this instanceof K}get id(){return this._backing.getId()}get internalCodecId(){return this._backing.getInternalCodecId()}get languageCode(){return this._backing.getLanguageCode()}get name(){return this._backing.getName()}get timeResolution(){return this._backing.getTimeResolution()}getFirstTimestamp(){return this._backing.getFirstTimestamp()}computeDuration(){return this._backing.computeDuration()}async computePacketStats(e=1/0){let t=new pt(this),n=1/0,s=-1/0,a=0,i=0;for await(let o of t.packets(void 0,void 0,{metadataOnly:!0})){if(a>=e&&o.timestamp>=s)break;n=Math.min(n,o.timestamp),s=Math.max(s,o.timestamp+o.duration),a++,i+=o.byteLength}return{packetCount:a,averagePacketRate:a?Number((a/(s-n)).toPrecision(16)):0,averageBitrate:a?Number((8*i/(s-n)).toPrecision(16)):0}}},de=class extends gt{constructor(e){super(e),this._backing=e}get type(){return"video"}get codec(){return this._backing.getCodec()}get codedWidth(){return this._backing.getCodedWidth()}get codedHeight(){return this._backing.getCodedHeight()}get rotation(){return this._backing.getRotation()}get displayWidth(){return this._backing.getRotation()%180===0?this._backing.getCodedWidth():this._backing.getCodedHeight()}get displayHeight(){return this._backing.getRotation()%180===0?this._backing.getCodedHeight():this._backing.getCodedWidth()}getColorSpace(){return this._backing.getColorSpace()}async hasHighDynamicRange(){let e=await this._backing.getColorSpace();return e.primaries==="bt2020"||e.primaries==="smpte432"||e.transfer==="pg"||e.transfer==="hlg"||e.matrix==="bt2020-ncl"}getDecoderConfig(){return this._backing.getDecoderConfig()}async getCodecParameterString(){return(await this._backing.getDecoderConfig())?.codec??null}async canDecode(){try{let e=await this._backing.getDecoderConfig();if(!e)return!1;let t=this._backing.getCodec();return b(t!==null),Nr.some(s=>s.supports(t,e))?!0:typeof VideoDecoder>"u"?!1:(await VideoDecoder.isConfigSupported(e)).supported===!0}catch(e){return console.error("Error during decodability check:",e),!1}}async determinePacketType(e){if(!(e instanceof N))throw new TypeError("packet must be an EncodedPacket.");if(e.isMetadataOnly)throw new TypeError("packet must not be metadata-only to determine its type.");return this.codec===null?null:Zs(this,e)}},K=class extends gt{constructor(e){super(e),this._backing=e}get type(){return"audio"}get codec(){return this._backing.getCodec()}get numberOfChannels(){return this._backing.getNumberOfChannels()}get sampleRate(){return this._backing.getSampleRate()}getDecoderConfig(){return this._backing.getDecoderConfig()}async getCodecParameterString(){return(await this._backing.getDecoderConfig())?.codec??null}async canDecode(){try{let e=await this._backing.getDecoderConfig();if(!e)return!1;let t=this._backing.getCodec();return b(t!==null),jn.some(n=>n.supports(t,e))||e.codec.startsWith("pcm-")?!0:typeof AudioDecoder>"u"?!1:(await AudioDecoder.isConfigSupported(e)).supported===!0}catch(e){return console.error("Error during decodability check:",e),!1}}async determinePacketType(e){if(!(e instanceof N))throw new TypeError("packet must be an EncodedPacket.");return this.codec===null?null:"key"}};var xe;(function(r){r[r.PCM=1]="PCM",r[r.IEEE_FLOAT=3]="IEEE_FLOAT",r[r.ALAW=6]="ALAW",r[r.MULAW=7]="MULAW",r[r.EXTENSIBLE=65534]="EXTENSIBLE"})(xe||(xe={}));var Lr=class extends Y{constructor(e){super(e),this.metadataPromise=null,this.dataStart=-1,this.dataSize=-1,this.audioInfo=null,this.tracks=[],this.lastKnownPacketIndex=0,this.metadataTags={},this.reader=e._reader}async readMetadata(){return this.metadataPromise??=(async()=>{let e=this.reader.requestSlice(0,12);e instanceof Promise&&(e=await e),b(e);let t=V(e,4),n=t!=="RIFX",s=t==="RF64",a=ge(e,n),i=s?this.reader.fileSize:Math.min(a+8,this.reader.fileSize??1/0);if(V(e,4)!=="WAVE")throw new Error("Invalid WAVE file - wrong format");let c=0,l=null,u=e.filePos;for(;i===null||u<i;){let f=this.reader.requestSlice(u,8);if(f instanceof Promise&&(f=await f),!f)break;let m=V(f,4),h=ge(f,n),g=f.filePos;if(s&&c===0&&m!=="ds64")throw new Error('Invalid RF64 file: First chunk must be "ds64".');if(m==="fmt ")await this.parseFmtChunk(g,h,n);else if(m==="data"){if(l??=h,this.dataStart=f.filePos,this.dataSize=Math.min(l,(i??1/0)-this.dataStart),this.reader.fileSize===null)break}else if(m==="ds64"){let y=Nn(f,n);l=Nn(f,n),i=Math.min(y+8,this.reader.fileSize??1/0)}else m==="LIST"&&await this.parseListChunk(g,h,n);u=g+h+(h&1),c++}if(!this.audioInfo)throw new Error('Invalid WAVE file - missing "fmt " chunk');if(this.dataStart===-1)throw new Error('Invalid WAVE file - missing "data" chunk');let d=this.audioInfo.blockSizeInBytes;this.dataSize=Math.floor(this.dataSize/d)*d,this.tracks.push(new K(new Xn(this)))})()}async parseFmtChunk(e,t,n){let s=this.reader.requestSlice(e,t);if(s instanceof Promise&&(s=await s),!s)return;let a=nt(s,n),i=nt(s,n),o=ge(s,n);s.skip(4);let c=nt(s,n),l;if(t===14?l=8:l=nt(s,n),t>=18&&a!==357){let u=nt(s,n),d=t-18;if(Math.min(d,u)>=22&&a===xe.EXTENSIBLE){s.skip(6);let m=D(s,16);a=m[0]|m[1]<<8}}(a===xe.MULAW||a===xe.ALAW)&&(l=8),this.audioInfo={format:a,numberOfChannels:i,sampleRate:o,sampleSizeInBytes:Math.ceil(l/8),blockSizeInBytes:c}}async parseListChunk(e,t,n){let s=this.reader.requestSlice(e,t);if(s instanceof Promise&&(s=await s),!s)return;let a=V(s,4);if(a!=="INFO"&&a!=="INF0")return;let i=s.filePos;for(;i<=e+t-8;){s.filePos=i;let o=V(s,4),c=ge(s,n),l=D(s,c),u=0;for(let f=0;f<l.length&&l[f]!==0;f++)u++;let d=String.fromCharCode(...l.subarray(0,u));switch(this.metadataTags.raw??={},this.metadataTags.raw[o]=d,o){case"INAM":case"TITL":this.metadataTags.title??=d;break;case"TIT3":this.metadataTags.description??=d;break;case"IART":this.metadataTags.artist??=d;break;case"IPRD":this.metadataTags.album??=d;break;case"IPRT":case"ITRK":case"TRCK":{let f=d.split("/"),m=Number.parseInt(f[0],10),h=f[1]&&Number.parseInt(f[1],10);Number.isInteger(m)&&m>0&&(this.metadataTags.trackNumber??=m),h&&Number.isInteger(h)&&h>0&&(this.metadataTags.tracksTotal??=h)}break;case"ICRD":case"IDIT":{let f=new Date(d);Number.isNaN(f.getTime())||(this.metadataTags.date??=f)}break;case"YEAR":{let f=Number.parseInt(d,10);Number.isInteger(f)&&f>0&&(this.metadataTags.date??=new Date(f,0,1))}break;case"IGNR":case"GENR":this.metadataTags.genre??=d;break;case"ICMT":case"CMNT":case"COMM":this.metadataTags.comment??=d;break}i+=8+c+(c&1)}}getCodec(){if(b(this.audioInfo),this.audioInfo.format===xe.MULAW)return"ulaw";if(this.audioInfo.format===xe.ALAW)return"alaw";if(this.audioInfo.format===xe.PCM){if(this.audioInfo.sampleSizeInBytes===1)return"pcm-u8";if(this.audioInfo.sampleSizeInBytes===2)return"pcm-s16";if(this.audioInfo.sampleSizeInBytes===3)return"pcm-s24";if(this.audioInfo.sampleSizeInBytes===4)return"pcm-s32"}return this.audioInfo.format===xe.IEEE_FLOAT&&this.audioInfo.sampleSizeInBytes===4?"pcm-f32":null}async getMimeType(){return"audio/wav"}async computeDuration(){await this.readMetadata();let e=this.tracks[0];return b(e),e.computeDuration()}async getTracks(){return await this.readMetadata(),this.tracks}async getMetadataTags(){return await this.readMetadata(),this.metadataTags}},bt=2048,Xn=class{constructor(e){this.demuxer=e}getId(){return 1}getCodec(){return this.demuxer.getCodec()}getInternalCodecId(){return b(this.demuxer.audioInfo),this.demuxer.audioInfo.format}async getDecoderConfig(){let e=this.demuxer.getCodec();return e?(b(this.demuxer.audioInfo),{codec:e,numberOfChannels:this.demuxer.audioInfo.numberOfChannels,sampleRate:this.demuxer.audioInfo.sampleRate}):null}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}getNumberOfChannels(){return b(this.demuxer.audioInfo),this.demuxer.audioInfo.numberOfChannels}getSampleRate(){return b(this.demuxer.audioInfo),this.demuxer.audioInfo.sampleRate}getTimeResolution(){return b(this.demuxer.audioInfo),this.demuxer.audioInfo.sampleRate}getName(){return null}getLanguageCode(){return q}async getFirstTimestamp(){return 0}async getPacketAtIndex(e,t){b(this.demuxer.audioInfo);let n=e*bt*this.demuxer.audioInfo.blockSizeInBytes;if(n>=this.demuxer.dataSize)return null;let s=Math.min(bt*this.demuxer.audioInfo.blockSizeInBytes,this.demuxer.dataSize-n);if(this.demuxer.reader.fileSize===null){let c=this.demuxer.reader.requestSlice(this.demuxer.dataStart+n,s);if(c instanceof Promise&&(c=await c),!c)return null}let a;if(t.metadataOnly)a=$;else{let c=this.demuxer.reader.requestSlice(this.demuxer.dataStart+n,s);c instanceof Promise&&(c=await c),b(c),a=D(c,s)}let i=e*bt/this.demuxer.audioInfo.sampleRate,o=s/this.demuxer.audioInfo.blockSizeInBytes/this.demuxer.audioInfo.sampleRate;return this.demuxer.lastKnownPacketIndex=Math.max(e,i),new N(a,"key",i,o,e,s)}getFirstPacket(e){return this.getPacketAtIndex(0,e)}async getPacket(e,t){b(this.demuxer.audioInfo);let n=Math.floor(Math.min(e*this.demuxer.audioInfo.sampleRate/bt,(this.demuxer.dataSize-1)/(bt*this.demuxer.audioInfo.blockSizeInBytes))),s=await this.getPacketAtIndex(n,t);if(s)return s;if(n===0)return null;b(this.demuxer.reader.fileSize===null);let a=await this.getPacketAtIndex(this.demuxer.lastKnownPacketIndex,t);for(;a;){let i=await this.getNextPacket(a,t);if(!i)break;a=i}return a}getNextPacket(e,t){b(this.demuxer.audioInfo);let n=Math.round(e.timestamp*this.demuxer.audioInfo.sampleRate/bt);return this.getPacketAtIndex(n+1,t)}getKeyPacket(e,t){return this.getPacket(e,t)}getNextKeyPacket(e,t){return this.getNextPacket(e,t)}};var Ke=class{constructor(){this._sizePromise=null,this.onread=null}async getSizeOrNull(){return this._sizePromise??=Promise.resolve(this._retrieveSize())}async getSize(){let e=await this.getSizeOrNull();if(e===null)throw new Error("Cannot determine the size of an unsized source.");return e}};var Nt=class extends Ke{constructor(e,t={}){if(!(e instanceof Blob))throw new TypeError("blob must be a Blob.");if(!t||typeof t!="object")throw new TypeError("options must be an object.");if(t.maxCacheSize!==void 0&&(!Number.isInteger(t.maxCacheSize)||t.maxCacheSize<0))throw new TypeError("options.maxCacheSize, when provided, must be a non-negative integer.");super(),this._readers=new WeakMap,this._blob=e,this._orchestrator=new Hr({maxCacheSize:t.maxCacheSize??8*2**20,maxWorkerCount:4,runWorker:this._runWorker.bind(this),prefetchProfile:xi.fileSystem})}_retrieveSize(){let e=this._blob.size;return this._orchestrator.fileSize=e,e}_read(e,t){return this._orchestrator.read(e,t)}async _runWorker(e){let t=this._readers.get(e);for(t||(t=this._blob.slice(e.currentPos).stream().getReader(),this._readers.set(e,t));e.currentPos<e.targetPos&&!e.aborted;){let{done:n,value:s}=await t.read();if(n){if(this._orchestrator.forgetWorker(e),e.currentPos<e.targetPos)throw new Error("Blob reader stopped unexpectedly before all requested data was read.");break}this.onread?.(e.currentPos,e.currentPos+s.length),this._orchestrator.supplyWorkerData(e,s)}e.running=!1}get _supportsRandomAccess(){return!0}},ki=.5*2**20,Vt=class extends Ke{constructor(e,t={}){if(typeof e!="string"&&!(e instanceof URL))throw new TypeError("url must be a string or URL.");if(!t||typeof t!="object")throw new TypeError("options must be an object.");if(t.requestInit!==void 0&&(!t.requestInit||typeof t.requestInit!="object"))throw new TypeError("options.requestInit, when provided, must be an object.");if(t.getRetryDelay!==void 0&&typeof t.getRetryDelay!="function")throw new TypeError("options.getRetryDelay, when provided, must be a function.");if(t.maxCacheSize!==void 0&&(!Number.isInteger(t.maxCacheSize)||t.maxCacheSize<0))throw new TypeError("options.maxCacheSize, when provided, must be a non-negative integer.");super(),this._existingResponses=new WeakMap,this._url=e instanceof URL?e:new URL(e,typeof location<"u"?location.href:void 0),this._options=t,this._getRetryDelay=t.getRetryDelay??(n=>Math.min(2**(n-2),8)),this._orchestrator=new Hr({maxCacheSize:t.maxCacheSize??64*2**20,maxWorkerCount:2,runWorker:this._runWorker.bind(this),prefetchProfile:xi.network})}async _retrieveSize(){let e=new AbortController,t=await Bn(this._url,xr(this._options.requestInit??{},{headers:{Range:"bytes=0-"},signal:e.signal}),this._getRetryDelay);if(!t.ok)throw new Error(`Error fetching ${this._url}: ${t.status} ${t.statusText}`);let n,s;if(t.status===206)s=this._getPartialLengthFromRangeResponse(t),n=this._orchestrator.createWorker(0,Math.min(s,ki));else{let a=t.headers.get("Content-Length");if(a)s=Number(a),n=this._orchestrator.createWorker(0,s),this._orchestrator.options.maxCacheSize=1/0,console.warn("HTTP server did not respond with 206 Partial Content, meaning the entire remote resource now has to be downloaded. For efficient media file streaming across a network, please make sure your server supports range requests.");else throw new Error(`HTTP response (status ${t.status}) must surface Content-Length header.`)}return this._orchestrator.fileSize=s,this._existingResponses.set(n,{response:t,abortController:e}),this._orchestrator.runWorker(n),s}_read(e,t){return this._orchestrator.read(e,t)}async _runWorker(e){for(;!e.aborted;){let t=this._existingResponses.get(e);this._existingResponses.delete(e);let n=t?.abortController,s=t?.response;if(n||(n=new AbortController,s=await Bn(this._url,xr(this._options.requestInit??{},{headers:{Range:`bytes=${e.currentPos}-`},signal:n.signal}),this._getRetryDelay)),b(s),!s.ok)throw new Error(`Error fetching ${this._url}: ${s.status} ${s.statusText}`);if(e.currentPos>0&&s.status!==206)throw new Error("HTTP server did not respond with 206 Partial Content to a range request. To enable efficient media file streaming across a network, please make sure your server supports range requests.");let a=this._getPartialLengthFromRangeResponse(s),i=e.targetPos-e.currentPos;if(a<i)throw new Error(`HTTP response unexpectedly too short: Needed at least ${i} bytes, got only ${a}.`);if(!s.body)throw new Error("Missing HTTP response body.");let o=s.body.getReader();for(;;){let c;try{c=await o.read()}catch(d){let f=this._getRetryDelay(1);if(f!==null){console.error("Error while reading response stream. Attempting to resume.",d),await new Promise(m=>setTimeout(m,1e3*f));break}else throw d}let{done:l,value:u}=c;if(l){if(this._orchestrator.forgetWorker(e),e.currentPos<e.targetPos)throw new Error("Response stream reader stopped unexpectedly before all requested data was read.");e.running=!1;return}if(this.onread?.(e.currentPos,e.currentPos+u.length),this._orchestrator.supplyWorkerData(e,u),e.currentPos>=e.targetPos||e.aborted){n.abort(),e.running=!1;return}}}e.running=!1}_getPartialLengthFromRangeResponse(e){let t=e.headers.get("Content-Range");if(t){let n=/\/(\d+)/.exec(t);if(n)return Number(n[1]);throw new Error(`Invalid Content-Range header: ${t}`)}else{let n=e.headers.get("Content-Length");if(n)return Number(n);throw new Error("Partial HTTP response (status 206) must surface either Content-Range or Content-Length header.")}}get _supportsRandomAccess(){return!0}};var xi={none:(r,e)=>({start:r,end:e}),fileSystem:(r,e)=>(r=Math.floor((r-65536)/65536)*65536,e=Math.ceil((e+65536)/65536)*65536,{start:r,end:e}),network:(r,e,t)=>{r=Math.max(0,Math.floor((r-65536)/65536)*65536);for(let s of t){let i=Math.max((s.startPos+s.targetPos)/2,s.targetPos-8388608);if(Sr(r,e,i,s.targetPos)){let o=s.targetPos-s.startPos,c=Math.ceil((o+1)/8388608)*8388608,l=2**Math.ceil(Math.log2(o+1)),u=Math.min(l,c);e=Math.max(e,s.startPos+u)}}return e=Math.max(e,r+ki),{start:r,end:e}}},Hr=class{constructor(e){this.options=e,this.fileSize=null,this.nextAge=0,this.workers=[],this.cache=[],this.currentCacheSize=0}read(e,t){b(this.fileSize!==null);let n=this.options.prefetchProfile(e,t,this.workers),s=Math.max(n.start,0),a=Math.min(n.end,this.fileSize);b(s<=e&&t<=a);let i=null,o=R(this.cache,e,p=>p.start),c=o!==-1?this.cache[o]:null;c&&c.start<=e&&t<=c.end&&(c.age=this.nextAge++,i={bytes:c.bytes,view:c.view,offset:c.start});let l=R(this.cache,s,p=>p.start),u=i?null:new Uint8Array(t-e),d=0,f=s,m=[];if(l!==-1){for(let p=l;p<this.cache.length;p++){let w=this.cache[p];if(w.start>=a)break;if(w.end<=s)continue;let k=Math.max(s,w.start),x=Math.min(a,w.end);if(b(k<=x),f<k&&m.push({start:f,end:k}),f=x,u){let C=Math.max(e,w.start),v=Math.min(t,w.end);if(C<v){let F=C-e;u.set(w.bytes.subarray(C-w.start,v-w.start),F),F===d&&(d=v-e)}}w.age=this.nextAge++}f<a&&m.push({start:f,end:a})}else m.push({start:s,end:a});if(u&&d>=u.length&&(i={bytes:u,view:z(u),offset:e}),m.length===0)return b(i),i;let{promise:h,resolve:g,reject:y}=X(),S=[];for(let p of m){let w=Math.max(e,p.start),k=Math.min(t,p.end);w===p.start&&k===p.end?S.push(p):w<k&&S.push({start:w,end:k})}for(let p of m){let w=u&&{start:e,bytes:u,holes:S,resolve:g,reject:y},k=!1;for(let x of this.workers)if(Sr(p.start-131072,p.start,x.currentPos,x.targetPos)){x.targetPos=Math.max(x.targetPos,p.end),k=!0,w&&!x.pendingSlices.includes(w)&&x.pendingSlices.push(w),x.running||this.runWorker(x);break}if(!k){let x=this.createWorker(p.start,p.end);w&&(x.pendingSlices=[w]),this.runWorker(x)}}return i||(b(u),i=h.then(p=>({bytes:p,view:z(p),offset:e}))),i}createWorker(e,t){let n={startPos:e,currentPos:e,targetPos:t,running:!1,aborted:!1,pendingSlices:[],age:this.nextAge++};for(this.workers.push(n);this.workers.length>this.options.maxWorkerCount;){let s=0,a=this.workers[0];for(let i=1;i<this.workers.length;i++){let o=this.workers[i];o.age<a.age&&(s=i,a=o)}if(a.running&&a.pendingSlices.length>0)break;a.aborted=!0,this.workers.splice(s,1)}return n}runWorker(e){b(!e.running),b(e.currentPos<e.targetPos),e.running=!0,e.age=this.nextAge++,this.options.runWorker(e).catch(t=>{if(e.running=!1,e.pendingSlices.length>0)e.pendingSlices.forEach(n=>n.reject(t)),e.pendingSlices.length=0;else throw t})}supplyWorkerData(e,t){let n=e.currentPos,s=n+t.length;this.insertIntoCache({start:n,end:s,bytes:t,view:z(t),age:this.nextAge++}),e.currentPos+=t.length,e.targetPos=Math.max(e.targetPos,e.currentPos);for(let a=0;a<e.pendingSlices.length;a++){let i=e.pendingSlices[a],o=Math.max(n,i.start),c=Math.min(s,i.start+i.bytes.length);o<c&&i.bytes.set(t.subarray(o-n,c-n),o-i.start);for(let l=0;l<i.holes.length;l++){let u=i.holes[l];n<=u.start&&s>u.start&&(u.start=s),u.end<=u.start&&(i.holes.splice(l,1),l--)}i.holes.length===0&&(i.resolve(i.bytes),e.pendingSlices.splice(a,1),a--)}for(let a=0;a<this.workers.length;a++){let i=this.workers[a];e===i||i.running||Sr(n,s,i.currentPos,i.targetPos)&&(this.workers.splice(a,1),a--)}}forgetWorker(e){let t=this.workers.indexOf(e);b(t!==-1),this.workers.splice(t,1)}insertIntoCache(e){if(this.options.maxCacheSize===0)return;let t=R(this.cache,e.start,n=>n.start)+1;if(t>0){let n=this.cache[t-1];if(n.end>=e.end)return;if(n.end>e.start){let s=new Uint8Array(e.end-n.start);s.set(n.bytes,0),s.set(e.bytes,e.start-n.start),this.currentCacheSize+=e.end-n.end,n.bytes=s,n.view=z(s),n.end=e.end,t--,e=n}else this.cache.splice(t,0,e),this.currentCacheSize+=e.bytes.length}else this.cache.splice(t,0,e),this.currentCacheSize+=e.bytes.length;for(let n=t+1;n<this.cache.length;n++){let s=this.cache[n];if(e.end<=s.start)break;if(e.end>=s.end){this.cache.splice(n,1),this.currentCacheSize-=s.bytes.length,n--;continue}let a=new Uint8Array(s.end-e.start);a.set(e.bytes,0),a.set(s.bytes,s.start-e.start),this.currentCacheSize-=e.end-s.start,e.bytes=a,e.view=z(a),e.end=s.end,this.cache.splice(n,1);break}for(;this.currentCacheSize>this.options.maxCacheSize;){let n=0,s=this.cache[0];for(let a=1;a<this.cache.length;a++){let i=this.cache[a];i.age<s.age&&(n=a,s=i)}if(this.currentCacheSize-s.bytes.length<=this.options.maxCacheSize)break;this.cache.splice(n,1),this.currentCacheSize-=s.bytes.length}}};var va=new Set(["@day","@mak","@mod","@swr","@xyz","CAME","CNCV","CNFV","CNMN","FIRM","FOV\0","GoPr","LENS","PXMN","SIGM","SNum","TAGS","albm","albr","angl","auth","ccid","cdis","clfn","clid","clsf","cmid","cmnm","coll","cprt","cver","cvru","date","dscp","fsid","gnre","hinv","icnu","info","infu","kgtt","loci","lrcu","mcvr","name","perf","pmcc","reel","rtng","scen","shot","slno","thmb","titl","tnam","urat","uuid","vndr","yrrc","\xA9ART","\xA9TIM","\xA9TSC","\xA9TSZ","\xA9alb","\xA9arg","\xA9ark","\xA9cmt","\xA9cok","\xA9com","\xA9cpy","\xA9day","\xA9dir","\xA9ed1","\xA9ed2","\xA9ed3","\xA9ed4","\xA9ed5","\xA9ed6","\xA9ed7","\xA9ed8","\xA9ed9","\xA9enc","\xA9fmt","\xA9fpt","\xA9frl","\xA9fyw","\xA9gen","\xA9gpt","\xA9grl","\xA9grp","\xA9gyw","\xA9inf","\xA9isr","\xA9lab","\xA9lal","\xA9lyr","\xA9mak","\xA9mal","\xA9mdl","\xA9mod","\xA9nam","\xA9pdk","\xA9phg","\xA9prd","\xA9prf","\xA9prk","\xA9prl","\xA9req","\xA9snk","\xA9snm","\xA9src","\xA9swf","\xA9swk","\xA9swr","\xA9too","\xA9trk","\xA9wrt","\xA9xsp","\xA9xyz","\xA9ysp","\xA9zsp"]),Wr=class extends Y{constructor(e){super(e),this.moovSlice=null,this.currentTrack=null,this.tracks=[],this.metadataPromise=null,this.movieTimescale=-1,this.movieDurationInTimescale=-1,this.isQuickTime=!1,this.metadataTags={},this.currentMetadataKeys=null,this.isFragmented=!1,this.fragmentTrackDefaults=[],this.fragments=[],this.currentFragment=null,this.fragmentLookupMutex=new ee,this.reader=e._reader}async computeDuration(){let e=await this.getTracks(),t=await Promise.all(e.map(n=>n.computeDuration()));return Math.max(0,...t)}async getTracks(){return await this.readMetadata(),this.tracks.map(e=>e.inputTrack)}async getMimeType(){await this.readMetadata();let e=await Promise.all(this.tracks.map(t=>t.inputTrack.getCodecParameterString()));return Ys({isQuickTime:this.isQuickTime,hasVideo:this.tracks.some(t=>t.info?.type==="video"),hasAudio:this.tracks.some(t=>t.info?.type==="audio"),codecStrings:e.filter(Boolean)})}async getMetadataTags(){return await this.readMetadata(),this.metadataTags}readMetadata(){return this.metadataPromise??=(async()=>{let e=0;for(;;){let t=this.reader.requestSliceRange(e,ye,qe);if(t instanceof Promise&&(t=await t),!t)break;let n=e,s=ue(t);if(!s)break;if(s.name==="ftyp"){let a=V(t,4);this.isQuickTime=a==="qt "}else if(s.name==="moov"){let a=this.reader.requestSlice(t.filePos,s.contentSize);if(a instanceof Promise&&(a=await a),!a)break;this.moovSlice=a,this.readContiguousBoxes(this.moovSlice);for(let i of this.tracks){let o=i.editListPreviousSegmentDurations/this.movieTimescale;i.editListOffset-=Math.round(o*i.timescale)}break}e=n+s.totalSize}if(this.isFragmented&&this.reader.fileSize!==null){let t=this.reader.requestSlice(this.reader.fileSize-4,4);t instanceof Promise&&(t=await t),b(t);let n=P(t),s=this.reader.fileSize-n;if(s>=0&&s<=this.reader.fileSize-qe){let a=this.reader.requestSliceRange(s,ye,qe);if(a instanceof Promise&&(a=await a),a){let i=ue(a);if(i&&i.name==="mfra"){let o=this.reader.requestSlice(a.filePos,i.contentSize);o instanceof Promise&&(o=await o),o&&this.readContiguousBoxes(o)}}}}})()}getSampleTableForTrack(e){if(e.sampleTable)return e.sampleTable;let t={sampleTimingEntries:[],sampleCompositionTimeOffsets:[],sampleSizes:[],keySampleIndices:null,chunkOffsets:[],sampleToChunk:[],presentationTimestamps:null,presentationTimestampIndexMap:null};e.sampleTable=t,b(this.moovSlice);let n=this.moovSlice.slice(e.sampleTableByteOffset);if(this.currentTrack=e,this.traverseBox(n),this.currentTrack=null,e.info?.type==="audio"&&e.info.codec&&At.includes(e.info.codec)&&t.sampleCompositionTimeOffsets.length===0){b(e.info?.type==="audio");let a=Hs(e.info.codec),i=[],o=[];for(let c=0;c<t.sampleToChunk.length;c++){let l=t.sampleToChunk[c],u=t.sampleToChunk[c+1],d=(u?u.startChunkIndex:t.chunkOffsets.length)-l.startChunkIndex;for(let f=0;f<d;f++){let m=l.startSampleIndex+f*l.samplesPerChunk,h=m+l.samplesPerChunk,g=R(t.sampleTimingEntries,m,F=>F.startIndex),y=t.sampleTimingEntries[g],S=R(t.sampleTimingEntries,h,F=>F.startIndex),p=t.sampleTimingEntries[S],w=y.startDecodeTimestamp+(m-y.startIndex)*y.delta,x=p.startDecodeTimestamp+(h-p.startIndex)*p.delta-w,C=W(i);C&&C.delta===x?C.count++:i.push({startIndex:l.startChunkIndex+f,startDecodeTimestamp:w,count:1,delta:x});let v=l.samplesPerChunk*a.sampleSize*e.info.numberOfChannels;o.push(v)}l.startSampleIndex=l.startChunkIndex,l.samplesPerChunk=1}t.sampleTimingEntries=i,t.sampleSizes=o}if(t.sampleCompositionTimeOffsets.length>0){t.presentationTimestamps=[];for(let a of t.sampleTimingEntries)for(let i=0;i<a.count;i++)t.presentationTimestamps.push({presentationTimestamp:a.startDecodeTimestamp+i*a.delta,sampleIndex:a.startIndex+i});for(let a of t.sampleCompositionTimeOffsets)for(let i=0;i<a.count;i++){let o=a.startIndex+i,c=t.presentationTimestamps[o];c&&(c.presentationTimestamp+=a.offset)}t.presentationTimestamps.sort((a,i)=>a.presentationTimestamp-i.presentationTimestamp),t.presentationTimestampIndexMap=Array(t.presentationTimestamps.length).fill(-1);for(let a=0;a<t.presentationTimestamps.length;a++)t.presentationTimestampIndexMap[t.presentationTimestamps[a].sampleIndex]=a}return t}async readFragment(e){let t=this.reader.requestSliceRange(e,ye,qe);t instanceof Promise&&(t=await t),b(t);let n=ue(t);b(n?.name==="moof");let s=this.reader.requestSlice(e,n.totalSize);s instanceof Promise&&(s=await s),b(s),this.traverseBox(s);let a=M(this.fragments,e,o=>o.moofOffset);b(a!==-1);let i=this.fragments[a];b(i.moofOffset===e);for(let[o,c]of i.trackData){if(c.startTimestampIsFinal)continue;let l=this.tracks.find(g=>g.id===o),u=0,d=null,f=null,m=R(l.fragments,e-1,g=>g.moofOffset);m!==-1&&(d=l.fragments[m],f=d,u=d.moofOffset+d.moofSize);let h=u===0;for(;u<=e-ye;){if(d?.nextFragment)d=d.nextFragment,u=d.moofOffset+d.moofSize;else{let g=this.reader.requestSliceRange(u,ye,qe);if(g instanceof Promise&&(g=await g),!g)break;let y=u,S=ue(g);if(!S)break;if(S.name==="moof"){let p=M(this.fragments,y,k=>k.moofOffset),w;p===-1?w=await this.readFragment(y):w=this.fragments[p],d&&(d.nextFragment=w),d=w,h&&(w.isKnownToBeFirstFragment=!0,h=!1)}u=y+S.totalSize}d&&d.trackData.has(o)&&(f=d)}if(f){let g=f.trackData.get(o);b(g.startTimestampIsFinal),Si(c,g.endTimestamp)}c.startTimestampIsFinal=!0}return i}readContiguousBoxes(e){let t=e.filePos;for(;e.filePos-t<=e.length-ye&&this.traverseBox(e););}*iterateContiguousBoxes(e){let t=e.filePos;for(;e.filePos-t<=e.length-ye;){let n=e.filePos,s=ue(e);if(!s)break;yield{boxInfo:s,slice:e},e.filePos=n+s.totalSize}}traverseBox(e){let t=e.filePos,n=ue(e);if(!n)return!1;let s=e.filePos,a=t+n.totalSize;switch(n.name){case"mdia":case"minf":case"dinf":case"mfra":case"edts":this.readContiguousBoxes(e.slice(s,n.contentSize));break;case"mvhd":{let i=E(e);e.skip(3),i===1?(e.skip(16),this.movieTimescale=P(e),this.movieDurationInTimescale=J(e)):(e.skip(8),this.movieTimescale=P(e),this.movieDurationInTimescale=P(e))}break;case"trak":{let i={id:-1,demuxer:this,inputTrack:null,info:null,timescale:-1,durationInMovieTimescale:-1,durationInMediaTimescale:-1,rotation:0,internalCodecId:null,name:null,languageCode:q,sampleTableByteOffset:-1,sampleTable:null,fragmentLookupTable:null,currentFragmentState:null,fragments:[],fragmentsWithKeyFrame:[],editListPreviousSegmentDurations:0,editListOffset:0};if(this.currentTrack=i,this.readContiguousBoxes(e.slice(s,n.contentSize)),i.id!==-1&&i.timescale!==-1&&i.info!==null){if(i.info.type==="video"&&i.info.width!==-1){let o=i;i.inputTrack=new de(new Qn(o)),this.tracks.push(i)}else if(i.info.type==="audio"&&i.info.numberOfChannels!==-1){let o=i;i.inputTrack=new K(new Zn(o)),this.tracks.push(i)}}this.currentTrack=null}break;case"tkhd":{let i=this.currentTrack;if(!i)break;let o=E(e);if(!((st(e)&1)!==0))break;if(o===0)e.skip(8),i.id=P(e),e.skip(4),i.durationInMovieTimescale=P(e);else if(o===1)e.skip(16),i.id=P(e),e.skip(4),i.durationInMovieTimescale=J(e);else throw new Error(`Incorrect track header version ${o}.`);e.skip(16);let u=[Ie(e),Ie(e),Fr(e),Ie(e),Ie(e),Fr(e),Ie(e),Ie(e),Fr(e)],d=mr(zs(Aa(u),90));b(d===0||d===90||d===180||d===270),i.rotation=d}break;case"elst":{let i=this.currentTrack;if(!i)break;let o=E(e);e.skip(3);let c=!1,l=0,u=P(e);for(let d=0;d<u;d++){let f=o===1?J(e):P(e),m=o===1?Js(e):be(e),h=Ie(e);if(f!==0){if(c){console.warn("Unsupported edit list: multiple edits are not currently supported. Only using first edit.");break}if(m===-1){l+=f;continue}if(h!==1){console.warn("Unsupported edit list entry: media rate must be 1.");break}i.editListPreviousSegmentDurations=l,i.editListOffset=m,c=!0}}}break;case"mdhd":{let i=this.currentTrack;if(!i)break;let o=E(e);e.skip(3),o===0?(e.skip(8),i.timescale=P(e),i.durationInMediaTimescale=P(e)):o===1&&(e.skip(16),i.timescale=P(e),i.durationInMediaTimescale=J(e));let c=j(e);if(c>0){i.languageCode="";for(let l=0;l<3;l++)i.languageCode=String.fromCharCode(96+(c&31))+i.languageCode,c>>=5;kr(i.languageCode)||(i.languageCode=q)}}break;case"hdlr":{let i=this.currentTrack;if(!i)break;e.skip(8);let o=V(e,4);o==="vide"?i.info={type:"video",width:-1,height:-1,codec:null,codecDescription:null,colorSpace:null,avcCodecInfo:null,hevcCodecInfo:null,vp9CodecInfo:null,av1CodecInfo:null}:o==="soun"&&(i.info={type:"audio",numberOfChannels:-1,sampleRate:-1,codec:null,codecDescription:null,aacCodecInfo:null})}break;case"stbl":{let i=this.currentTrack;if(!i)break;i.sampleTableByteOffset=t,this.readContiguousBoxes(e.slice(s,n.contentSize))}break;case"stsd":{let i=this.currentTrack;if(!i||i.info===null||i.sampleTable)break;let o=E(e);e.skip(3);let c=P(e);for(let l=0;l<c;l++){let u=e.filePos,d=ue(e);if(!d)break;i.internalCodecId=d.name;let f=d.name.toLowerCase();if(i.info.type==="video")f==="avc1"?i.info.codec="avc":f==="hvc1"||f==="hev1"?i.info.codec="hevc":f==="vp08"?i.info.codec="vp8":f==="vp09"?i.info.codec="vp9":f==="av01"?i.info.codec="av1":console.warn(`Unsupported video codec (sample entry type '${d.name}').`),e.skip(24),i.info.width=j(e),i.info.height=j(e),e.skip(50),this.readContiguousBoxes(e.slice(e.filePos,u+d.totalSize-e.filePos));else{f==="mp4a"||(f==="opus"?i.info.codec="opus":f==="flac"?i.info.codec="flac":f==="twos"||f==="sowt"||f==="raw "||f==="in24"||f==="in32"||f==="fl32"||f==="fl64"||f==="lpcm"||f==="ipcm"||f==="fpcm"||(f==="ulaw"?i.info.codec="ulaw":f==="alaw"?i.info.codec="alaw":console.warn(`Unsupported audio codec (sample entry type '${d.name}').`))),e.skip(8);let m=j(e);e.skip(6);let h=j(e),g=j(e);e.skip(4);let y=P(e)/65536;if(o===0&&m>0){if(m===1)e.skip(4),g=8*P(e),e.skip(8);else if(m===2){e.skip(4),y=Ar(e),h=P(e),e.skip(4),g=P(e);let S=P(e);if(e.skip(8),f==="lpcm"){let p=g+7>>3,w=!!(S&1),k=!!(S&2),x=S&4?-1:0;g>0&&g<=64&&(w?g===32&&(i.info.codec=k?"pcm-f32be":"pcm-f32"):x&1<<p-1?p===1?i.info.codec="pcm-s8":p===2?i.info.codec=k?"pcm-s16be":"pcm-s16":p===3?i.info.codec=k?"pcm-s24be":"pcm-s24":p===4&&(i.info.codec=k?"pcm-s32be":"pcm-s32"):p===1&&(i.info.codec="pcm-u8")),i.info.codec===null&&console.warn("Unsupported PCM format.")}}}i.info.numberOfChannels=h,i.info.sampleRate=y,f==="twos"?g===8?i.info.codec="pcm-s8":g===16?i.info.codec="pcm-s16be":(console.warn(`Unsupported sample size ${g} for codec 'twos'.`),i.info.codec=null):f==="sowt"?g===8?i.info.codec="pcm-s8":g===16?i.info.codec="pcm-s16":(console.warn(`Unsupported sample size ${g} for codec 'sowt'.`),i.info.codec=null):f==="raw "?i.info.codec="pcm-u8":f==="in24"?i.info.codec="pcm-s24be":f==="in32"?i.info.codec="pcm-s32be":f==="fl32"?i.info.codec="pcm-f32be":f==="fl64"?i.info.codec="pcm-f64be":f==="ipcm"?i.info.codec="pcm-s16be":f==="fpcm"&&(i.info.codec="pcm-f32be"),this.readContiguousBoxes(e.slice(e.filePos,u+d.totalSize-e.filePos))}}}break;case"avcC":{let i=this.currentTrack;if(!i)break;b(i.info),i.info.codecDescription=D(e,n.contentSize)}break;case"hvcC":{let i=this.currentTrack;if(!i)break;b(i.info),i.info.codecDescription=D(e,n.contentSize)}break;case"vpcC":{let i=this.currentTrack;if(!i)break;b(i.info?.type==="video"),e.skip(4);let o=E(e),c=E(e),l=E(e),u=l>>4,d=l>>1&7,f=l&1,m=E(e),h=E(e),g=E(e);i.info.vp9CodecInfo={profile:o,level:c,bitDepth:u,chromaSubsampling:d,videoFullRangeFlag:f,colourPrimaries:m,transferCharacteristics:h,matrixCoefficients:g}}break;case"av1C":{let i=this.currentTrack;if(!i)break;b(i.info?.type==="video"),e.skip(1);let o=E(e),c=o>>5,l=o&31,u=E(e),d=u>>7,f=u>>6&1,m=u>>5&1,h=u>>4&1,g=u>>3&1,y=u>>2&1,S=u&3,p=c===2&&f?m?12:10:f?10:8;i.info.av1CodecInfo={profile:c,level:l,tier:d,bitDepth:p,monochrome:h,chromaSubsamplingX:g,chromaSubsamplingY:y,chromaSamplePosition:S}}break;case"colr":{let i=this.currentTrack;if(!i||(b(i.info?.type==="video"),V(e,4)!=="nclx"))break;let c=j(e),l=j(e),u=j(e),d=!!(E(e)&128);i.info.colorSpace={primaries:hr[c],transfer:pr[l],matrix:gr[u],fullRange:d}}break;case"wave":this.readContiguousBoxes(e.slice(s,n.contentSize));break;case"esds":{let i=this.currentTrack;if(!i)break;b(i.info?.type==="audio"),e.skip(4);let o=E(e);b(o===3),Dr(e),e.skip(2);let c=E(e),l=(c&128)!==0,u=(c&64)!==0,d=(c&32)!==0;if(l&&e.skip(2),u){let y=E(e);e.skip(y)}d&&e.skip(2);let f=E(e);b(f===4);let m=Dr(e),h=e.filePos,g=E(e);if(g===64||g===103?(i.info.codec="aac",i.info.aacCodecInfo={isMpeg2:g===103}):g===105||g===107?i.info.codec="mp3":g===221?i.info.codec="vorbis":console.warn(`Unsupported audio codec (objectTypeIndication ${g}) - discarding track.`),e.skip(12),m>e.filePos-h){let y=E(e);b(y===5);let S=Dr(e);if(i.info.codecDescription=D(e,S),i.info.codec==="aac"){let p=On(i.info.codecDescription);p.numberOfChannels!==null&&(i.info.numberOfChannels=p.numberOfChannels),p.sampleRate!==null&&(i.info.sampleRate=p.sampleRate)}}}break;case"enda":{let i=this.currentTrack;if(!i)break;b(i.info?.type==="audio"),j(e)&255&&(i.info.codec==="pcm-s16be"?i.info.codec="pcm-s16":i.info.codec==="pcm-s24be"?i.info.codec="pcm-s24":i.info.codec==="pcm-s32be"?i.info.codec="pcm-s32":i.info.codec==="pcm-f32be"?i.info.codec="pcm-f32":i.info.codec==="pcm-f64be"&&(i.info.codec="pcm-f64"))}break;case"pcmC":{let i=this.currentTrack;if(!i)break;b(i.info?.type==="audio"),e.skip(4);let c=!!(E(e)&1),l=E(e);i.info.codec==="pcm-s16be"?c?l===16?i.info.codec="pcm-s16":l===24?i.info.codec="pcm-s24":l===32?i.info.codec="pcm-s32":(console.warn(`Invalid ipcm sample size ${l}.`),i.info.codec=null):l===16?i.info.codec="pcm-s16be":l===24?i.info.codec="pcm-s24be":l===32?i.info.codec="pcm-s32be":(console.warn(`Invalid ipcm sample size ${l}.`),i.info.codec=null):i.info.codec==="pcm-f32be"&&(c?l===32?i.info.codec="pcm-f32":l===64?i.info.codec="pcm-f64":(console.warn(`Invalid fpcm sample size ${l}.`),i.info.codec=null):l===32?i.info.codec="pcm-f32be":l===64?i.info.codec="pcm-f64be":(console.warn(`Invalid fpcm sample size ${l}.`),i.info.codec=null));break}case"dOps":{let i=this.currentTrack;if(!i)break;b(i.info?.type==="audio"),e.skip(1);let o=E(e),c=j(e),l=P(e),u=Ft(e),d=E(e),f;d!==0?f=D(e,2+o):f=new Uint8Array(0);let m=new Uint8Array(19+f.byteLength),h=new DataView(m.buffer);h.setUint32(0,1332770163,!1),h.setUint32(4,1214603620,!1),h.setUint8(8,1),h.setUint8(9,o),h.setUint16(10,c,!0),h.setUint32(12,l,!0),h.setInt16(16,u,!0),h.setUint8(18,d),m.set(f,19),i.info.codecDescription=m,i.info.numberOfChannels=o,i.info.sampleRate=l}break;case"dfLa":{let i=this.currentTrack;if(!i)break;b(i.info?.type==="audio"),e.skip(4);let o=127,c=128,l=e.filePos;for(;e.filePos<a;){let h=E(e),g=st(e);if((h&o)===0){e.skip(10);let S=P(e),p=S>>>12,w=(S>>9&7)+1;i.info.sampleRate=p,i.info.numberOfChannels=w,e.skip(20)}else e.skip(g);if(h&c)break}let u=e.filePos;e.filePos=l;let d=D(e,u-l),f=new Uint8Array(4+d.byteLength);new DataView(f.buffer).setUint32(0,1716281667,!1),f.set(d,4),i.info.codecDescription=f}break;case"stts":{let i=this.currentTrack;if(!i||!i.sampleTable)break;e.skip(4);let o=P(e),c=0,l=0;for(let u=0;u<o;u++){let d=P(e),f=P(e);i.sampleTable.sampleTimingEntries.push({startIndex:c,startDecodeTimestamp:l,count:d,delta:f}),c+=d,l+=d*f}}break;case"ctts":{let i=this.currentTrack;if(!i||!i.sampleTable)break;e.skip(4);let o=P(e),c=0;for(let l=0;l<o;l++){let u=P(e),d=be(e);i.sampleTable.sampleCompositionTimeOffsets.push({startIndex:c,count:u,offset:d}),c+=u}}break;case"stsz":{let i=this.currentTrack;if(!i||!i.sampleTable)break;e.skip(4);let o=P(e),c=P(e);if(o===0)for(let l=0;l<c;l++){let u=P(e);i.sampleTable.sampleSizes.push(u)}else i.sampleTable.sampleSizes.push(o)}break;case"stz2":{let i=this.currentTrack;if(!i||!i.sampleTable)break;e.skip(4),e.skip(3);let o=E(e),c=P(e),l=D(e,Math.ceil(c*o/8)),u=new U(l);for(let d=0;d<c;d++){let f=u.readBits(o);i.sampleTable.sampleSizes.push(f)}}break;case"stss":{let i=this.currentTrack;if(!i||!i.sampleTable)break;e.skip(4),i.sampleTable.keySampleIndices=[];let o=P(e);for(let c=0;c<o;c++){let l=P(e)-1;i.sampleTable.keySampleIndices.push(l)}i.sampleTable.keySampleIndices[0]!==0&&i.sampleTable.keySampleIndices.unshift(0)}break;case"stsc":{let i=this.currentTrack;if(!i||!i.sampleTable)break;e.skip(4);let o=P(e);for(let l=0;l<o;l++){let u=P(e)-1,d=P(e),f=P(e);i.sampleTable.sampleToChunk.push({startSampleIndex:-1,startChunkIndex:u,samplesPerChunk:d,sampleDescriptionIndex:f})}let c=0;for(let l=0;l<i.sampleTable.sampleToChunk.length;l++)if(i.sampleTable.sampleToChunk[l].startSampleIndex=c,l<i.sampleTable.sampleToChunk.length-1){let d=i.sampleTable.sampleToChunk[l+1].startChunkIndex-i.sampleTable.sampleToChunk[l].startChunkIndex;c+=d*i.sampleTable.sampleToChunk[l].samplesPerChunk}}break;case"stco":{let i=this.currentTrack;if(!i||!i.sampleTable)break;e.skip(4);let o=P(e);for(let c=0;c<o;c++){let l=P(e);i.sampleTable.chunkOffsets.push(l)}}break;case"co64":{let i=this.currentTrack;if(!i||!i.sampleTable)break;e.skip(4);let o=P(e);for(let c=0;c<o;c++){let l=J(e);i.sampleTable.chunkOffsets.push(l)}}break;case"mvex":this.isFragmented=!0,this.readContiguousBoxes(e.slice(s,n.contentSize));break;case"mehd":{let i=E(e);e.skip(3);let o=i===1?J(e):P(e);this.movieDurationInTimescale=o}break;case"trex":{e.skip(4);let i=P(e),o=P(e),c=P(e),l=P(e),u=P(e);this.fragmentTrackDefaults.push({trackId:i,defaultSampleDescriptionIndex:o,defaultSampleDuration:c,defaultSampleSize:l,defaultSampleFlags:u})}break;case"tfra":{let i=E(e);e.skip(3);let o=P(e),c=this.tracks.find(p=>p.id===o);if(!c)break;c.fragmentLookupTable=[];let l=P(e),u=(l&48)>>4,d=(l&12)>>2,f=l&3,m=[E,j,st,P],h=m[u],g=m[d],y=m[f],S=P(e);for(let p=0;p<S;p++){let w=i===1?J(e):P(e),k=i===1?J(e):P(e);h(e),g(e),y(e),c.fragmentLookupTable.push({timestamp:w,moofOffset:k})}}break;case"moof":{this.currentFragment={moofOffset:t,moofSize:n.totalSize,implicitBaseDataOffset:t,trackData:new Map,dataStart:1/0,dataEnd:0,nextFragment:null,isKnownToBeFirstFragment:!1},this.readContiguousBoxes(e.slice(s,n.contentSize)),te(this.fragments,this.currentFragment,i=>i.moofOffset);for(let[,i]of this.currentFragment.trackData){let o=i.samples[0],c=W(i.samples);this.currentFragment.dataStart=Math.min(this.currentFragment.dataStart,o.byteOffset),this.currentFragment.dataEnd=Math.max(this.currentFragment.dataEnd,c.byteOffset+c.byteSize)}this.currentFragment=null}break;case"traf":if(b(this.currentFragment),this.readContiguousBoxes(e.slice(s,n.contentSize)),this.currentTrack){let i=this.currentFragment.trackData.get(this.currentTrack.id);if(i){te(this.currentTrack.fragments,this.currentFragment,l=>l.moofOffset),i.firstKeyFrameTimestamp!==null&&te(this.currentTrack.fragmentsWithKeyFrame,this.currentFragment,l=>l.moofOffset);let{currentFragmentState:c}=this.currentTrack;b(c),c.startTimestamp!==null&&(Si(i,c.startTimestamp),i.startTimestampIsFinal=!0)}this.currentTrack.currentFragmentState=null,this.currentTrack=null}break;case"tfhd":{b(this.currentFragment),e.skip(1);let i=st(e),o=!!(i&1),c=!!(i&2),l=!!(i&8),u=!!(i&16),d=!!(i&32),f=!!(i&65536),m=!!(i&131072),h=P(e),g=this.tracks.find(S=>S.id===h);if(!g)break;let y=this.fragmentTrackDefaults.find(S=>S.trackId===h);this.currentTrack=g,g.currentFragmentState={baseDataOffset:this.currentFragment.implicitBaseDataOffset,sampleDescriptionIndex:y?.defaultSampleDescriptionIndex??null,defaultSampleDuration:y?.defaultSampleDuration??null,defaultSampleSize:y?.defaultSampleSize??null,defaultSampleFlags:y?.defaultSampleFlags??null,startTimestamp:null},o?g.currentFragmentState.baseDataOffset=J(e):m&&(g.currentFragmentState.baseDataOffset=this.currentFragment.moofOffset),c&&(g.currentFragmentState.sampleDescriptionIndex=P(e)),l&&(g.currentFragmentState.defaultSampleDuration=P(e)),u&&(g.currentFragmentState.defaultSampleSize=P(e)),d&&(g.currentFragmentState.defaultSampleFlags=P(e)),f&&(g.currentFragmentState.defaultSampleDuration=0)}break;case"tfdt":{let i=this.currentTrack;if(!i)break;b(i.currentFragmentState);let o=E(e);e.skip(3);let c=o===0?P(e):J(e);i.currentFragmentState.startTimestamp=c}break;case"trun":{let i=this.currentTrack;if(!i)break;if(b(this.currentFragment),b(i.currentFragmentState),this.currentFragment.trackData.has(i.id)){console.warn("Can't have two trun boxes for the same track in one fragment. Ignoring...");break}let o=E(e),c=st(e),l=!!(c&1),u=!!(c&4),d=!!(c&256),f=!!(c&512),m=!!(c&1024),h=!!(c&2048),g=P(e),y=i.currentFragmentState.baseDataOffset;l&&(y+=be(e));let S=null;u&&(S=P(e));let p=y;if(g===0){this.currentFragment.implicitBaseDataOffset=p;break}let w=0,k={startTimestamp:0,endTimestamp:0,firstKeyFrameTimestamp:null,samples:[],presentationTimestamps:[],startTimestampIsFinal:!1};this.currentFragment.trackData.set(i.id,k);for(let v=0;v<g;v++){let F;d?F=P(e):(b(i.currentFragmentState.defaultSampleDuration!==null),F=i.currentFragmentState.defaultSampleDuration);let A;f?A=P(e):(b(i.currentFragmentState.defaultSampleSize!==null),A=i.currentFragmentState.defaultSampleSize);let _;m?_=P(e):(b(i.currentFragmentState.defaultSampleFlags!==null),_=i.currentFragmentState.defaultSampleFlags),v===0&&S!==null&&(_=S);let B=0;h&&(o===0?B=P(e):B=be(e));let L=!(_&65536);k.samples.push({presentationTimestamp:w+B,duration:F,byteOffset:p,byteSize:A,isKeyFrame:L}),p+=A,w+=F}k.presentationTimestamps=k.samples.map((v,F)=>({presentationTimestamp:v.presentationTimestamp,sampleIndex:F})).sort((v,F)=>v.presentationTimestamp-F.presentationTimestamp);for(let v=0;v<k.presentationTimestamps.length;v++){let F=k.presentationTimestamps[v],A=k.samples[F.sampleIndex];if(k.firstKeyFrameTimestamp===null&&A.isKeyFrame&&(k.firstKeyFrameTimestamp=A.presentationTimestamp),v<k.presentationTimestamps.length-1){let _=k.presentationTimestamps[v+1];A.duration=_.presentationTimestamp-F.presentationTimestamp}}let x=k.samples[k.presentationTimestamps[0].sampleIndex],C=k.samples[W(k.presentationTimestamps).sampleIndex];k.startTimestamp=x.presentationTimestamp,k.endTimestamp=C.presentationTimestamp+C.duration,this.currentFragment.implicitBaseDataOffset=p}break;case"udta":{let i=this.iterateContiguousBoxes(e.slice(s,n.contentSize));for(let{boxInfo:o,slice:c}of i){if(o.name!=="meta"&&!this.currentTrack){let l=c.filePos;this.metadataTags.raw??={},va.has(o.name)?this.metadataTags.raw[o.name]??=re(c):this.metadataTags.raw[o.name]??=D(c,o.contentSize),c.filePos=l}switch(o.name){case"meta":c.skip(-o.headerSize),this.traverseBox(c);break;case"\xA9nam":case"name":this.currentTrack?this.currentTrack.name=G.decode(D(c,o.contentSize)):this.metadataTags.title??=re(c);break;case"\xA9des":this.currentTrack||(this.metadataTags.description??=re(c));break;case"\xA9ART":this.currentTrack||(this.metadataTags.artist??=re(c));break;case"\xA9alb":this.currentTrack||(this.metadataTags.album??=re(c));break;case"albr":this.currentTrack||(this.metadataTags.albumArtist??=re(c));break;case"\xA9gen":this.currentTrack||(this.metadataTags.genre??=re(c));break;case"\xA9day":if(!this.currentTrack){let l=new Date(re(c));Number.isNaN(l.getTime())||(this.metadataTags.date??=l)}break;case"\xA9cmt":this.currentTrack||(this.metadataTags.comment??=re(c));break;case"\xA9lyr":this.currentTrack||(this.metadataTags.lyrics??=re(c));break}}}break;case"meta":{if(this.currentTrack)break;let o=P(e)!==0;this.currentMetadataKeys=new Map,o?this.readContiguousBoxes(e.slice(s,n.contentSize)):this.readContiguousBoxes(e.slice(s+4,n.contentSize-4)),this.currentMetadataKeys=null}break;case"keys":{if(!this.currentMetadataKeys)break;e.skip(4);let i=P(e);for(let o=0;o<i;o++){let c=P(e);e.skip(4);let l=G.decode(D(e,c-8));this.currentMetadataKeys.set(o+1,l)}}break;case"ilst":{if(!this.currentMetadataKeys)break;let i=this.iterateContiguousBoxes(e.slice(s,n.contentSize));for(let{boxInfo:o,slice:c}of i){let l=o.name,u=(l.charCodeAt(0)<<24)+(l.charCodeAt(1)<<16)+(l.charCodeAt(2)<<8)+l.charCodeAt(3);this.currentMetadataKeys.has(u)&&(l=this.currentMetadataKeys.get(u));let d=ri(c);switch(this.metadataTags.raw??={},this.metadataTags.raw[l]??=d,l){case"\xA9nam":case"titl":case"com.apple.quicktime.title":case"title":typeof d=="string"&&(this.metadataTags.title??=d);break;case"\xA9des":case"desc":case"dscp":case"com.apple.quicktime.description":case"description":typeof d=="string"&&(this.metadataTags.description??=d);break;case"\xA9ART":case"com.apple.quicktime.artist":case"artist":typeof d=="string"&&(this.metadataTags.artist??=d);break;case"\xA9alb":case"albm":case"com.apple.quicktime.album":case"album":typeof d=="string"&&(this.metadataTags.album??=d);break;case"aART":case"album_artist":typeof d=="string"&&(this.metadataTags.albumArtist??=d);break;case"\xA9cmt":case"com.apple.quicktime.comment":case"comment":typeof d=="string"&&(this.metadataTags.comment??=d);break;case"\xA9gen":case"gnre":case"com.apple.quicktime.genre":case"genre":typeof d=="string"&&(this.metadataTags.genre??=d);break;case"\xA9lyr":case"lyrics":typeof d=="string"&&(this.metadataTags.lyrics??=d);break;case"\xA9day":case"rldt":case"com.apple.quicktime.creationdate":case"date":if(typeof d=="string"){let f=new Date(d);Number.isNaN(f.getTime())||(this.metadataTags.date??=f)}break;case"covr":case"com.apple.quicktime.artwork":d instanceof ve?(this.metadataTags.images??=[],this.metadataTags.images.push({data:d.data,kind:"coverFront",mimeType:d.mimeType})):d instanceof Uint8Array&&(this.metadataTags.images??=[],this.metadataTags.images.push({data:d,kind:"coverFront",mimeType:"image/*"}));break;case"trkn":if(d instanceof Uint8Array){let f=z(d),m=f.getUint16(2,!1),h=f.getUint16(4,!1);m>0&&(this.metadataTags.trackNumber??=m),h>0&&(this.metadataTags.tracksTotal??=h)}break;case"disc":case"disk":if(d instanceof Uint8Array){let f=z(d),m=f.getUint16(2,!1),h=f.getUint16(4,!1);m>0&&(this.metadataTags.discNumber??=m),h>0&&(this.metadataTags.discsTotal??=h)}break}}}break}return e.filePos=a,!0}},qr=class{constructor(e){this.internalTrack=e,this.packetToSampleIndex=new WeakMap,this.packetToFragmentLocation=new WeakMap}getId(){return this.internalTrack.id}getCodec(){throw new Error("Not implemented on base class.")}getInternalCodecId(){return this.internalTrack.internalCodecId}getName(){return this.internalTrack.name}getLanguageCode(){return this.internalTrack.languageCode}getTimeResolution(){return this.internalTrack.timescale}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}async getFirstTimestamp(){return(await this.getFirstPacket({metadataOnly:!0}))?.timestamp??0}async getFirstPacket(e){let t=await this.fetchPacketForSampleIndex(0,e);return t||!this.internalTrack.demuxer.isFragmented?t:this.performFragmentedLookup(()=>{let n=this.internalTrack.demuxer.fragments[0]??null;if(n?.isKnownToBeFirstFragment){let s=n;for(;s;){if(s.trackData.get(this.internalTrack.id))return{fragmentIndex:M(this.internalTrack.fragments,s.moofOffset,i=>i.moofOffset),sampleIndex:0,correctSampleFound:!0};s=s.nextFragment}}return{fragmentIndex:-1,sampleIndex:-1,correctSampleFound:!1}},-1/0,1/0,e)}mapTimestampIntoTimescale(e){return Ue(e*this.internalTrack.timescale,14)+this.internalTrack.editListOffset}async getPacket(e,t){let n=this.mapTimestampIntoTimescale(e),s=this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack),a=wi(s,n),i=await this.fetchPacketForSampleIndex(a,t);return!Ti(s)||!this.internalTrack.demuxer.isFragmented?i:this.performFragmentedLookup(()=>this.findSampleInFragmentsForTimestamp(n),n,n,t)}async getNextPacket(e,t){let n=this.packetToSampleIndex.get(e);if(n!==void 0)return this.fetchPacketForSampleIndex(n+1,t);let s=this.packetToFragmentLocation.get(e);if(s===void 0)throw new Error("Packet was not created from this track.");let a=s.fragment.trackData.get(this.internalTrack.id),i=M(this.internalTrack.fragments,s.fragment.moofOffset,o=>o.moofOffset);return b(i!==-1),this.performFragmentedLookup(()=>{if(s.sampleIndex+1<a.samples.length)return{fragmentIndex:i,sampleIndex:s.sampleIndex+1,correctSampleFound:!0};{let o=s.fragment;for(;o.nextFragment;)if(o=o.nextFragment,o.trackData.get(this.internalTrack.id)){let l=M(this.internalTrack.fragments,o.moofOffset,u=>u.moofOffset);return b(l!==-1),{fragmentIndex:l,sampleIndex:0,correctSampleFound:!0}}return{fragmentIndex:i,sampleIndex:-1,correctSampleFound:!1}}},-1/0,1/0,t)}async getKeyPacket(e,t){let n=this.mapTimestampIntoTimescale(e),s=this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack),a=wi(s,n),i=a===-1?-1:Ea(s,a),o=await this.fetchPacketForSampleIndex(i,t);return!Ti(s)||!this.internalTrack.demuxer.isFragmented?o:this.performFragmentedLookup(()=>this.findKeySampleInFragmentsForTimestamp(n),n,n,t)}async getNextKeyPacket(e,t){let n=this.packetToSampleIndex.get(e);if(n!==void 0){let o=this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack),c=_a(o,n);return this.fetchPacketForSampleIndex(c,t)}let s=this.packetToFragmentLocation.get(e);if(s===void 0)throw new Error("Packet was not created from this track.");let a=s.fragment.trackData.get(this.internalTrack.id),i=M(this.internalTrack.fragments,s.fragment.moofOffset,o=>o.moofOffset);return b(i!==-1),this.performFragmentedLookup(()=>{let o=a.samples.findIndex((c,l)=>c.isKeyFrame&&l>s.sampleIndex);if(o!==-1)return{fragmentIndex:i,sampleIndex:o,correctSampleFound:!0};{let c=s.fragment;for(;c.nextFragment;){c=c.nextFragment;let l=c.trackData.get(this.internalTrack.id);if(l&&l.firstKeyFrameTimestamp!==null){let u=M(this.internalTrack.fragments,c.moofOffset,f=>f.moofOffset);b(u!==-1);let d=l.samples.findIndex(f=>f.isKeyFrame);return b(d!==-1),{fragmentIndex:u,sampleIndex:d,correctSampleFound:!0}}}return{fragmentIndex:i,sampleIndex:-1,correctSampleFound:!1}}},-1/0,1/0,t)}async fetchPacketForSampleIndex(e,t){if(e===-1)return null;let n=this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack),s=Ia(n,e);if(!s)return null;let a;if(t.metadataOnly)a=$;else{let l=this.internalTrack.demuxer.reader.requestSlice(s.sampleOffset,s.sampleSize);l instanceof Promise&&(l=await l),b(l),a=D(l,s.sampleSize)}let i=(s.presentationTimestamp-this.internalTrack.editListOffset)/this.internalTrack.timescale,o=s.duration/this.internalTrack.timescale,c=new N(a,s.isKeyFrame?"key":"delta",i,o,e,s.sampleSize);return this.packetToSampleIndex.set(c,e),c}async fetchPacketInFragment(e,t,n){if(t===-1)return null;let a=e.trackData.get(this.internalTrack.id).samples[t];b(a);let i;if(n.metadataOnly)i=$;else{let u=this.internalTrack.demuxer.reader.requestSlice(a.byteOffset,a.byteSize);u instanceof Promise&&(u=await u),b(u),i=D(u,a.byteSize)}let o=(a.presentationTimestamp-this.internalTrack.editListOffset)/this.internalTrack.timescale,c=a.duration/this.internalTrack.timescale,l=new N(i,a.isKeyFrame?"key":"delta",o,c,e.moofOffset+t,a.byteSize);return this.packetToFragmentLocation.set(l,{fragment:e,sampleIndex:t}),l}findSampleInFragmentsForTimestamp(e){let t=R(this.internalTrack.fragments,e,a=>a.trackData.get(this.internalTrack.id).startTimestamp),n=-1,s=!1;if(t!==-1){let i=this.internalTrack.fragments[t].trackData.get(this.internalTrack.id),o=R(i.presentationTimestamps,e,c=>c.presentationTimestamp);b(o!==-1),n=i.presentationTimestamps[o].sampleIndex,s=e<i.endTimestamp}return{fragmentIndex:t,sampleIndex:n,correctSampleFound:s}}findKeySampleInFragmentsForTimestamp(e){let t=R(this.internalTrack.fragmentsWithKeyFrame,e,i=>i.trackData.get(this.internalTrack.id).startTimestamp),n=-1,s=-1,a=!1;if(t!==-1){let i=this.internalTrack.fragmentsWithKeyFrame[t];n=M(this.internalTrack.fragments,i.moofOffset,u=>u.moofOffset),b(n!==-1);let o=i.trackData.get(this.internalTrack.id),c=br(o.presentationTimestamps,u=>o.samples[u.sampleIndex].isKeyFrame&&u.presentationTimestamp<=e);b(c!==-1),s=o.presentationTimestamps[c].sampleIndex,a=e<o.endTimestamp}return{fragmentIndex:n,sampleIndex:s,correctSampleFound:a}}async performFragmentedLookup(e,t,n,s){let a=this.internalTrack.demuxer,i=await a.fragmentLookupMutex.acquire();try{let{fragmentIndex:o,sampleIndex:c,correctSampleFound:l}=e();if(l){let p=this.internalTrack.fragments[o];return this.fetchPacketInFragment(p,c,s)}let u=null,d=o,f=c,m=this.internalTrack.fragmentLookupTable?R(this.internalTrack.fragmentLookupTable,t,p=>p.timestamp):-1,h=m!==-1?this.internalTrack.fragmentLookupTable[m]:null,g,y=!1;if(o===-1)g=h?.moofOffset??0,y=g===0;else{let p=this.internalTrack.fragments[o];!h||p.moofOffset>=h.moofOffset?(g=p.moofOffset+p.moofSize,u=p):g=h.moofOffset}for(;;){if(u){let x=u.trackData.get(this.internalTrack.id);if(x&&x.startTimestamp>n)break;if(u.nextFragment){g=u.nextFragment.moofOffset+u.nextFragment.moofSize,u=u.nextFragment;continue}}let p=a.reader.requestSliceRange(g,ye,qe);if(p instanceof Promise&&(p=await p),!p)break;let w=g,k=ue(p);if(!k)break;if(k.name==="moof"){let x=M(a.fragments,w,_=>_.moofOffset),C;x===-1?C=await a.readFragment(w):C=a.fragments[x],u&&(u.nextFragment=C),u=C,y&&(C.isKnownToBeFirstFragment=!0,y=!1);let{fragmentIndex:v,sampleIndex:F,correctSampleFound:A}=e();if(A){let _=this.internalTrack.fragments[v];return this.fetchPacketInFragment(_,F,s)}v!==-1&&(d=v,f=F)}g=w+k.totalSize}let S=d!==-1?this.internalTrack.fragments[d]:null;if(h&&(!S||S.moofOffset<h.moofOffset)){let w=this.internalTrack.fragmentLookupTable[m-1]?.timestamp??-1/0;return this.performFragmentedLookup(e,w,n,s)}return S?this.fetchPacketInFragment(S,f,s):null}finally{i()}}},Qn=class extends qr{constructor(e){super(e),this.decoderConfigPromise=null,this.internalTrack=e}getCodec(){return this.internalTrack.info.codec}getCodedWidth(){return this.internalTrack.info.width}getCodedHeight(){return this.internalTrack.info.height}getRotation(){return this.internalTrack.rotation}async getColorSpace(){return{primaries:this.internalTrack.info.colorSpace?.primaries,transfer:this.internalTrack.info.colorSpace?.transfer,matrix:this.internalTrack.info.colorSpace?.matrix,fullRange:this.internalTrack.info.colorSpace?.fullRange}}async getDecoderConfig(){return this.internalTrack.info.codec?this.decoderConfigPromise??=(async()=>{if(this.internalTrack.info.codec==="vp9"&&!this.internalTrack.info.vp9CodecInfo){let e=await this.getFirstPacket({});this.internalTrack.info.vp9CodecInfo=e&&Ir(e.data)}else if(this.internalTrack.info.codec==="av1"&&!this.internalTrack.info.av1CodecInfo){let e=await this.getFirstPacket({});this.internalTrack.info.av1CodecInfo=e&&Er(e.data)}return{codec:Tr(this.internalTrack.info),codedWidth:this.internalTrack.info.width,codedHeight:this.internalTrack.info.height,description:this.internalTrack.info.codecDescription??void 0,colorSpace:this.internalTrack.info.colorSpace??void 0}})():null}},Zn=class extends qr{constructor(e){super(e),this.decoderConfig=null,this.internalTrack=e}getCodec(){return this.internalTrack.info.codec}getNumberOfChannels(){return this.internalTrack.info.numberOfChannels}getSampleRate(){return this.internalTrack.info.sampleRate}async getDecoderConfig(){return this.internalTrack.info.codec?this.decoderConfig??={codec:Pr(this.internalTrack.info),numberOfChannels:this.internalTrack.info.numberOfChannels,sampleRate:this.internalTrack.info.sampleRate,description:this.internalTrack.info.codecDescription??void 0}:null}},wi=(r,e)=>{if(r.presentationTimestamps){let t=R(r.presentationTimestamps,e,n=>n.presentationTimestamp);return t===-1?-1:r.presentationTimestamps[t].sampleIndex}else{let t=R(r.sampleTimingEntries,e,s=>s.startDecodeTimestamp);if(t===-1)return-1;let n=r.sampleTimingEntries[t];return n.startIndex+Math.min(Math.floor((e-n.startDecodeTimestamp)/n.delta),n.count-1)}},Ia=(r,e)=>{let t=R(r.sampleTimingEntries,e,S=>S.startIndex),n=r.sampleTimingEntries[t];if(!n||n.startIndex+n.count<=e)return null;let a=n.startDecodeTimestamp+(e-n.startIndex)*n.delta,i=R(r.sampleCompositionTimeOffsets,e,S=>S.startIndex),o=r.sampleCompositionTimeOffsets[i];o&&e-o.startIndex<o.count&&(a+=o.offset);let c=r.sampleSizes[Math.min(e,r.sampleSizes.length-1)],l=R(r.sampleToChunk,e,S=>S.startSampleIndex),u=r.sampleToChunk[l];b(u);let d=u.startChunkIndex+Math.floor((e-u.startSampleIndex)/u.samplesPerChunk),f=r.chunkOffsets[d],m=u.startSampleIndex+(d-u.startChunkIndex)*u.samplesPerChunk,h=0,g=f;if(r.sampleSizes.length===1)g+=c*(e-m),h+=c*u.samplesPerChunk;else for(let S=m;S<m+u.samplesPerChunk;S++){let p=r.sampleSizes[S];S<e&&(g+=p),h+=p}let y=n.delta;if(r.presentationTimestamps){let S=r.presentationTimestampIndexMap[e];b(S!==void 0),S<r.presentationTimestamps.length-1&&(y=r.presentationTimestamps[S+1].presentationTimestamp-a)}return{presentationTimestamp:a,duration:y,sampleOffset:g,sampleSize:c,chunkOffset:f,chunkSize:h,isKeyFrame:r.keySampleIndices?M(r.keySampleIndices,e,S=>S)!==-1:!0}},Ea=(r,e)=>{if(!r.keySampleIndices)return e;let t=R(r.keySampleIndices,e,n=>n);return r.keySampleIndices[t]??-1},_a=(r,e)=>{if(!r.keySampleIndices)return e+1;let t=R(r.keySampleIndices,e,n=>n);return r.keySampleIndices[t+1]??-1},Si=(r,e)=>{r.startTimestamp+=e,r.endTimestamp+=e;for(let t of r.samples)t.presentationTimestamp+=e;for(let t of r.presentationTimestamps)t.presentationTimestamp+=e},Aa=r=>{let[e,,,t]=r,n=Math.hypot(e,t),s=e/n,a=t/n,i=-Math.atan2(a,s)*(180/Math.PI);return Number.isFinite(i)?i:0},Ti=r=>r.sampleSizes.length===0;var we;(function(r){r[r.None=0]="None",r[r.Xiph=1]="Xiph",r[r.FixedSize=2]="FixedSize",r[r.Ebml=3]="Ebml"})(we||(we={}));var Yn=[{id:T.SeekHead,flag:"seekHeadSeen"},{id:T.Info,flag:"infoSeen"},{id:T.Tracks,flag:"tracksSeen"},{id:T.Cues,flag:"cuesSeen"}],Pi=10*2**20,jr=class extends Y{constructor(e){super(e),this.readMetadataPromise=null,this.segments=[],this.currentSegment=null,this.currentTrack=null,this.currentCluster=null,this.currentBlock=null,this.currentCueTime=null,this.currentTagTargetIsMovie=!0,this.currentSimpleTagName=null,this.currentAttachedFile=null,this.isWebM=!1,this.reader=e._reader}async computeDuration(){let e=await this.getTracks(),t=await Promise.all(e.map(n=>n.computeDuration()));return Math.max(0,...t)}async getTracks(){return await this.readMetadata(),this.segments.flatMap(e=>e.tracks.map(t=>t.inputTrack))}async getMimeType(){await this.readMetadata();let e=await this.getTracks(),t=await Promise.all(e.map(n=>n.getCodecParameterString()));return si({isWebM:this.isWebM,hasVideo:this.segments.some(n=>n.tracks.some(s=>s.info?.type==="video")),hasAudio:this.segments.some(n=>n.tracks.some(s=>s.info?.type==="audio")),codecStrings:t.filter(Boolean)})}async getMetadataTags(){await this.readMetadata();for(let t of this.segments)t.metadataTagsCollected||(this.reader.fileSize!==null&&await this.loadSegmentMetadata(t),t.metadataTagsCollected=!0);let e={};for(let t of this.segments)e={...e,...t.metadataTags};return e}readMetadata(){return this.readMetadataPromise??=(async()=>{let e=0;for(;;){let t=this.reader.requestSliceRange(e,Z,ne);if(t instanceof Promise&&(t=await t),!t)break;let n=se(t);if(!n)break;let s=n.id,a=n.size,i=t.filePos;if(s===T.EBML){ke(a);let o=this.reader.requestSlice(i,a);if(o instanceof Promise&&(o=await o),!o)break;this.readContiguousElements(o)}else if(s===T.Segment){if(await this.readSegment(i,a),a===null||this.reader.fileSize===null)break}else if(s===T.Cluster){if(this.reader.fileSize===null)break;a===null&&(a=(await zr(this.reader,i,Br,this.reader.fileSize)).pos-i);let o=W(this.segments);o&&(o.elementEndPos=i+a)}ke(a),e=i+a}})()}async readSegment(e,t){this.currentSegment={seekHeadSeen:!1,infoSeen:!1,tracksSeen:!1,cuesSeen:!1,tagsSeen:!1,attachmentsSeen:!1,timestampScale:-1,timestampFactor:-1,duration:-1,seekEntries:[],tracks:[],cuePoints:[],dataStartPos:e,elementEndPos:t===null?null:e+t,clusterSeekStartPos:e,clusters:[],clusterLookupMutex:new ee,metadataTags:{},metadataTagsCollected:!1},this.segments.push(this.currentSegment);let n=e;for(;this.currentSegment.elementEndPos===null||n<this.currentSegment.elementEndPos;){let c=this.reader.requestSliceRange(n,Z,ne);if(c instanceof Promise&&(c=await c),!c)break;let l=n,u=se(c);if(!u||!it.includes(u.id)&&u.id!==T.Void){let g=await Hn(this.reader,l,it,Math.min(this.currentSegment.elementEndPos??1/0,l+Pi));if(g){n=g;continue}else break}let{id:d,size:f}=u,m=c.filePos,h=Yn.findIndex(g=>g.id===d);if(h!==-1){let g=Yn[h].flag;this.currentSegment[g]=!0,ke(f);let y=this.reader.requestSlice(m,f);y instanceof Promise&&(y=await y),y&&this.readContiguousElements(y)}else if(d===T.Tags||d===T.Attachments){d===T.Tags?this.currentSegment.tagsSeen=!0:this.currentSegment.attachmentsSeen=!0,ke(f);let g=this.reader.requestSlice(m,f);g instanceof Promise&&(g=await g),g&&this.readContiguousElements(g)}else if(d===T.Cluster){this.currentSegment.clusterSeekStartPos=l;break}if(f===null)break;n=m+f}if(this.currentSegment.seekEntries.sort((c,l)=>c.segmentPosition-l.segmentPosition),this.reader.fileSize!==null)for(let c of this.currentSegment.seekEntries){let l=Yn.find(g=>g.id===c.id);if(!l||this.currentSegment[l.flag])continue;let u=this.reader.requestSliceRange(e+c.segmentPosition,Z,ne);if(u instanceof Promise&&(u=await u),!u)continue;let d=se(u);if(!d)continue;let{id:f,size:m}=d;if(f!==l.id)continue;ke(m),this.currentSegment[l.flag]=!0;let h=this.reader.requestSlice(u.filePos,m);h instanceof Promise&&(h=await h),h&&this.readContiguousElements(h)}this.currentSegment.timestampScale===-1&&(this.currentSegment.timestampScale=1e6,this.currentSegment.timestampFactor=1e9/1e6),this.currentSegment.tracks.sort((c,l)=>Number(l.isDefault)-Number(c.isDefault)),this.currentSegment.cuePoints.sort((c,l)=>c.clusterPosition-l.clusterPosition);let s=this.currentSegment.tracks.map(c=>c.id),a=new Set,i=null,o=null;for(let c of this.currentSegment.cuePoints){if(c.clusterPosition!==i){for(let u of a)b(o),this.currentSegment.tracks.find(f=>f.id===u).cuePoints.push(o);for(let u of s)a.add(u)}if(o=c,!a.has(c.trackId))continue;this.currentSegment.tracks.find(u=>u.id===c.trackId).cuePoints.push(c),a.delete(c.trackId),i=c.clusterPosition}for(let c of a)b(o),this.currentSegment.tracks.find(u=>u.id===c).cuePoints.push(o);for(let c of this.currentSegment.tracks)c.cuePoints.sort((l,u)=>l.time-u.time);this.currentSegment=null}async readCluster(e,t){let n=this.reader.requestSliceRange(e,Z,ne);n instanceof Promise&&(n=await n),b(n);let s=e,a=se(n);b(a);let i=a.id,o=a.size,c=n.filePos;o===null&&(o=(await zr(this.reader,c,Br,t.elementEndPos)).pos-c),b(i===T.Cluster);let l=this.reader.requestSlice(c,o);l instanceof Promise&&(l=await l);let u={elementStartPos:s,elementEndPos:c+o,dataStartPos:c,timestamp:-1,trackData:new Map,nextCluster:null,isKnownToBeFirstCluster:!1};this.currentCluster=u,l&&this.readContiguousElements(l);for(let[d,f]of u.trackData){let m=t.tracks.find(p=>p.id===d)??null;b(f.blocks.length>0);let h=!1,g=!1;for(let p=0;p<f.blocks.length;p++){let w=f.blocks[p];w.timestamp+=u.timestamp,h||=w.referencedTimestamps.length>0,g||=w.lacing!==we.None}h&&(f.blocks=Fa(f.blocks)),f.presentationTimestamps=f.blocks.map((p,w)=>({timestamp:p.timestamp,blockIndex:w})).sort((p,w)=>p.timestamp-w.timestamp);for(let p=0;p<f.presentationTimestamps.length;p++){let w=f.presentationTimestamps[p],k=f.blocks[w.blockIndex];if(f.firstKeyFrameTimestamp===null&&k.isKeyFrame&&(f.firstKeyFrameTimestamp=k.timestamp),p<f.presentationTimestamps.length-1){let x=f.presentationTimestamps[p+1];k.duration=x.timestamp-k.timestamp}else k.duration===0&&m?.defaultDuration!=null&&k.lacing===we.None&&(k.duration=m.defaultDuration)}g&&(this.expandLacedBlocks(f.blocks,m),f.presentationTimestamps=f.blocks.map((p,w)=>({timestamp:p.timestamp,blockIndex:w})).sort((p,w)=>p.timestamp-w.timestamp));let y=f.blocks[f.presentationTimestamps[0].blockIndex],S=f.blocks[W(f.presentationTimestamps).blockIndex];f.startTimestamp=y.timestamp,f.endTimestamp=S.timestamp+S.duration,m&&(te(m.clusters,u,w=>w.elementStartPos),f.firstKeyFrameTimestamp!==null&&te(m.clustersWithKeyFrame,u,w=>w.elementStartPos))}return te(t.clusters,u,d=>d.elementStartPos),this.currentCluster=null,u}getTrackDataInCluster(e,t){let n=e.trackData.get(t);return n||(n={startTimestamp:0,endTimestamp:0,firstKeyFrameTimestamp:null,blocks:[],presentationTimestamps:[]},e.trackData.set(t,n)),n}expandLacedBlocks(e,t){for(let n=0;n<e.length;n++){let s=e[n];if(s.lacing===we.None)continue;let a=rt.tempFromBytes(s.data),i=[],o=E(a)+1;switch(s.lacing){case we.Xiph:{let c=0;for(let l=0;l<o-1;l++){let u=0;for(;a.bufferPos<a.length;){let d=E(a);if(u+=d,d<255){i.push(u),c+=u;break}}}i.push(a.length-(a.bufferPos+c))}break;case we.FixedSize:{let c=a.length-1,l=Math.floor(c/o);for(let u=0;u<o;u++)i.push(l)}break;case we.Ebml:{let c=at(a);b(c!==null);let l=c;i.push(l);let u=l;for(let d=1;d<o-1;d++){let f=a.bufferPos,m=at(a);b(m!==null);let h=m,y=(1<<(a.bufferPos-f)*7-1)-1,S=h-y;l+=S,i.push(l),u+=l}i.push(a.length-(a.bufferPos+u))}break;default:b(!1)}b(i.length===o),e.splice(n,1);for(let c=0;c<o;c++){let l=i[c],u=D(a,l),d=s.duration||o*(t?.defaultDuration??0),f=s.timestamp+d*c/o,m=d/o;e.splice(n+c,0,{timestamp:f,duration:m,isKeyFrame:s.isKeyFrame,referencedTimestamps:s.referencedTimestamps,data:u,lacing:we.None})}n+=o,n--}}async loadSegmentMetadata(e){for(let t of e.seekEntries){if(!(t.id===T.Tags&&!e.tagsSeen)){if(!(t.id===T.Attachments&&!e.attachmentsSeen))continue}let n=this.reader.requestSliceRange(e.dataStartPos+t.segmentPosition,Z,ne);if(n instanceof Promise&&(n=await n),!n)continue;let s=se(n);if(!s||s.id!==t.id)continue;let{size:a}=s;ke(a),b(!this.currentSegment),this.currentSegment=e;let i=this.reader.requestSlice(n.filePos,a);i instanceof Promise&&(i=await i),i&&this.readContiguousElements(i),this.currentSegment=null,t.id===T.Tags?e.tagsSeen=!0:t.id===T.Attachments&&(e.attachmentsSeen=!0)}}readContiguousElements(e){let t=e.filePos;for(;e.filePos-t<=e.length-Z&&this.traverseElement(e););}traverseElement(e){let t=se(e);if(!t)return!1;let{id:n,size:s}=t,a=e.filePos;switch(ke(s),n){case T.DocType:this.isWebM=Ee(e,s)==="webm";break;case T.Seek:{if(!this.currentSegment)break;let i={id:-1,segmentPosition:-1};this.currentSegment.seekEntries.push(i),this.readContiguousElements(e.slice(a,s)),(i.id===-1||i.segmentPosition===-1)&&this.currentSegment.seekEntries.pop()}break;case T.SeekID:{let i=this.currentSegment?.seekEntries[this.currentSegment.seekEntries.length-1];if(!i)break;i.id=O(e,s)}break;case T.SeekPosition:{let i=this.currentSegment?.seekEntries[this.currentSegment.seekEntries.length-1];if(!i)break;i.segmentPosition=O(e,s)}break;case T.TimestampScale:{if(!this.currentSegment)break;this.currentSegment.timestampScale=O(e,s),this.currentSegment.timestampFactor=1e9/this.currentSegment.timestampScale}break;case T.Duration:{if(!this.currentSegment)break;this.currentSegment.duration=Or(e,s)}break;case T.TrackEntry:{if(!this.currentSegment)break;if(this.currentTrack={id:-1,segment:this.currentSegment,demuxer:this,clusters:[],clustersWithKeyFrame:[],cuePoints:[],isDefault:!1,inputTrack:null,codecId:null,codecPrivate:null,defaultDuration:null,name:null,languageCode:q,info:null},this.readContiguousElements(e.slice(a,s)),this.currentTrack&&this.currentTrack.id!==-1&&this.currentTrack.codecId&&this.currentTrack.info){let i=this.currentTrack.codecId.indexOf("/"),o=i===-1?this.currentTrack.codecId:this.currentTrack.codecId.slice(0,i);if(this.currentTrack.info.type==="video"&&this.currentTrack.info.width!==-1&&this.currentTrack.info.height!==-1){this.currentTrack.codecId===ie.avc?(this.currentTrack.info.codec="avc",this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate):this.currentTrack.codecId===ie.hevc?(this.currentTrack.info.codec="hevc",this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate):o===ie.vp8?this.currentTrack.info.codec="vp8":o===ie.vp9?this.currentTrack.info.codec="vp9":o===ie.av1&&(this.currentTrack.info.codec="av1");let c=this.currentTrack,l=new de(new Jn(c));this.currentTrack.inputTrack=l,this.currentSegment.tracks.push(this.currentTrack)}else if(this.currentTrack.info.type==="audio"&&this.currentTrack.info.numberOfChannels!==-1&&this.currentTrack.info.sampleRate!==-1){o===ie.aac?(this.currentTrack.info.codec="aac",this.currentTrack.info.aacCodecInfo={isMpeg2:this.currentTrack.codecId.includes("MPEG2")},this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate):this.currentTrack.codecId===ie.mp3?this.currentTrack.info.codec="mp3":o===ie.opus?(this.currentTrack.info.codec="opus",this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate):o===ie.vorbis?(this.currentTrack.info.codec="vorbis",this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate):o===ie.flac?(this.currentTrack.info.codec="flac",this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate):this.currentTrack.codecId==="A_PCM/INT/LIT"?this.currentTrack.info.bitDepth===8?this.currentTrack.info.codec="pcm-u8":this.currentTrack.info.bitDepth===16?this.currentTrack.info.codec="pcm-s16":this.currentTrack.info.bitDepth===24?this.currentTrack.info.codec="pcm-s24":this.currentTrack.info.bitDepth===32&&(this.currentTrack.info.codec="pcm-s32"):this.currentTrack.codecId==="A_PCM/INT/BIG"?this.currentTrack.info.bitDepth===8?this.currentTrack.info.codec="pcm-u8":this.currentTrack.info.bitDepth===16?this.currentTrack.info.codec="pcm-s16be":this.currentTrack.info.bitDepth===24?this.currentTrack.info.codec="pcm-s24be":this.currentTrack.info.bitDepth===32&&(this.currentTrack.info.codec="pcm-s32be"):this.currentTrack.codecId==="A_PCM/FLOAT/IEEE"&&(this.currentTrack.info.bitDepth===32?this.currentTrack.info.codec="pcm-f32":this.currentTrack.info.bitDepth===64&&(this.currentTrack.info.codec="pcm-f64"));let c=this.currentTrack,l=new K(new es(c));this.currentTrack.inputTrack=l,this.currentSegment.tracks.push(this.currentTrack)}}this.currentTrack=null}break;case T.TrackNumber:{if(!this.currentTrack)break;this.currentTrack.id=O(e,s)}break;case T.TrackType:{if(!this.currentTrack)break;let i=O(e,s);i===1?this.currentTrack.info={type:"video",width:-1,height:-1,rotation:0,codec:null,codecDescription:null,colorSpace:null}:i===2&&(this.currentTrack.info={type:"audio",numberOfChannels:-1,sampleRate:-1,bitDepth:-1,codec:null,codecDescription:null,aacCodecInfo:null})}break;case T.FlagEnabled:{if(!this.currentTrack)break;O(e,s)||(this.currentSegment.tracks.pop(),this.currentTrack=null)}break;case T.FlagDefault:{if(!this.currentTrack)break;this.currentTrack.isDefault=!!O(e,s)}break;case T.CodecID:{if(!this.currentTrack)break;this.currentTrack.codecId=Ee(e,s)}break;case T.CodecPrivate:{if(!this.currentTrack)break;this.currentTrack.codecPrivate=D(e,s)}break;case T.DefaultDuration:{if(!this.currentTrack)break;this.currentTrack.defaultDuration=this.currentTrack.segment.timestampFactor*O(e,s)/1e9}break;case T.Name:{if(!this.currentTrack)break;this.currentTrack.name=ot(e,s)}break;case T.Language:{if(!this.currentTrack||this.currentTrack.languageCode!==q)break;this.currentTrack.languageCode=Ee(e,s),kr(this.currentTrack.languageCode)||(this.currentTrack.languageCode=q)}break;case T.LanguageBCP47:{if(!this.currentTrack)break;let o=Ee(e,s).split("-")[0];o?this.currentTrack.languageCode=o:this.currentTrack.languageCode=q}break;case T.Video:{if(this.currentTrack?.info?.type!=="video")break;this.readContiguousElements(e.slice(a,s))}break;case T.PixelWidth:{if(this.currentTrack?.info?.type!=="video")break;this.currentTrack.info.width=O(e,s)}break;case T.PixelHeight:{if(this.currentTrack?.info?.type!=="video")break;this.currentTrack.info.height=O(e,s)}break;case T.Colour:{if(this.currentTrack?.info?.type!=="video")break;this.currentTrack.info.colorSpace={},this.readContiguousElements(e.slice(a,s))}break;case T.MatrixCoefficients:{if(this.currentTrack?.info?.type!=="video"||!this.currentTrack.info.colorSpace)break;let i=O(e,s),o=gr[i]??null;this.currentTrack.info.colorSpace.matrix=o}break;case T.Range:{if(this.currentTrack?.info?.type!=="video"||!this.currentTrack.info.colorSpace)break;this.currentTrack.info.colorSpace.fullRange=O(e,s)===2}break;case T.TransferCharacteristics:{if(this.currentTrack?.info?.type!=="video"||!this.currentTrack.info.colorSpace)break;let i=O(e,s),o=pr[i]??null;this.currentTrack.info.colorSpace.transfer=o}break;case T.Primaries:{if(this.currentTrack?.info?.type!=="video"||!this.currentTrack.info.colorSpace)break;let i=O(e,s),o=hr[i]??null;this.currentTrack.info.colorSpace.primaries=o}break;case T.Projection:{if(this.currentTrack?.info?.type!=="video")break;this.readContiguousElements(e.slice(a,s))}break;case T.ProjectionPoseRoll:{if(this.currentTrack?.info?.type!=="video")break;let o=-Or(e,s);try{this.currentTrack.info.rotation=mr(o)}catch{}}break;case T.Audio:{if(this.currentTrack?.info?.type!=="audio")break;this.readContiguousElements(e.slice(a,s))}break;case T.SamplingFrequency:{if(this.currentTrack?.info?.type!=="audio")break;this.currentTrack.info.sampleRate=Or(e,s)}break;case T.Channels:{if(this.currentTrack?.info?.type!=="audio")break;this.currentTrack.info.numberOfChannels=O(e,s)}break;case T.BitDepth:{if(this.currentTrack?.info?.type!=="audio")break;this.currentTrack.info.bitDepth=O(e,s)}break;case T.CuePoint:{if(!this.currentSegment)break;this.readContiguousElements(e.slice(a,s)),this.currentCueTime=null}break;case T.CueTime:this.currentCueTime=O(e,s);break;case T.CueTrackPositions:{if(this.currentCueTime===null)break;b(this.currentSegment);let i={time:this.currentCueTime,trackId:-1,clusterPosition:-1};this.currentSegment.cuePoints.push(i),this.readContiguousElements(e.slice(a,s)),(i.trackId===-1||i.clusterPosition===-1)&&this.currentSegment.cuePoints.pop()}break;case T.CueTrack:{let i=this.currentSegment?.cuePoints[this.currentSegment.cuePoints.length-1];if(!i)break;i.trackId=O(e,s)}break;case T.CueClusterPosition:{let i=this.currentSegment?.cuePoints[this.currentSegment.cuePoints.length-1];if(!i)break;b(this.currentSegment),i.clusterPosition=this.currentSegment.dataStartPos+O(e,s)}break;case T.Timestamp:{if(!this.currentCluster)break;this.currentCluster.timestamp=O(e,s)}break;case T.SimpleBlock:{if(!this.currentCluster)break;let i=at(e);if(i===null)break;let o=Ft(e),c=E(e),l=!!(c&128),u=c>>1&3;this.getTrackDataInCluster(this.currentCluster,i).blocks.push({timestamp:o,duration:0,isKeyFrame:l,referencedTimestamps:[],data:D(e,s-(e.filePos-a)),lacing:u})}break;case T.BlockGroup:{if(!this.currentCluster)break;if(this.readContiguousElements(e.slice(a,s)),this.currentBlock){for(let i=0;i<this.currentBlock.referencedTimestamps.length;i++)this.currentBlock.referencedTimestamps[i]+=this.currentBlock.timestamp;this.currentBlock=null}}break;case T.Block:{if(!this.currentCluster)break;let i=at(e);if(i===null)break;let o=Ft(e),l=E(e)>>1&3,u=this.getTrackDataInCluster(this.currentCluster,i);this.currentBlock={timestamp:o,duration:0,isKeyFrame:!0,referencedTimestamps:[],data:D(e,s-(e.filePos-a)),lacing:l},u.blocks.push(this.currentBlock)}break;case T.BlockDuration:{if(!this.currentBlock)break;this.currentBlock.duration=O(e,s)}break;case T.ReferenceBlock:{if(!this.currentBlock)break;this.currentBlock.isKeyFrame=!1;let i=ni(e,s);this.currentBlock.referencedTimestamps.push(i)}break;case T.Tag:this.currentTagTargetIsMovie=!0,this.readContiguousElements(e.slice(a,s));break;case T.Targets:this.readContiguousElements(e.slice(a,s));break;case T.TargetTypeValue:O(e,s)!==50&&(this.currentTagTargetIsMovie=!1);break;case T.TagTrackUID:case T.TagEditionUID:case T.TagChapterUID:case T.TagAttachmentUID:this.currentTagTargetIsMovie=!1;break;case T.SimpleTag:{if(!this.currentTagTargetIsMovie)break;this.currentSimpleTagName=null,this.readContiguousElements(e.slice(a,s))}break;case T.TagName:this.currentSimpleTagName=ot(e,s);break;case T.TagString:{if(!this.currentSimpleTagName)break;let i=ot(e,s);this.processTagValue(this.currentSimpleTagName,i)}break;case T.TagBinary:{if(!this.currentSimpleTagName)break;let i=D(e,s);this.processTagValue(this.currentSimpleTagName,i)}break;case T.AttachedFile:{if(!this.currentSegment)break;if(this.currentAttachedFile={fileName:null,fileMediaType:null,fileData:null,fileDescription:null},this.readContiguousElements(e.slice(a,s)),this.currentAttachedFile.fileMediaType?.startsWith("image/")&&this.currentAttachedFile.fileData){let i=this.currentAttachedFile.fileName,o="unknown";if(i){let c=i.toLowerCase();c.startsWith("cover.")?o="coverFront":c.startsWith("back.")&&(o="coverBack")}this.currentSegment.metadataTags.images??=[],this.currentSegment.metadataTags.images.push({data:this.currentAttachedFile.fileData,mimeType:this.currentAttachedFile.fileMediaType,kind:o,name:this.currentAttachedFile.fileName??void 0,description:this.currentAttachedFile.fileDescription??void 0})}this.currentAttachedFile=null}break;case T.FileName:{if(!this.currentAttachedFile)break;this.currentAttachedFile.fileName=ot(e,s)}break;case T.FileMediaType:{if(!this.currentAttachedFile)break;this.currentAttachedFile.fileMediaType=Ee(e,s)}break;case T.FileData:{if(!this.currentAttachedFile)break;this.currentAttachedFile.fileData=D(e,s)}break;case T.FileDescription:{if(!this.currentAttachedFile)break;this.currentAttachedFile.fileDescription=ot(e,s)}break}return e.filePos=a+s,!0}processTagValue(e,t){if(!this.currentSegment?.metadataTags)return;let n=this.currentSegment.metadataTags;if(n.raw??={},n.raw[e]??=t,typeof t=="string")switch(e.toLowerCase()){case"title":n.title??=t;break;case"description":n.description??=t;break;case"artist":n.artist??=t;break;case"album":n.album??=t;break;case"album_artist":n.albumArtist??=t;break;case"genre":n.genre??=t;break;case"comment":n.comment??=t;break;case"lyrics":n.lyrics??=t;break;case"date":{let s=new Date(t);Number.isNaN(s.getTime())||(n.date??=s)}break;case"track_number":case"part_number":{let s=t.split("/"),a=Number.parseInt(s[0],10),i=s[1]&&Number.parseInt(s[1],10);Number.isInteger(a)&&a>0&&(n.trackNumber??=a),i&&Number.isInteger(i)&&i>0&&(n.tracksTotal??=i)}break;case"disc_number":case"disc":{let s=t.split("/"),a=Number.parseInt(s[0],10),i=s[1]&&Number.parseInt(s[1],10);Number.isInteger(a)&&a>0&&(n.discNumber??=a),i&&Number.isInteger(i)&&i>0&&(n.discsTotal??=i)}break}}},$r=class{constructor(e){this.internalTrack=e,this.packetToClusterLocation=new WeakMap}getId(){return this.internalTrack.id}getCodec(){throw new Error("Not implemented on base class.")}getInternalCodecId(){return this.internalTrack.codecId}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}getName(){return this.internalTrack.name}getLanguageCode(){return this.internalTrack.languageCode}async getFirstTimestamp(){return(await this.getFirstPacket({metadataOnly:!0}))?.timestamp??0}getTimeResolution(){return this.internalTrack.segment.timestampFactor}async getFirstPacket(e){return this.performClusterLookup(()=>{let t=this.internalTrack.segment.clusters[0]??null;if(t?.isKnownToBeFirstCluster){let n=t;for(;n;){if(n.trackData.get(this.internalTrack.id))return{clusterIndex:M(this.internalTrack.clusters,n.elementStartPos,a=>a.elementStartPos),blockIndex:0,correctBlockFound:!0};n=n.nextCluster}}return{clusterIndex:-1,blockIndex:-1,correctBlockFound:!1}},-1/0,1/0,e)}intoTimescale(e){return Ue(e*this.internalTrack.segment.timestampFactor,14)}async getPacket(e,t){let n=this.intoTimescale(e);return this.performClusterLookup(()=>this.findBlockInClustersForTimestamp(n),n,n,t)}async getNextPacket(e,t){let n=this.packetToClusterLocation.get(e);if(n===void 0)throw new Error("Packet was not created from this track.");let s=n.cluster.trackData.get(this.internalTrack.id),a=M(this.internalTrack.clusters,n.cluster.elementStartPos,i=>i.elementStartPos);return b(a!==-1),this.performClusterLookup(()=>{if(n.blockIndex+1<s.blocks.length)return{clusterIndex:a,blockIndex:n.blockIndex+1,correctBlockFound:!0};{let i=n.cluster;for(;i.nextCluster;)if(i=i.nextCluster,i.trackData.get(this.internalTrack.id)){let c=M(this.internalTrack.clusters,i.elementStartPos,l=>l.elementStartPos);return b(c!==-1),{clusterIndex:c,blockIndex:0,correctBlockFound:!0}}return{clusterIndex:a,blockIndex:-1,correctBlockFound:!1}}},-1/0,1/0,t)}async getKeyPacket(e,t){let n=this.intoTimescale(e);return this.performClusterLookup(()=>this.findKeyBlockInClustersForTimestamp(n),n,n,t)}async getNextKeyPacket(e,t){let n=this.packetToClusterLocation.get(e);if(n===void 0)throw new Error("Packet was not created from this track.");let s=n.cluster.trackData.get(this.internalTrack.id),a=M(this.internalTrack.clusters,n.cluster.elementStartPos,i=>i.elementStartPos);return b(a!==-1),this.performClusterLookup(()=>{let i=s.blocks.findIndex((o,c)=>o.isKeyFrame&&c>n.blockIndex);if(i!==-1)return{clusterIndex:a,blockIndex:i,correctBlockFound:!0};{let o=n.cluster;for(;o.nextCluster;){o=o.nextCluster;let c=o.trackData.get(this.internalTrack.id);if(c&&c.firstKeyFrameTimestamp!==null){let l=M(this.internalTrack.clusters,o.elementStartPos,d=>d.elementStartPos);b(l!==-1);let u=c.blocks.findIndex(d=>d.isKeyFrame);return b(u!==-1),{clusterIndex:l,blockIndex:u,correctBlockFound:!0}}}return{clusterIndex:a,blockIndex:-1,correctBlockFound:!1}}},-1/0,1/0,t)}async fetchPacketInCluster(e,t,n){if(t===-1)return null;let a=e.trackData.get(this.internalTrack.id).blocks[t];b(a);let i=n.metadataOnly?$:a.data,o=a.timestamp/this.internalTrack.segment.timestampFactor,c=a.duration/this.internalTrack.segment.timestampFactor,l=new N(i,a.isKeyFrame?"key":"delta",o,c,e.dataStartPos+t,a.data.byteLength);return this.packetToClusterLocation.set(l,{cluster:e,blockIndex:t}),l}findBlockInClustersForTimestamp(e){let t=R(this.internalTrack.clusters,e,a=>a.trackData.get(this.internalTrack.id).startTimestamp),n=-1,s=!1;if(t!==-1){let i=this.internalTrack.clusters[t].trackData.get(this.internalTrack.id),o=R(i.presentationTimestamps,e,c=>c.timestamp);b(o!==-1),n=i.presentationTimestamps[o].blockIndex,s=e<i.endTimestamp}return{clusterIndex:t,blockIndex:n,correctBlockFound:s}}findKeyBlockInClustersForTimestamp(e){let t=R(this.internalTrack.clustersWithKeyFrame,e,i=>i.trackData.get(this.internalTrack.id).firstKeyFrameTimestamp),n=-1,s=-1,a=!1;if(t!==-1){let i=this.internalTrack.clustersWithKeyFrame[t];n=M(this.internalTrack.clusters,i.elementStartPos,u=>u.elementStartPos),b(n!==-1);let o=i.trackData.get(this.internalTrack.id),c=br(o.presentationTimestamps,u=>o.blocks[u.blockIndex].isKeyFrame&&u.timestamp<=e);b(c!==-1),s=o.presentationTimestamps[c].blockIndex,a=e<o.endTimestamp}return{clusterIndex:n,blockIndex:s,correctBlockFound:a}}async performClusterLookup(e,t,n,s){let{demuxer:a,segment:i}=this.internalTrack,o=await i.clusterLookupMutex.acquire();try{let{clusterIndex:c,blockIndex:l,correctBlockFound:u}=e();if(u){let w=this.internalTrack.clusters[c];return this.fetchPacketInCluster(w,l,s)}let d=null,f=c,m=l,h=R(this.internalTrack.cuePoints,t,w=>w.time),g=h!==-1?this.internalTrack.cuePoints[h]:null,y,S=!1;if(c===-1)y=g?.clusterPosition??i.clusterSeekStartPos,S=y===i.clusterSeekStartPos;else{let w=this.internalTrack.clusters[c];!g||w.elementStartPos>=g.clusterPosition?(y=w.elementEndPos,d=w):y=g.clusterPosition}for(;i.elementEndPos===null||y<=i.elementEndPos-Z;){if(d){let A=d.trackData.get(this.internalTrack.id);if(A&&A.startTimestamp>n)break;if(d.nextCluster){y=d.nextCluster.elementEndPos,d=d.nextCluster;continue}}let w=a.reader.requestSliceRange(y,Z,ne);if(w instanceof Promise&&(w=await w),!w)break;let k=y,x=se(w);if(!x||!it.includes(x.id)&&x.id!==T.Void){let A=await Hn(a.reader,k,it,Math.min(i.elementEndPos??1/0,k+Pi));if(A){y=A;continue}else break}let C=x.id,v=x.size,F=w.filePos;if(C===T.Cluster){let A=M(i.clusters,k,Kt=>Kt.elementStartPos),_;A===-1?_=await a.readCluster(k,i):_=i.clusters[A],d&&(d.nextCluster=_),d=_,S&&(_.isKnownToBeFirstCluster=!0,S=!1);let{clusterIndex:B,blockIndex:L,correctBlockFound:Fe}=e();if(Fe){let Kt=this.internalTrack.clusters[B];return this.fetchPacketInCluster(Kt,L,s)}B!==-1&&(f=B,m=L)}if(v===null){C===T.Cluster?(b(d),v=d.elementEndPos-F):v=(await zr(a.reader,F,Br,i.elementEndPos)).pos-F;let A=F+v;if(i.elementEndPos!==null&&A>i.elementEndPos-Z)break;{let _=a.reader.requestSliceRange(A,Z,ne);if(_ instanceof Promise&&(_=await _),!_)break;if(Rr(_)===T.Segment){i.elementEndPos=A;break}}}y=F+v}let p=f!==-1?this.internalTrack.clusters[f]:null;if(g&&(!p||p.elementStartPos<g.clusterPosition)){let k=this.internalTrack.cuePoints[h-1]?.time??-1/0;return this.performClusterLookup(e,k,n,s)}return p?this.fetchPacketInCluster(p,m,s):null}finally{o()}}},Jn=class extends $r{constructor(e){super(e),this.decoderConfigPromise=null,this.internalTrack=e}getCodec(){return this.internalTrack.info.codec}getCodedWidth(){return this.internalTrack.info.width}getCodedHeight(){return this.internalTrack.info.height}getRotation(){return this.internalTrack.info.rotation}async getColorSpace(){return{primaries:this.internalTrack.info.colorSpace?.primaries,transfer:this.internalTrack.info.colorSpace?.transfer,matrix:this.internalTrack.info.colorSpace?.matrix,fullRange:this.internalTrack.info.colorSpace?.fullRange}}async getDecoderConfig(){return this.internalTrack.info.codec?this.decoderConfigPromise??=(async()=>{let e=null;return(this.internalTrack.info.codec==="vp9"||this.internalTrack.info.codec==="av1"||this.internalTrack.info.codec==="avc"&&!this.internalTrack.info.codecDescription||this.internalTrack.info.codec==="hevc"&&!this.internalTrack.info.codecDescription)&&(e=await this.getFirstPacket({})),{codec:Tr({width:this.internalTrack.info.width,height:this.internalTrack.info.height,codec:this.internalTrack.info.codec,codecDescription:this.internalTrack.info.codecDescription,colorSpace:this.internalTrack.info.colorSpace,avcCodecInfo:this.internalTrack.info.codec==="avc"&&e?js(e.data):null,hevcCodecInfo:this.internalTrack.info.codec==="hevc"&&e?$s(e.data):null,vp9CodecInfo:this.internalTrack.info.codec==="vp9"&&e?Ir(e.data):null,av1CodecInfo:this.internalTrack.info.codec==="av1"&&e?Er(e.data):null}),codedWidth:this.internalTrack.info.width,codedHeight:this.internalTrack.info.height,description:this.internalTrack.info.codecDescription??void 0,colorSpace:this.internalTrack.info.colorSpace??void 0}})():null}},es=class extends $r{constructor(e){super(e),this.decoderConfig=null,this.internalTrack=e}getCodec(){return this.internalTrack.info.codec}getNumberOfChannels(){return this.internalTrack.info.numberOfChannels}getSampleRate(){return this.internalTrack.info.sampleRate}async getDecoderConfig(){return this.internalTrack.info.codec?this.decoderConfig??={codec:Pr({codec:this.internalTrack.info.codec,codecDescription:this.internalTrack.info.codecDescription,aacCodecInfo:this.internalTrack.info.aacCodecInfo}),numberOfChannels:this.internalTrack.info.numberOfChannels,sampleRate:this.internalTrack.info.sampleRate,description:this.internalTrack.info.codecDescription??void 0}:null}},Fa=r=>{let e=new Map;for(let a=0;a<r.length;a++){let i=r[a];e.set(i.timestamp,i)}let t=new Set,n=[],s=a=>{if(!t.has(a)){t.add(a);for(let i=0;i<a.referencedTimestamps.length;i++){let o=a.referencedTimestamps[i],c=e.get(o);c&&s(c)}n.push(a)}};for(let a=0;a<r.length;a++)s(r[a]);return n};var Kr=class extends Y{constructor(e){super(e),this.metadataPromise=null,this.firstFrameHeader=null,this.loadedSamples=[],this.metadataTags=null,this.tracks=[],this.readingMutex=new ee,this.lastSampleLoaded=!1,this.lastLoadedPos=0,this.nextTimestampInSamples=0,this.reader=e._reader}async readMetadata(){return this.metadataPromise??=(async()=>{for(;!this.firstFrameHeader&&!this.lastSampleLoaded;)await this.advanceReader();if(!this.firstFrameHeader)throw new Error("No valid MP3 frame found.");this.tracks=[new K(new ts(this))]})()}async advanceReader(){if(this.lastLoadedPos===0)for(;;){let o=this.reader.requestSlice(this.lastLoadedPos,ft);if(o instanceof Promise&&(o=await o),!o){this.lastSampleLoaded=!0;return}let c=Rt(o);if(!c)break;this.lastLoadedPos=o.filePos+c.size}let e=await Bt(this.reader,this.lastLoadedPos,this.reader.fileSize);if(!e){this.lastSampleLoaded=!0;return}let t=e.header;this.lastLoadedPos=e.startPos+t.totalSize-1;let n=oi(t.mpegVersionId,t.channel),s=this.reader.requestSlice(e.startPos+n,4);if(s instanceof Promise&&(s=await s),s){let o=P(s);if(o===ii||o===ai)return}this.firstFrameHeader||(this.firstFrameHeader=t);let a=t.audioSamplesInFrame/t.sampleRate,i={timestamp:this.nextTimestampInSamples/t.sampleRate,duration:a,dataStart:e.startPos,dataSize:t.totalSize};this.loadedSamples.push(i),this.nextTimestampInSamples+=t.audioSamplesInFrame}async getMimeType(){return"audio/mpeg"}async getTracks(){return await this.readMetadata(),this.tracks}async computeDuration(){await this.readMetadata();let e=this.tracks[0];return b(e),e.computeDuration()}async getMetadataTags(){let e=await this.readingMutex.acquire();try{if(await this.readMetadata(),this.metadataTags)return this.metadataTags;this.metadataTags={};let t=0,n=!1;for(;;){let s=this.reader.requestSlice(t,ft);if(s instanceof Promise&&(s=await s),!s)break;let a=Rt(s);if(!a)break;n=!0;let i=this.reader.requestSlice(s.filePos,a.size);if(i instanceof Promise&&(i=await i),!i)break;di(i,a,this.metadataTags),t=s.filePos+a.size}if(!n&&this.reader.fileSize!==null&&this.reader.fileSize>=Dt){let s=this.reader.requestSlice(this.reader.fileSize-Dt,Dt);s instanceof Promise&&(s=await s),b(s),V(s,3)==="TAG"&&ui(s,this.metadataTags)}return this.metadataTags}finally{e()}}},ts=class{constructor(e){this.demuxer=e}getId(){return 1}async getFirstTimestamp(){return 0}getTimeResolution(){return b(this.demuxer.firstFrameHeader),this.demuxer.firstFrameHeader.sampleRate/this.demuxer.firstFrameHeader.audioSamplesInFrame}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}getName(){return null}getLanguageCode(){return q}getCodec(){return"mp3"}getInternalCodecId(){return null}getNumberOfChannels(){return b(this.demuxer.firstFrameHeader),this.demuxer.firstFrameHeader.channel===3?1:2}getSampleRate(){return b(this.demuxer.firstFrameHeader),this.demuxer.firstFrameHeader.sampleRate}async getDecoderConfig(){return b(this.demuxer.firstFrameHeader),{codec:"mp3",numberOfChannels:this.demuxer.firstFrameHeader.channel===3?1:2,sampleRate:this.demuxer.firstFrameHeader.sampleRate}}async getPacketAtIndex(e,t){if(e===-1)return null;let n=this.demuxer.loadedSamples[e];if(!n)return null;let s;if(t.metadataOnly)s=$;else{let a=this.demuxer.reader.requestSlice(n.dataStart,n.dataSize);if(a instanceof Promise&&(a=await a),!a)return null;s=D(a,n.dataSize)}return new N(s,"key",n.timestamp,n.duration,e,n.dataSize)}getFirstPacket(e){return this.getPacketAtIndex(0,e)}async getNextPacket(e,t){let n=await this.demuxer.readingMutex.acquire();try{let s=M(this.demuxer.loadedSamples,e.timestamp,i=>i.timestamp);if(s===-1)throw new Error("Packet was not created from this track.");let a=s+1;for(;a>=this.demuxer.loadedSamples.length&&!this.demuxer.lastSampleLoaded;)await this.demuxer.advanceReader();return this.getPacketAtIndex(a,t)}finally{n()}}async getPacket(e,t){let n=await this.demuxer.readingMutex.acquire();try{for(;;){let s=R(this.demuxer.loadedSamples,e,a=>a.timestamp);if(s===-1&&this.demuxer.loadedSamples.length>0)return null;if(this.demuxer.lastSampleLoaded)return this.getPacketAtIndex(s,t);if(s>=0&&s+1<this.demuxer.loadedSamples.length)return this.getPacketAtIndex(s,t);await this.demuxer.advanceReader()}}finally{n()}}getKeyPacket(e,t){return this.getPacket(e,t)}getNextKeyPacket(e,t){return this.getNextPacket(e,t)}};var Gr=class extends Y{constructor(e){super(e),this.metadataPromise=null,this.bitstreams=[],this.tracks=[],this.metadataTags={},this.reader=e._reader}async readMetadata(){return this.metadataPromise??=(async()=>{let e=0;for(;;){let t=this.reader.requestSliceRange(e,_e,je);if(t instanceof Promise&&(t=await t),!t)break;let n=mt(t);if(!n||!!!(n.headerType&2))break;this.bitstreams.push({serialNumber:n.serialNumber,bosPage:n,description:null,numberOfChannels:-1,sampleRate:-1,codecInfo:{codec:null,vorbisInfo:null,opusInfo:null},lastMetadataPacket:null}),e=n.headerStartPos+n.totalSize}for(let t of this.bitstreams){let n=await this.readPacket(t.bosPage,0);n&&(n.data.byteLength>=7&&n.data[0]===1&&n.data[1]===118&&n.data[2]===111&&n.data[3]===114&&n.data[4]===98&&n.data[5]===105&&n.data[6]===115?await this.readVorbisMetadata(n,t):n.data.byteLength>=8&&n.data[0]===79&&n.data[1]===112&&n.data[2]===117&&n.data[3]===115&&n.data[4]===72&&n.data[5]===101&&n.data[6]===97&&n.data[7]===100&&await this.readOpusMetadata(n,t),t.codecInfo.codec!==null&&this.tracks.push(new K(new rs(t,this))))}})()}async readVorbisMetadata(e,t){let n=await this.findNextPacketStart(e);if(!n)return;let s=await this.readPacket(n.startPage,n.startSegmentIndex);if(!s||(n=await this.findNextPacketStart(s),!n))return;let a=await this.readPacket(n.startPage,n.startSegmentIndex);if(!a||s.data[0]!==3||a.data[0]!==5)return;let i=[],o=d=>{for(;i.push(Math.min(255,d)),!(d<255);)d-=255};o(e.data.length),o(s.data.length);let c=new Uint8Array(1+i.length+e.data.length+s.data.length+a.data.length);c[0]=i.length,c.set(i,1),c.set(e.data,1+i.length),c.set(s.data,1+i.length+e.data.length),c.set(a.data,1+i.length+e.data.length+s.data.length),t.codecInfo.codec="vorbis",t.description=c,t.lastMetadataPacket=a;let l=z(e.data);t.numberOfChannels=l.getUint8(11),t.sampleRate=l.getUint32(12,!0);let u=l.getUint8(28);t.codecInfo.vorbisInfo={blocksizes:[1<<(u&15),1<<(u>>4)],modeBlockflags:Qs(a.data).modeBlockflags},this.readVorbisComments(s.data.subarray(7))}async readOpusMetadata(e,t){let n=await this.findNextPacketStart(e);if(!n)return;let s=await this.readPacket(n.startPage,n.startSegmentIndex);if(!s)return;t.codecInfo.codec="opus",t.description=e.data,t.lastMetadataPacket=s;let a=Gs(e.data);t.numberOfChannels=a.outputChannelCount,t.sampleRate=a.inputSampleRate,t.codecInfo.opusInfo={preSkip:a.preSkip},this.readVorbisComments(s.data.subarray(8))}readVorbisComments(e){let t=z(e),n=0,s=t.getUint32(n,!0);n+=4;let a=G.decode(e.subarray(n,n+s));n+=s,s>0&&(this.metadataTags.raw??={},this.metadataTags.raw.vendor??=a);let i=t.getUint32(n,!0);n+=4;for(let o=0;o<i;o++){let c=t.getUint32(n,!0);n+=4;let l=G.decode(e.subarray(n,n+c));n+=c;let u=l.indexOf("=");if(u===-1)continue;let d=l.slice(0,u).toUpperCase(),f=l.slice(u+1);switch(this.metadataTags.raw??={},this.metadataTags.raw[d]??=f,d){case"TITLE":this.metadataTags.title??=f;break;case"DESCRIPTION":this.metadataTags.description??=f;break;case"ARTIST":this.metadataTags.artist??=f;break;case"ALBUM":this.metadataTags.album??=f;break;case"ALBUMARTIST":this.metadataTags.albumArtist??=f;break;case"COMMENT":this.metadataTags.comment??=f;break;case"LYRICS":this.metadataTags.lyrics??=f;break;case"TRACKNUMBER":{let m=f.split("/"),h=Number.parseInt(m[0],10),g=m[1]&&Number.parseInt(m[1],10);Number.isInteger(h)&&h>0&&(this.metadataTags.trackNumber??=h),g&&Number.isInteger(g)&&g>0&&(this.metadataTags.tracksTotal??=g)}break;case"TRACKTOTAL":{let m=Number.parseInt(f,10);Number.isInteger(m)&&m>0&&(this.metadataTags.tracksTotal??=m)}break;case"DISCNUMBER":{let m=f.split("/"),h=Number.parseInt(m[0],10),g=m[1]&&Number.parseInt(m[1],10);Number.isInteger(h)&&h>0&&(this.metadataTags.discNumber??=h),g&&Number.isInteger(g)&&g>0&&(this.metadataTags.discsTotal??=g)}break;case"DISCTOTAL":{let m=Number.parseInt(f,10);Number.isInteger(m)&&m>0&&(this.metadataTags.discsTotal??=m)}break;case"DATE":{let m=new Date(f);Number.isNaN(m.getTime())||(this.metadataTags.date??=m)}break;case"GENRE":this.metadataTags.genre??=f;break;case"METADATA_BLOCK_PICTURE":{let m=Ns(f),h=z(m),g=h.getUint32(0,!1),y=h.getUint32(4,!1),S=String.fromCharCode(...m.subarray(8,8+y)),p=h.getUint32(8+y,!1),w=G.decode(m.subarray(12+y,12+y+p)),k=h.getUint32(y+p+28),x=m.subarray(y+p+32,y+p+32+k);this.metadataTags.images??=[],this.metadataTags.images.push({data:x,mimeType:S,kind:g===3?"coverFront":g===4?"coverBack":"unknown",name:void 0,description:w||void 0})}break}}}async readPacket(e,t){b(t<e.lacingValues.length);let n=0;for(let d=0;d<t;d++)n+=e.lacingValues[d];let s=e,a=n,i=t,o=[];e:for(;;){let d=this.reader.requestSlice(s.dataStartPos,s.dataSize);d instanceof Promise&&(d=await d),b(d);let f=D(d,s.dataSize);for(;;){if(i===s.lacingValues.length){o.push(f.subarray(n,a));break}let h=s.lacingValues[i];if(a+=h,h<255){o.push(f.subarray(n,a));break e}i++}let m=s.headerStartPos+s.totalSize;for(;;){let h=this.reader.requestSliceRange(m,_e,je);if(h instanceof Promise&&(h=await h),!h)return null;let g=mt(h);if(!g)return null;if(s=g,s.serialNumber===e.serialNumber)break;m=s.headerStartPos+s.totalSize}n=0,a=0,i=0}let c=o.reduce((d,f)=>d+f.length,0),l=new Uint8Array(c),u=0;for(let d=0;d<o.length;d++){let f=o[d];l.set(f,u),u+=f.length}return{data:l,endPage:s,endSegmentIndex:i}}async findNextPacketStart(e){if(e.endSegmentIndex<e.endPage.lacingValues.length-1)return{startPage:e.endPage,startSegmentIndex:e.endSegmentIndex+1};if(!!(e.endPage.headerType&4))return null;let n=e.endPage.headerStartPos+e.endPage.totalSize;for(;;){let s=this.reader.requestSliceRange(n,_e,je);if(s instanceof Promise&&(s=await s),!s)return null;let a=mt(s);if(!a)return null;if(a.serialNumber===e.endPage.serialNumber)return{startPage:a,startSegmentIndex:0};n=a.headerStartPos+a.totalSize}}async getMimeType(){await this.readMetadata();let e=await Promise.all(this.tracks.map(t=>t.getCodecParameterString()));return pi({codecStrings:e.filter(Boolean)})}async getTracks(){return await this.readMetadata(),this.tracks}async computeDuration(){let e=await this.getTracks(),t=await Promise.all(e.map(n=>n.computeDuration()));return Math.max(0,...t)}async getMetadataTags(){return await this.readMetadata(),this.metadataTags}},rs=class{constructor(e,t){this.bitstream=e,this.demuxer=t,this.encodedPacketToMetadata=new WeakMap,this.sequentialScanCache=[],this.sequentialScanMutex=new ee,this.internalSampleRate=e.codecInfo.codec==="opus"?Ls:e.sampleRate}getId(){return this.bitstream.serialNumber}getNumberOfChannels(){return this.bitstream.numberOfChannels}getSampleRate(){return this.bitstream.sampleRate}getTimeResolution(){return this.bitstream.sampleRate}getCodec(){return this.bitstream.codecInfo.codec}getInternalCodecId(){return null}async getDecoderConfig(){return b(this.bitstream.codecInfo.codec),{codec:this.bitstream.codecInfo.codec,numberOfChannels:this.bitstream.numberOfChannels,sampleRate:this.bitstream.sampleRate,description:this.bitstream.description??void 0}}getName(){return null}getLanguageCode(){return q}async getFirstTimestamp(){return 0}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}granulePositionToTimestampInSamples(e){return this.bitstream.codecInfo.codec==="opus"?(b(this.bitstream.codecInfo.opusInfo),e-this.bitstream.codecInfo.opusInfo.preSkip):e}createEncodedPacketFromOggPacket(e,t,n){if(!e)return null;let{durationInSamples:s,vorbisBlockSize:a}=hi(e.data,this.bitstream.codecInfo,t.vorbisLastBlocksize),i=new N(n.metadataOnly?$:e.data,"key",Math.max(0,t.timestampInSamples)/this.internalSampleRate,s/this.internalSampleRate,e.endPage.headerStartPos+e.endSegmentIndex,e.data.byteLength);return this.encodedPacketToMetadata.set(i,{packet:e,timestampInSamples:t.timestampInSamples,durationInSamples:s,vorbisLastBlockSize:t.vorbisLastBlocksize,vorbisBlockSize:a}),i}async getFirstPacket(e){b(this.bitstream.lastMetadataPacket);let t=await this.demuxer.findNextPacketStart(this.bitstream.lastMetadataPacket);if(!t)return null;let n=0;this.bitstream.codecInfo.codec==="opus"&&(b(this.bitstream.codecInfo.opusInfo),n-=this.bitstream.codecInfo.opusInfo.preSkip);let s=await this.demuxer.readPacket(t.startPage,t.startSegmentIndex);return this.createEncodedPacketFromOggPacket(s,{timestampInSamples:n,vorbisLastBlocksize:null},e)}async getNextPacket(e,t){let n=this.encodedPacketToMetadata.get(e);if(!n)throw new Error("Packet was not created from this track.");let s=await this.demuxer.findNextPacketStart(n.packet);if(!s)return null;let a=n.timestampInSamples+n.durationInSamples,i=await this.demuxer.readPacket(s.startPage,s.startSegmentIndex);return this.createEncodedPacketFromOggPacket(i,{timestampInSamples:a,vorbisLastBlocksize:n.vorbisBlockSize},t)}async getPacket(e,t){if(this.demuxer.reader.fileSize===null)return this.getPacketSequential(e,t);let n=Ue(e*this.internalSampleRate,14);if(n===0)return this.getFirstPacket(t);if(n<0)return null;b(this.bitstream.lastMetadataPacket);let s=await this.demuxer.findNextPacketStart(this.bitstream.lastMetadataPacket);if(!s)return null;let a=s.startPage,i=this.demuxer.reader.fileSize,o=[a];e:for(;a.headerStartPos+a.totalSize<i;){let p=a.headerStartPos,w=Math.floor((p+i)/2),k=w;for(;;){let x=Math.min(k+gi,i-_e),C=this.demuxer.reader.requestSlice(k,x-k);if(C instanceof Promise&&(C=await C),b(C),!bi(C,x)){i=w+_e;continue e}let F=this.demuxer.reader.requestSliceRange(C.filePos,_e,je);F instanceof Promise&&(F=await F),b(F);let A=mt(F);b(A);let _=!1;if(A.serialNumber===this.bitstream.serialNumber)_=!0;else{let L=this.demuxer.reader.requestSlice(A.headerStartPos,A.totalSize);L instanceof Promise&&(L=await L),b(L);let Fe=D(L,A.totalSize);_=mi(Fe)===A.checksum}if(!_){k=A.headerStartPos+4;continue}if(_&&A.serialNumber!==this.bitstream.serialNumber){k=A.headerStartPos+A.totalSize;continue}if(A.granulePosition===-1){k=A.headerStartPos+A.totalSize;continue}this.granulePositionToTimestampInSamples(A.granulePosition)>n?i=A.headerStartPos:(a=A,o.push(A));continue e}}let c=s.startPage;for(let p of o){if(p.granulePosition===a.granulePosition)break;(!c||p.headerStartPos>c.headerStartPos)&&(c=p)}let l=c,u=[l];for(;!(l.serialNumber===this.bitstream.serialNumber&&l.granulePosition===a.granulePosition);){let p=l.headerStartPos+l.totalSize,w=this.demuxer.reader.requestSliceRange(p,_e,je);w instanceof Promise&&(w=await w),b(w);let k=mt(w);b(k),l=k,l.serialNumber===this.bitstream.serialNumber&&u.push(l)}b(l.granulePosition!==-1);let d=null,f,m,h=l,g=0;if(l.headerStartPos===s.startPage.headerStartPos)f=this.granulePositionToTimestampInSamples(0),m=!0,d=0;else{f=0,m=!1;for(let k=l.lacingValues.length-1;k>=0;k--)if(l.lacingValues[k]<255){d=k+1;break}if(d===null)throw new Error("Invalid page with granule position: no packets end on this page.");g=d-1;let p={data:$,endPage:h,endSegmentIndex:g};if(await this.demuxer.findNextPacketStart(p)){let k=vi(u,l,d);b(k);let x=Ci(u,k.page,k.segmentIndex);x&&(l=x.page,d=x.segmentIndex)}else for(;;){let k=vi(u,l,d);if(!k)break;let x=Ci(u,k.page,k.segmentIndex);if(!x)break;if(l=x.page,d=x.segmentIndex,k.page.headerStartPos!==h.headerStartPos){h=k.page,g=k.segmentIndex;break}}}let y=null,S=null;for(;l!==null;){b(d!==null);let p=await this.demuxer.readPacket(l,d);if(!p)break;if(!(l.headerStartPos===s.startPage.headerStartPos&&d<s.startSegmentIndex)){let x=this.createEncodedPacketFromOggPacket(p,{timestampInSamples:f,vorbisLastBlocksize:S?.vorbisBlockSize??null},t);b(x);let C=this.encodedPacketToMetadata.get(x);if(b(C),!m&&p.endPage.headerStartPos===h.headerStartPos&&p.endSegmentIndex===g?(f=this.granulePositionToTimestampInSamples(l.granulePosition),m=!0,x=this.createEncodedPacketFromOggPacket(p,{timestampInSamples:f-C.durationInSamples,vorbisLastBlocksize:S?.vorbisBlockSize??null},t),b(x),C=this.encodedPacketToMetadata.get(x),b(C)):f+=C.durationInSamples,y=x,S=C,m&&(Math.max(f,0)>n||Math.max(C.timestampInSamples,0)===n))break}let k=await this.demuxer.findNextPacketStart(p);if(!k)break;l=k.startPage,d=k.startSegmentIndex}return y}async getPacketSequential(e,t){let n=await this.sequentialScanMutex.acquire();try{let s=Ue(e*this.internalSampleRate,14);e=s/this.internalSampleRate;let a=R(this.sequentialScanCache,s,c=>c.timestampInSamples),i;if(a!==-1){let c=this.sequentialScanCache[a];i=this.createEncodedPacketFromOggPacket(c.packet,{timestampInSamples:c.timestampInSamples,vorbisLastBlocksize:c.vorbisLastBlockSize},t)}else i=await this.getFirstPacket(t);let o=0;for(;i&&i.timestamp<e;){let c=await this.getNextPacket(i,t);if(!c||c.timestamp>e)break;if(i=c,o++,o===100){o=0;let l=this.encodedPacketToMetadata.get(i);b(l),this.sequentialScanCache.length>0&&b(W(this.sequentialScanCache).timestampInSamples<=l.timestampInSamples),this.sequentialScanCache.push(l)}}return i}finally{n()}}getKeyPacket(e,t){return this.getPacket(e,t)}getNextKeyPacket(e,t){return this.getNextPacket(e,t)}},Ci=(r,e,t)=>{let n=e,s=t;e:for(;;){for(s--,s;s>=0;s--)if(n.lacingValues[s]<255){s++;break e}if(b(s===-1),!(n.headerType&1)){s=0;break}let i=Fn(r,o=>o.headerStartPos<n.headerStartPos);if(!i)return null;n=i,s=n.lacingValues.length}if(b(s!==-1),s===n.lacingValues.length){let a=r[r.indexOf(n)+1];b(a),n=a,s=0}return{page:n,segmentIndex:s}},vi=(r,e,t)=>{if(t>0)return{page:e,segmentIndex:t-1};let n=Fn(r,s=>s.headerStartPos<e.headerStartPos);return n?{page:n,segmentIndex:n.lacingValues.length-1}:null};var yt=7,kt=9,Ut=r=>{let e=r.filePos,t=D(r,9),n=new U(t);if(n.readBits(12)!==4095||(n.skipBits(1),n.readBits(2)!==0))return null;let i=n.readBits(1),o=n.readBits(2)+1,c=n.readBits(4);if(c===15)return null;n.skipBits(1);let l=n.readBits(3);if(l===0)throw new Error("ADTS frames with channel configuration 0 are not supported.");n.skipBits(1),n.skipBits(1),n.skipBits(1),n.skipBits(1);let u=n.readBits(13);n.skipBits(11);let d=n.readBits(2)+1;if(d!==1)throw new Error("ADTS frames with more than one AAC frame are not supported.");let f=null;return i===1?r.filePos-=2:f=n.readBits(16),{objectType:o,samplingFrequencyIndex:c,channelConfiguration:l,frameLength:u,numberOfAacFrames:d,crcCheck:f,startPos:e}};var ns=1024,Xr=class extends Y{constructor(e){super(e),this.metadataPromise=null,this.firstFrameHeader=null,this.loadedSamples=[],this.tracks=[],this.readingMutex=new ee,this.lastSampleLoaded=!1,this.lastLoadedPos=0,this.nextTimestampInSamples=0,this.reader=e._reader}async readMetadata(){return this.metadataPromise??=(async()=>{for(;!this.firstFrameHeader&&!this.lastSampleLoaded;)await this.advanceReader();b(this.firstFrameHeader),this.tracks=[new K(new ss(this))]})()}async advanceReader(){let e=this.reader.requestSliceRange(this.lastLoadedPos,yt,kt);if(e instanceof Promise&&(e=await e),!e){this.lastSampleLoaded=!0;return}let t=Ut(e);if(!t){this.lastSampleLoaded=!0;return}if(this.reader.fileSize!==null&&t.startPos+t.frameLength>this.reader.fileSize){this.lastSampleLoaded=!0;return}this.firstFrameHeader||(this.firstFrameHeader=t);let n=_t[t.samplingFrequencyIndex];b(n!==void 0);let s=ns/n,a=t.crcCheck?kt:yt,i={timestamp:this.nextTimestampInSamples/n,duration:s,dataStart:t.startPos+a,dataSize:t.frameLength-a};this.loadedSamples.push(i),this.nextTimestampInSamples+=ns,this.lastLoadedPos=t.startPos+t.frameLength}async getMimeType(){return"audio/aac"}async getTracks(){return await this.readMetadata(),this.tracks}async computeDuration(){await this.readMetadata();let e=this.tracks[0];return b(e),e.computeDuration()}async getMetadataTags(){return{}}},ss=class{constructor(e){this.demuxer=e}getId(){return 1}async getFirstTimestamp(){return 0}getTimeResolution(){return this.getSampleRate()/ns}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}getName(){return null}getLanguageCode(){return q}getCodec(){return"aac"}getInternalCodecId(){return b(this.demuxer.firstFrameHeader),this.demuxer.firstFrameHeader.objectType}getNumberOfChannels(){b(this.demuxer.firstFrameHeader);let e=Rn[this.demuxer.firstFrameHeader.channelConfiguration];return b(e!==void 0),e}getSampleRate(){b(this.demuxer.firstFrameHeader);let e=_t[this.demuxer.firstFrameHeader.samplingFrequencyIndex];return b(e!==void 0),e}async getDecoderConfig(){b(this.demuxer.firstFrameHeader);let e=new Uint8Array(3),t=new U(e),{objectType:n,samplingFrequencyIndex:s,channelConfiguration:a}=this.demuxer.firstFrameHeader;return n>31?(t.writeBits(5,31),t.writeBits(6,n-32)):t.writeBits(5,n),t.writeBits(4,s),t.writeBits(4,a),{codec:`mp4a.40.${this.demuxer.firstFrameHeader.objectType}`,numberOfChannels:this.getNumberOfChannels(),sampleRate:this.getSampleRate(),description:e.subarray(0,Math.ceil((t.pos-1)/8))}}async getPacketAtIndex(e,t){if(e===-1)return null;let n=this.demuxer.loadedSamples[e];if(!n)return null;let s;if(t.metadataOnly)s=$;else{let a=this.demuxer.reader.requestSlice(n.dataStart,n.dataSize);if(a instanceof Promise&&(a=await a),!a)return null;s=D(a,n.dataSize)}return new N(s,"key",n.timestamp,n.duration,e,n.dataSize)}getFirstPacket(e){return this.getPacketAtIndex(0,e)}async getNextPacket(e,t){let n=await this.demuxer.readingMutex.acquire();try{let s=M(this.demuxer.loadedSamples,e.timestamp,i=>i.timestamp);if(s===-1)throw new Error("Packet was not created from this track.");let a=s+1;for(;a>=this.demuxer.loadedSamples.length&&!this.demuxer.lastSampleLoaded;)await this.demuxer.advanceReader();return this.getPacketAtIndex(a,t)}finally{n()}}async getPacket(e,t){let n=await this.demuxer.readingMutex.acquire();try{for(;;){let s=R(this.demuxer.loadedSamples,e,a=>a.timestamp);if(s===-1&&this.demuxer.loadedSamples.length>0)return null;if(this.demuxer.lastSampleLoaded)return this.getPacketAtIndex(s,t);if(s>=0&&s+1<this.demuxer.loadedSamples.length)return this.getPacketAtIndex(s,t);await this.demuxer.advanceReader()}}finally{n()}}getKeyPacket(e,t){return this.getPacket(e,t)}getNextKeyPacket(e,t){return this.getNextPacket(e,t)}};var ae=class{},Lt=class extends ae{async _getMajorBrand(e){let t=e._reader.requestSlice(0,12);return t instanceof Promise&&(t=await t),!t||(t.skip(4),V(t,4)!=="ftyp")?null:V(t,4)}_createDemuxer(e){return new Wr(e)}},Qr=class extends Lt{async _canReadInput(e){let t=await this._getMajorBrand(e);return!!t&&t!=="qt "}get name(){return"MP4"}get mimeType(){return"video/mp4"}},Zr=class extends Lt{async _canReadInput(e){return await this._getMajorBrand(e)==="qt "}get name(){return"QuickTime File Format"}get mimeType(){return"video/quicktime"}},Ht=class extends ae{async isSupportedEBMLOfDocType(e,t){let n=e._reader.requestSlice(0,ne);if(n instanceof Promise&&(n=await n),!n)return!1;let s=Un(n);if(s===null||s<1||s>8||O(n,s)!==T.EBML)return!1;let i=Ln(n);if(i===null)return!1;let o=e._reader.requestSlice(n.filePos,i);if(o instanceof Promise&&(o=await o),!o)return!1;let c=n.filePos;for(;o.filePos<=c+i-Z;){let l=se(o);if(!l)break;let{id:u,size:d}=l,f=o.filePos;if(d===null)return!1;switch(u){case T.EBMLVersion:if(O(o,d)!==1)return!1;break;case T.EBMLReadVersion:if(O(o,d)!==1)return!1;break;case T.DocType:if(Ee(o,d)!==t)return!1;break;case T.DocTypeVersion:if(O(o,d)>4)return!1;break}o.filePos=f+d}return!0}_canReadInput(e){return this.isSupportedEBMLOfDocType(e,"matroska")}_createDemuxer(e){return new jr(e)}get name(){return"Matroska"}get mimeType(){return"video/x-matroska"}},Yr=class extends Ht{_canReadInput(e){return this.isSupportedEBMLOfDocType(e,"webm")}get name(){return"WebM"}get mimeType(){return"video/webm"}},Jr=class extends ae{async _canReadInput(e){let t=e._reader.requestSlice(0,10);if(t instanceof Promise&&(t=await t),!t)return!1;let n=0,s=!1;for(;;){let l=e._reader.requestSlice(n,ft);if(l instanceof Promise&&(l=await l),!l)break;let u=Rt(l);if(!u)break;s=!0,n=l.filePos+u.size}let a=await Bt(e._reader,n,n+4096);if(!a)return!1;if(s)return!0;n=a.startPos+=a.header.totalSize;let i=await Bt(e._reader,n,n+4);if(!i)return!1;let o=a.header,c=i.header;return!(o.channel!==c.channel||o.sampleRate!==c.sampleRate)}_createDemuxer(e){return new Kr(e)}get name(){return"MP3"}get mimeType(){return"audio/mpeg"}},en=class extends ae{async _canReadInput(e){let t=e._reader.requestSlice(0,12);if(t instanceof Promise&&(t=await t),!t)return!1;let n=V(t,4);return n!=="RIFF"&&n!=="RIFX"&&n!=="RF64"?!1:(t.skip(4),V(t,4)==="WAVE")}_createDemuxer(e){return new Lr(e)}get name(){return"WAVE"}get mimeType(){return"audio/wav"}},tn=class extends ae{async _canReadInput(e){let t=e._reader.requestSlice(0,4);return t instanceof Promise&&(t=await t),t?V(t,4)==="OggS":!1}_createDemuxer(e){return new Gr(e)}get name(){return"Ogg"}get mimeType(){return"application/ogg"}},rn=class extends ae{async _canReadInput(e){let t=e._reader.requestSliceRange(0,yt,kt);if(t instanceof Promise&&(t=await t),!t)return!1;let n=Ut(t);if(!n||(t=e._reader.requestSliceRange(n.frameLength,yt,kt),t instanceof Promise&&(t=await t),!t))return!1;let s=Ut(t);return s?n.objectType===s.objectType&&n.samplingFrequencyIndex===s.samplingFrequencyIndex&&n.channelConfiguration===s.channelConfiguration:!1}_createDemuxer(e){return new Xr(e)}get name(){return"ADTS"}get mimeType(){return"audio/aac"}},Ii=new Qr,Ei=new Zr,_i=new Ht,Ai=new Yr,Fi=new Jr,Di=new en,Bi=new tn,Ri=new rn,xt=[Ii,Ei,_i,Ai,Di,Bi,Fi,Ri];var Ae=class{constructor(e){if(this._demuxerPromise=null,this._format=null,!e||typeof e!="object")throw new TypeError("options must be an object.");if(!Array.isArray(e.formats)||e.formats.some(t=>!(t instanceof ae)))throw new TypeError("options.formats must be an array of InputFormat.");if(!(e.source instanceof Ke))throw new TypeError("options.source must be a Source.");this._formats=e.formats,this._source=e.source,this._reader=new _r(e.source)}_getDemuxer(){return this._demuxerPromise??=(async()=>{this._reader.fileSize=await this._source.getSizeOrNull();for(let e of this._formats)if(await e._canReadInput(this))return this._format=e,e._createDemuxer(this);throw new Error("Input has an unsupported or unrecognizable format.")})()}get source(){return this._source}async getFormat(){return await this._getDemuxer(),b(this._format),this._format}async computeDuration(){return(await this._getDemuxer()).computeDuration()}async getTracks(){return(await this._getDemuxer()).getTracks()}async getVideoTracks(){return(await this.getTracks()).filter(t=>t.isVideoTrack())}async getAudioTracks(){return(await this.getTracks()).filter(t=>t.isAudioTrack())}async getPrimaryVideoTrack(){return(await this.getTracks()).find(t=>t.isVideoTrack())??null}async getPrimaryAudioTrack(){return(await this.getTracks()).find(t=>t.isAudioTrack())??null}async getMimeType(){return(await this._getDemuxer()).getMimeType()}async getMetadataTags(){return(await this._getDemuxer()).getMetadataTags()}};var nn=class{count=0;#e=new Map;register(e,t){this.#e.set(e,t)}unregister(e){this.#e.delete(e)}dispatch(e,t){this.#e.get(e)?.(t)}};var Oi=r=>Je.host(e=>({async world(){r.count++}}));async function Wt(r){return r instanceof Blob?new Nt(r):new Vt(r)}var sn=class{machina;thread;static async setup(e){let t=new nn,n=await Je.thread({label:"OmnitoolDriver",workerUrl:e.workerUrl,setupHost:Oi(t)});return new this(t,n)}constructor(e,t){this.machina=e,this.thread=t}async hello(){return this.thread.work.hello()}async getAudioDuration(e){return await(await new Ae({source:await Wt(e),formats:xt}).getPrimaryAudioTrack())?.computeDuration()}async getVideoDuration(e){return await(await new Ae({source:await Wt(e),formats:xt}).getPrimaryVideoTrack())?.computeDuration()}decodeVideo(e){let t=null,n=new TransformStream({async transform(s,a){let i=await e.onFrame?.(s)??s;t?.close(),a.enqueue(i),t=i}});return this.thread.work.decodeVideo[Oe]({transfer:[n.writable]})({source:e.source,video:n.writable,start:e.start,end:e.end}),n.readable}decodeAudio(e){let t=new TransformStream;return this.thread.work.decodeAudio[Oe]({transfer:[t.writable]})({source:e.source,audio:t.writable,start:e.start,end:e.end}),t.readable}async encode({video:e,audio:t,config:n}){let a=await(await window.showSaveFilePicker()).createWritable(),i=new WritableStream({async write(o){await a.write(o)},async close(){await a.close()}});return await this.thread.work.encode[Oe]({transfer:[t??[],e??[],i]})({video:e,audio:t,config:n,bridge:i})}async composite(e){let t=this.#e(e);return await this.thread.work.composite[Oe]({transfer:t})(e)}#e(e){let t=[],n=s=>{if(Array.isArray(s))for(let a of s)n(a);else s&&typeof s=="object"&&"kind"in s&&s.kind==="image"&&s.frame instanceof VideoFrame&&t.push(s.frame)};return n(e),t}};var Da=new URL("../driver/driver.worker.bundle.min.js",import.meta.url),an={driver:sn.setup({workerUrl:Da})};function H(r,e,t,n){return new(t||(t=Promise))(function(s,a){function i(l){try{c(n.next(l))}catch(u){a(u)}}function o(l){try{c(n.throw(l))}catch(u){a(u)}}function c(l){var u;l.done?s(l.value):(u=l.value,u instanceof t?u:new t(function(d){d(u)})).then(i,o)}c((n=n.apply(r,e||[])).next())})}var Ge=class{constructor(){this.listeners={}}on(e,t,n){if(this.listeners[e]||(this.listeners[e]=new Set),this.listeners[e].add(t),n?.once){let s=()=>{this.un(e,s),this.un(e,t)};return this.on(e,s),s}return()=>this.un(e,t)}un(e,t){var n;(n=this.listeners[e])===null||n===void 0||n.delete(t)}once(e,t){return this.on(e,t,{once:!0})}unAll(){this.listeners={}}emit(e,...t){this.listeners[e]&&this.listeners[e].forEach(n=>n(...t))}},on={decode:function(r,e){return H(this,void 0,void 0,function*(){let t=new AudioContext({sampleRate:e});return t.decodeAudioData(r).finally(()=>t.close())})},createBuffer:function(r,e){return typeof r[0]=="number"&&(r=[r]),function(t){let n=t[0];if(n.some(s=>s>1||s<-1)){let s=n.length,a=0;for(let i=0;i<s;i++){let o=Math.abs(n[i]);o>a&&(a=o)}for(let i of t)for(let o=0;o<s;o++)i[o]/=a}}(r),{duration:e,length:r[0].length,sampleRate:r[0].length/e,numberOfChannels:r.length,getChannelData:t=>r?.[t],copyFromChannel:AudioBuffer.prototype.copyFromChannel,copyToChannel:AudioBuffer.prototype.copyToChannel}}};function Mi(r,e){let t=e.xmlns?document.createElementNS(e.xmlns,r):document.createElement(r);for(let[n,s]of Object.entries(e))if(n==="children"&&s)for(let[a,i]of Object.entries(s))i instanceof Node?t.appendChild(i):typeof i=="string"?t.appendChild(document.createTextNode(i)):t.appendChild(Mi(a,i));else n==="style"?Object.assign(t.style,s):n==="textContent"?t.textContent=s:t.setAttribute(n,s.toString());return t}function zi(r,e,t){let n=Mi(r,e||{});return t?.appendChild(n),n}var Ba=Object.freeze({__proto__:null,createElement:zi,default:zi}),Ra={fetchBlob:function(r,e,t){return H(this,void 0,void 0,function*(){let n=yield fetch(r,t);if(n.status>=400)throw new Error(`Failed to fetch ${r}: ${n.status} (${n.statusText})`);return function(s,a){H(this,void 0,void 0,function*(){if(!s.body||!s.headers)return;let i=s.body.getReader(),o=Number(s.headers.get("Content-Length"))||0,c=0,l=d=>H(this,void 0,void 0,function*(){c+=d?.length||0;let f=Math.round(c/o*100);a(f)}),u=()=>H(this,void 0,void 0,function*(){let d;try{d=yield i.read()}catch{return}d.done||(l(d.value),yield u())});u()})}(n.clone(),e),n.blob()})}},is=class extends Ge{constructor(e){super(),this.isExternalMedia=!1,e.media?(this.media=e.media,this.isExternalMedia=!0):this.media=document.createElement("audio"),e.mediaControls&&(this.media.controls=!0),e.autoplay&&(this.media.autoplay=!0),e.playbackRate!=null&&this.onMediaEvent("canplay",()=>{e.playbackRate!=null&&(this.media.playbackRate=e.playbackRate)},{once:!0})}onMediaEvent(e,t,n){return this.media.addEventListener(e,t,n),()=>this.media.removeEventListener(e,t,n)}getSrc(){return this.media.currentSrc||this.media.src||""}revokeSrc(){let e=this.getSrc();e.startsWith("blob:")&&URL.revokeObjectURL(e)}canPlayType(e){return this.media.canPlayType(e)!==""}setSrc(e,t){let n=this.getSrc();if(e&&n===e)return;this.revokeSrc();let s=t instanceof Blob&&(this.canPlayType(t.type)||!e)?URL.createObjectURL(t):e;if(n&&this.media.removeAttribute("src"),s||e)try{this.media.src=s}catch{this.media.src=e}}destroy(){this.isExternalMedia||(this.media.pause(),this.media.remove(),this.revokeSrc(),this.media.removeAttribute("src"),this.media.load())}setMediaElement(e){this.media=e}play(){return H(this,void 0,void 0,function*(){return this.media.play()})}pause(){this.media.pause()}isPlaying(){return!this.media.paused&&!this.media.ended}setTime(e){this.media.currentTime=Math.max(0,Math.min(e,this.getDuration()))}getDuration(){return this.media.duration}getCurrentTime(){return this.media.currentTime}getVolume(){return this.media.volume}setVolume(e){this.media.volume=e}getMuted(){return this.media.muted}setMuted(e){this.media.muted=e}getPlaybackRate(){return this.media.playbackRate}isSeeking(){return this.media.seeking}setPlaybackRate(e,t){t!=null&&(this.media.preservesPitch=t),this.media.playbackRate=e}getMediaElement(){return this.media}setSinkId(e){return this.media.setSinkId(e)}},jt=class r extends Ge{constructor(e,t){super(),this.timeouts=[],this.isScrollable=!1,this.audioData=null,this.resizeObserver=null,this.lastContainerWidth=0,this.isDragging=!1,this.subscriptions=[],this.unsubscribeOnScroll=[],this.subscriptions=[],this.options=e;let n=this.parentFromOptionsContainer(e.container);this.parent=n;let[s,a]=this.initHtml();n.appendChild(s),this.container=s,this.scrollContainer=a.querySelector(".scroll"),this.wrapper=a.querySelector(".wrapper"),this.canvasWrapper=a.querySelector(".canvases"),this.progressWrapper=a.querySelector(".progress"),this.cursor=a.querySelector(".cursor"),t&&a.appendChild(t),this.initEvents()}parentFromOptionsContainer(e){let t;if(typeof e=="string"?t=document.querySelector(e):e instanceof HTMLElement&&(t=e),!t)throw new Error("Container not found");return t}initEvents(){let e=t=>{let n=this.wrapper.getBoundingClientRect(),s=t.clientX-n.left,a=t.clientY-n.top;return[s/n.width,a/n.height]};if(this.wrapper.addEventListener("click",t=>{let[n,s]=e(t);this.emit("click",n,s)}),this.wrapper.addEventListener("dblclick",t=>{let[n,s]=e(t);this.emit("dblclick",n,s)}),this.options.dragToSeek!==!0&&typeof this.options.dragToSeek!="object"||this.initDrag(),this.scrollContainer.addEventListener("scroll",()=>{let{scrollLeft:t,scrollWidth:n,clientWidth:s}=this.scrollContainer,a=t/n,i=(t+s)/n;this.emit("scroll",a,i,t,t+s)}),typeof ResizeObserver=="function"){let t=this.createDelay(100);this.resizeObserver=new ResizeObserver(()=>{t().then(()=>this.onContainerResize()).catch(()=>{})}),this.resizeObserver.observe(this.scrollContainer)}}onContainerResize(){let e=this.parent.clientWidth;e===this.lastContainerWidth&&this.options.height!=="auto"||(this.lastContainerWidth=e,this.reRender())}initDrag(){this.subscriptions.push(function(e,t,n,s,a=3,i=0,o=100){if(!e)return()=>{};let c=matchMedia("(pointer: coarse)").matches,l=()=>{},u=d=>{if(d.button!==i)return;d.preventDefault(),d.stopPropagation();let f=d.clientX,m=d.clientY,h=!1,g=Date.now(),y=x=>{if(x.preventDefault(),x.stopPropagation(),c&&Date.now()-g<o)return;let C=x.clientX,v=x.clientY,F=C-f,A=v-m;if(h||Math.abs(F)>a||Math.abs(A)>a){let _=e.getBoundingClientRect(),{left:B,top:L}=_;h||(n?.(f-B,m-L),h=!0),t(F,A,C-B,v-L),f=C,m=v}},S=x=>{if(h){let C=x.clientX,v=x.clientY,F=e.getBoundingClientRect(),{left:A,top:_}=F;s?.(C-A,v-_)}l()},p=x=>{x.relatedTarget&&x.relatedTarget!==document.documentElement||S(x)},w=x=>{h&&(x.stopPropagation(),x.preventDefault())},k=x=>{h&&x.preventDefault()};document.addEventListener("pointermove",y),document.addEventListener("pointerup",S),document.addEventListener("pointerout",p),document.addEventListener("pointercancel",p),document.addEventListener("touchmove",k,{passive:!1}),document.addEventListener("click",w,{capture:!0}),l=()=>{document.removeEventListener("pointermove",y),document.removeEventListener("pointerup",S),document.removeEventListener("pointerout",p),document.removeEventListener("pointercancel",p),document.removeEventListener("touchmove",k),setTimeout(()=>{document.removeEventListener("click",w,{capture:!0})},10)}};return e.addEventListener("pointerdown",u),()=>{l(),e.removeEventListener("pointerdown",u)}}(this.wrapper,(e,t,n)=>{this.emit("drag",Math.max(0,Math.min(1,n/this.wrapper.getBoundingClientRect().width)))},e=>{this.isDragging=!0,this.emit("dragstart",Math.max(0,Math.min(1,e/this.wrapper.getBoundingClientRect().width)))},e=>{this.isDragging=!1,this.emit("dragend",Math.max(0,Math.min(1,e/this.wrapper.getBoundingClientRect().width)))}))}getHeight(e,t){var n;let s=((n=this.audioData)===null||n===void 0?void 0:n.numberOfChannels)||1;if(e==null)return 128;if(!isNaN(Number(e)))return Number(e);if(e==="auto"){let a=this.parent.clientHeight||128;return t?.every(i=>!i.overlay)?a/s:a}return 128}initHtml(){let e=document.createElement("div"),t=e.attachShadow({mode:"open"}),n=this.options.cspNonce&&typeof this.options.cspNonce=="string"?this.options.cspNonce.replace(/"/g,""):"";return t.innerHTML=`
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
1
|
+
import"./chunk-T3METYEY.js";import{c as Ir,j as Fi,k as Di,l as ho}from"./chunk-5ZZYIILO.js";import"./chunk-P3PTHHFE.js";import"./chunk-USLRKDKD.js";import"./chunk-Q4MWBZHL.js";import{b as Ar}from"./chunk-YISSXWBT.js";import{Aa as go,D as fo,H as $t,N as mo,Q as Ei,R as Kt,T as ht,a as oc,b as ic,c as Cr,d as Ci,da as po,h as uo,i as Ii,k as Ai,m as _i}from"./chunk-PYG4RZZ2.js";var Pa=oc((Gg,va)=>{va.exports=[{name:"Bounce",paramsTypes:{shadow_colour:"vec4",shadow_height:"float",bounces:"float"},defaultParams:{shadow_colour:[0,0,0,.6],shadow_height:.075,bounces:3},glsl:`// Author: Adrian Purser
|
|
2
|
+
// License: MIT
|
|
3
|
+
|
|
4
|
+
uniform vec4 shadow_colour; // = vec4(0.,0.,0.,.6)
|
|
5
|
+
uniform float shadow_height; // = 0.075
|
|
6
|
+
uniform float bounces; // = 3.0
|
|
7
|
+
|
|
8
|
+
const float PI = 3.14159265358;
|
|
9
|
+
|
|
10
|
+
vec4 transition (vec2 uv) {
|
|
11
|
+
float time = progress;
|
|
12
|
+
float stime = sin(time * PI / 2.);
|
|
13
|
+
float phase = time * PI * bounces;
|
|
14
|
+
float y = (abs(cos(phase))) * (1.0 - stime);
|
|
15
|
+
float d = uv.y - y;
|
|
16
|
+
return mix(
|
|
17
|
+
mix(
|
|
18
|
+
getToColor(uv),
|
|
19
|
+
shadow_colour,
|
|
20
|
+
step(d, shadow_height) * (1. - mix(
|
|
21
|
+
((d / shadow_height) * shadow_colour.a) + (1.0 - shadow_colour.a),
|
|
22
|
+
1.0,
|
|
23
|
+
smoothstep(0.95, 1., progress) // fade-out the shadow at the end
|
|
24
|
+
))
|
|
25
|
+
),
|
|
26
|
+
getFromColor(vec2(uv.x, uv.y + (1.0 - y))),
|
|
27
|
+
step(d, 0.0)
|
|
28
|
+
);
|
|
29
|
+
}
|
|
30
|
+
`,author:"Adrian Purser",license:"MIT",createdAt:"Fri, 10 Nov 2017 17:01:45 +0000",updatedAt:"Sat, 11 Nov 2017 08:50:40 +0100"},{name:"BowTieHorizontal",paramsTypes:{},defaultParams:{},glsl:`// Author: huynx
|
|
31
|
+
// License: MIT
|
|
32
|
+
|
|
33
|
+
vec2 bottom_left = vec2(0.0, 1.0);
|
|
34
|
+
vec2 bottom_right = vec2(1.0, 1.0);
|
|
35
|
+
vec2 top_left = vec2(0.0, 0.0);
|
|
36
|
+
vec2 top_right = vec2(1.0, 0.0);
|
|
37
|
+
vec2 center = vec2(0.5, 0.5);
|
|
38
|
+
|
|
39
|
+
float check(vec2 p1, vec2 p2, vec2 p3)
|
|
40
|
+
{
|
|
41
|
+
return (p1.x - p3.x) * (p2.y - p3.y) - (p2.x - p3.x) * (p1.y - p3.y);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
bool PointInTriangle (vec2 pt, vec2 p1, vec2 p2, vec2 p3)
|
|
45
|
+
{
|
|
46
|
+
bool b1, b2, b3;
|
|
47
|
+
b1 = check(pt, p1, p2) < 0.0;
|
|
48
|
+
b2 = check(pt, p2, p3) < 0.0;
|
|
49
|
+
b3 = check(pt, p3, p1) < 0.0;
|
|
50
|
+
return ((b1 == b2) && (b2 == b3));
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
bool in_left_triangle(vec2 p){
|
|
54
|
+
vec2 vertex1, vertex2, vertex3;
|
|
55
|
+
vertex1 = vec2(progress, 0.5);
|
|
56
|
+
vertex2 = vec2(0.0, 0.5-progress);
|
|
57
|
+
vertex3 = vec2(0.0, 0.5+progress);
|
|
58
|
+
if (PointInTriangle(p, vertex1, vertex2, vertex3))
|
|
59
|
+
{
|
|
60
|
+
return true;
|
|
61
|
+
}
|
|
62
|
+
return false;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
bool in_right_triangle(vec2 p){
|
|
66
|
+
vec2 vertex1, vertex2, vertex3;
|
|
67
|
+
vertex1 = vec2(1.0-progress, 0.5);
|
|
68
|
+
vertex2 = vec2(1.0, 0.5-progress);
|
|
69
|
+
vertex3 = vec2(1.0, 0.5+progress);
|
|
70
|
+
if (PointInTriangle(p, vertex1, vertex2, vertex3))
|
|
71
|
+
{
|
|
72
|
+
return true;
|
|
73
|
+
}
|
|
74
|
+
return false;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
float blur_edge(vec2 bot1, vec2 bot2, vec2 top, vec2 testPt)
|
|
78
|
+
{
|
|
79
|
+
vec2 lineDir = bot1 - top;
|
|
80
|
+
vec2 perpDir = vec2(lineDir.y, -lineDir.x);
|
|
81
|
+
vec2 dirToPt1 = bot1 - testPt;
|
|
82
|
+
float dist1 = abs(dot(normalize(perpDir), dirToPt1));
|
|
83
|
+
|
|
84
|
+
lineDir = bot2 - top;
|
|
85
|
+
perpDir = vec2(lineDir.y, -lineDir.x);
|
|
86
|
+
dirToPt1 = bot2 - testPt;
|
|
87
|
+
float min_dist = min(abs(dot(normalize(perpDir), dirToPt1)), dist1);
|
|
88
|
+
|
|
89
|
+
if (min_dist < 0.005) {
|
|
90
|
+
return min_dist / 0.005;
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
return 1.0;
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
vec4 transition (vec2 uv) {
|
|
99
|
+
if (in_left_triangle(uv))
|
|
100
|
+
{
|
|
101
|
+
if (progress < 0.1)
|
|
102
|
+
{
|
|
103
|
+
return getFromColor(uv);
|
|
104
|
+
}
|
|
105
|
+
if (uv.x < 0.5)
|
|
106
|
+
{
|
|
107
|
+
vec2 vertex1 = vec2(progress, 0.5);
|
|
108
|
+
vec2 vertex2 = vec2(0.0, 0.5-progress);
|
|
109
|
+
vec2 vertex3 = vec2(0.0, 0.5+progress);
|
|
110
|
+
return mix(
|
|
111
|
+
getFromColor(uv),
|
|
112
|
+
getToColor(uv),
|
|
113
|
+
blur_edge(vertex2, vertex3, vertex1, uv)
|
|
114
|
+
);
|
|
115
|
+
}
|
|
116
|
+
else
|
|
117
|
+
{
|
|
118
|
+
if (progress > 0.0)
|
|
119
|
+
{
|
|
120
|
+
return getToColor(uv);
|
|
121
|
+
}
|
|
122
|
+
else
|
|
123
|
+
{
|
|
124
|
+
return getFromColor(uv);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
else if (in_right_triangle(uv))
|
|
129
|
+
{
|
|
130
|
+
if (uv.x >= 0.5)
|
|
131
|
+
{
|
|
132
|
+
vec2 vertex1 = vec2(1.0-progress, 0.5);
|
|
133
|
+
vec2 vertex2 = vec2(1.0, 0.5-progress);
|
|
134
|
+
vec2 vertex3 = vec2(1.0, 0.5+progress);
|
|
135
|
+
return mix(
|
|
136
|
+
getFromColor(uv),
|
|
137
|
+
getToColor(uv),
|
|
138
|
+
blur_edge(vertex2, vertex3, vertex1, uv)
|
|
139
|
+
);
|
|
140
|
+
}
|
|
141
|
+
else
|
|
142
|
+
{
|
|
143
|
+
return getFromColor(uv);
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
else {
|
|
147
|
+
return getFromColor(uv);
|
|
148
|
+
}
|
|
149
|
+
}`,author:"huynx",license:"MIT",createdAt:"Sat, 24 Mar 2018 12:54:26 +0100",updatedAt:"Sat, 24 Mar 2018 12:54:26 +0100"},{name:"BowTieVertical",paramsTypes:{},defaultParams:{},glsl:`// Author: huynx\r
|
|
150
|
+
// License: MIT\r
|
|
151
|
+
\r
|
|
152
|
+
float check(vec2 p1, vec2 p2, vec2 p3)\r
|
|
153
|
+
{\r
|
|
154
|
+
return (p1.x - p3.x) * (p2.y - p3.y) - (p2.x - p3.x) * (p1.y - p3.y);\r
|
|
155
|
+
}\r
|
|
156
|
+
\r
|
|
157
|
+
bool PointInTriangle (vec2 pt, vec2 p1, vec2 p2, vec2 p3)\r
|
|
158
|
+
{\r
|
|
159
|
+
bool b1, b2, b3;\r
|
|
160
|
+
b1 = check(pt, p1, p2) < 0.0;\r
|
|
161
|
+
b2 = check(pt, p2, p3) < 0.0;\r
|
|
162
|
+
b3 = check(pt, p3, p1) < 0.0;\r
|
|
163
|
+
return ((b1 == b2) && (b2 == b3));\r
|
|
164
|
+
}\r
|
|
165
|
+
\r
|
|
166
|
+
bool in_top_triangle(vec2 p){\r
|
|
167
|
+
vec2 vertex1, vertex2, vertex3;\r
|
|
168
|
+
vertex1 = vec2(0.5, progress);\r
|
|
169
|
+
vertex2 = vec2(0.5-progress, 0.0);\r
|
|
170
|
+
vertex3 = vec2(0.5+progress, 0.0);\r
|
|
171
|
+
if (PointInTriangle(p, vertex1, vertex2, vertex3))\r
|
|
172
|
+
{\r
|
|
173
|
+
return true;\r
|
|
174
|
+
}\r
|
|
175
|
+
return false;\r
|
|
176
|
+
}\r
|
|
177
|
+
\r
|
|
178
|
+
bool in_bottom_triangle(vec2 p){\r
|
|
179
|
+
vec2 vertex1, vertex2, vertex3;\r
|
|
180
|
+
vertex1 = vec2(0.5, 1.0 - progress);\r
|
|
181
|
+
vertex2 = vec2(0.5-progress, 1.0);\r
|
|
182
|
+
vertex3 = vec2(0.5+progress, 1.0);\r
|
|
183
|
+
if (PointInTriangle(p, vertex1, vertex2, vertex3))\r
|
|
184
|
+
{\r
|
|
185
|
+
return true;\r
|
|
186
|
+
}\r
|
|
187
|
+
return false;\r
|
|
188
|
+
}\r
|
|
189
|
+
\r
|
|
190
|
+
float blur_edge(vec2 bot1, vec2 bot2, vec2 top, vec2 testPt)\r
|
|
191
|
+
{\r
|
|
192
|
+
vec2 lineDir = bot1 - top;\r
|
|
193
|
+
vec2 perpDir = vec2(lineDir.y, -lineDir.x);\r
|
|
194
|
+
vec2 dirToPt1 = bot1 - testPt;\r
|
|
195
|
+
float dist1 = abs(dot(normalize(perpDir), dirToPt1));\r
|
|
196
|
+
\r
|
|
197
|
+
lineDir = bot2 - top;\r
|
|
198
|
+
perpDir = vec2(lineDir.y, -lineDir.x);\r
|
|
199
|
+
dirToPt1 = bot2 - testPt;\r
|
|
200
|
+
float min_dist = min(abs(dot(normalize(perpDir), dirToPt1)), dist1);\r
|
|
201
|
+
\r
|
|
202
|
+
if (min_dist < 0.005) {\r
|
|
203
|
+
return min_dist / 0.005;\r
|
|
204
|
+
}\r
|
|
205
|
+
else {\r
|
|
206
|
+
return 1.0;\r
|
|
207
|
+
};\r
|
|
208
|
+
}\r
|
|
209
|
+
\r
|
|
210
|
+
\r
|
|
211
|
+
vec4 transition (vec2 uv) {\r
|
|
212
|
+
if (in_top_triangle(uv))\r
|
|
213
|
+
{\r
|
|
214
|
+
if (progress < 0.1)\r
|
|
215
|
+
{\r
|
|
216
|
+
return getFromColor(uv);\r
|
|
217
|
+
}\r
|
|
218
|
+
if (uv.y < 0.5)\r
|
|
219
|
+
{\r
|
|
220
|
+
vec2 vertex1 = vec2(0.5, progress);\r
|
|
221
|
+
vec2 vertex2 = vec2(0.5-progress, 0.0);\r
|
|
222
|
+
vec2 vertex3 = vec2(0.5+progress, 0.0);\r
|
|
223
|
+
return mix(\r
|
|
224
|
+
getFromColor(uv),\r
|
|
225
|
+
getToColor(uv),\r
|
|
226
|
+
blur_edge(vertex2, vertex3, vertex1, uv)\r
|
|
227
|
+
);\r
|
|
228
|
+
}\r
|
|
229
|
+
else\r
|
|
230
|
+
{\r
|
|
231
|
+
if (progress > 0.0)\r
|
|
232
|
+
{\r
|
|
233
|
+
return getToColor(uv);\r
|
|
234
|
+
}\r
|
|
235
|
+
else\r
|
|
236
|
+
{\r
|
|
237
|
+
return getFromColor(uv);\r
|
|
238
|
+
}\r
|
|
239
|
+
} \r
|
|
240
|
+
}\r
|
|
241
|
+
else if (in_bottom_triangle(uv))\r
|
|
242
|
+
{\r
|
|
243
|
+
if (uv.y >= 0.5)\r
|
|
244
|
+
{\r
|
|
245
|
+
vec2 vertex1 = vec2(0.5, 1.0-progress);\r
|
|
246
|
+
vec2 vertex2 = vec2(0.5-progress, 1.0);\r
|
|
247
|
+
vec2 vertex3 = vec2(0.5+progress, 1.0);\r
|
|
248
|
+
return mix(\r
|
|
249
|
+
getFromColor(uv),\r
|
|
250
|
+
getToColor(uv),\r
|
|
251
|
+
blur_edge(vertex2, vertex3, vertex1, uv)\r
|
|
252
|
+
); \r
|
|
253
|
+
}\r
|
|
254
|
+
else\r
|
|
255
|
+
{\r
|
|
256
|
+
return getFromColor(uv);\r
|
|
257
|
+
}\r
|
|
258
|
+
}\r
|
|
259
|
+
else {\r
|
|
260
|
+
return getFromColor(uv);\r
|
|
261
|
+
}\r
|
|
262
|
+
}`,author:"huynx",license:"MIT",createdAt:"Tue, 27 Mar 2018 10:07:54 +0700",updatedAt:"Tue, 27 Mar 2018 10:07:54 +0700"},{name:"ButterflyWaveScrawler",paramsTypes:{amplitude:"float",waves:"float",colorSeparation:"float"},defaultParams:{amplitude:1,waves:30,colorSeparation:.3},glsl:`// Author: mandubian
|
|
263
|
+
// License: MIT
|
|
264
|
+
uniform float amplitude; // = 1.0
|
|
265
|
+
uniform float waves; // = 30.0
|
|
266
|
+
uniform float colorSeparation; // = 0.3
|
|
267
|
+
float PI = 3.14159265358979323846264;
|
|
268
|
+
float compute(vec2 p, float progress, vec2 center) {
|
|
269
|
+
vec2 o = p*sin(progress * amplitude)-center;
|
|
270
|
+
// horizontal vector
|
|
271
|
+
vec2 h = vec2(1., 0.);
|
|
272
|
+
// butterfly polar function (don't ask me why this one :))
|
|
273
|
+
float theta = acos(dot(o, h)) * waves;
|
|
274
|
+
return (exp(cos(theta)) - 2.*cos(4.*theta) + pow(sin((2.*theta - PI) / 24.), 5.)) / 10.;
|
|
275
|
+
}
|
|
276
|
+
vec4 transition(vec2 uv) {
|
|
277
|
+
vec2 p = uv.xy / vec2(1.0).xy;
|
|
278
|
+
float inv = 1. - progress;
|
|
279
|
+
vec2 dir = p - vec2(.5);
|
|
280
|
+
float dist = length(dir);
|
|
281
|
+
float disp = compute(p, progress, vec2(0.5, 0.5)) ;
|
|
282
|
+
vec4 texTo = getToColor(p + inv*disp);
|
|
283
|
+
vec4 texFrom = vec4(
|
|
284
|
+
getFromColor(p + progress*disp*(1.0 - colorSeparation)).r,
|
|
285
|
+
getFromColor(p + progress*disp).g,
|
|
286
|
+
getFromColor(p + progress*disp*(1.0 + colorSeparation)).b,
|
|
287
|
+
1.0);
|
|
288
|
+
return texTo*progress + texFrom*inv;
|
|
289
|
+
}
|
|
290
|
+
`,author:"mandubian",license:"MIT",createdAt:"Thu, 1 Jun 2017 11:47:17 +0200",updatedAt:"Thu, 1 Jun 2017 11:47:17 +0200"},{name:"CircleCrop",paramsTypes:{bgcolor:"vec4"},defaultParams:{bgcolor:[0,0,0,1]},glsl:`// License: MIT
|
|
291
|
+
// Author: fkuteken
|
|
292
|
+
// ported by gre from https://gist.github.com/fkuteken/f63e3009c1143950dee9063c3b83fb88
|
|
293
|
+
|
|
294
|
+
uniform vec4 bgcolor; // = vec4(0.0, 0.0, 0.0, 1.0)
|
|
295
|
+
|
|
296
|
+
vec2 ratio2 = vec2(1.0, 1.0 / ratio);
|
|
297
|
+
float s = pow(2.0 * abs(progress - 0.5), 3.0);
|
|
298
|
+
|
|
299
|
+
vec4 transition(vec2 p) {
|
|
300
|
+
float dist = length((vec2(p) - 0.5) * ratio2);
|
|
301
|
+
return mix(
|
|
302
|
+
progress < 0.5 ? getFromColor(p) : getToColor(p), // branching is ok here as we statically depend on progress uniform (branching won't change over pixels)
|
|
303
|
+
bgcolor,
|
|
304
|
+
step(s, dist)
|
|
305
|
+
);
|
|
306
|
+
}
|
|
307
|
+
`,license:"MIT",author:"fkuteken",createdAt:"Mon, 12 Jun 2017 12:52:34 +0800",updatedAt:"Mon, 12 Jun 2017 12:52:34 +0800"},{name:"ColourDistance",paramsTypes:{power:"float"},defaultParams:{power:5},glsl:`// License: MIT
|
|
308
|
+
// Author: P-Seebauer
|
|
309
|
+
// ported by gre from https://gist.github.com/P-Seebauer/2a5fa2f77c883dd661f9
|
|
310
|
+
|
|
311
|
+
uniform float power; // = 5.0
|
|
312
|
+
|
|
313
|
+
vec4 transition(vec2 p) {
|
|
314
|
+
vec4 fTex = getFromColor(p);
|
|
315
|
+
vec4 tTex = getToColor(p);
|
|
316
|
+
float m = step(distance(fTex, tTex), progress);
|
|
317
|
+
return mix(
|
|
318
|
+
mix(fTex, tTex, m),
|
|
319
|
+
tTex,
|
|
320
|
+
pow(progress, power)
|
|
321
|
+
);
|
|
322
|
+
}
|
|
323
|
+
`,license:"MIT",author:"P-Seebauer",createdAt:"Mon, 12 Jun 2017 12:57:42 +0800",updatedAt:"Mon, 12 Jun 2017 12:57:42 +0800"},{name:"CrazyParametricFun",paramsTypes:{a:"float",b:"float",amplitude:"float",smoothness:"float"},defaultParams:{a:4,b:1,amplitude:120,smoothness:.1},glsl:`// Author: mandubian
|
|
324
|
+
// License: MIT
|
|
325
|
+
|
|
326
|
+
uniform float a; // = 4
|
|
327
|
+
uniform float b; // = 1
|
|
328
|
+
uniform float amplitude; // = 120
|
|
329
|
+
uniform float smoothness; // = 0.1
|
|
330
|
+
|
|
331
|
+
vec4 transition(vec2 uv) {
|
|
332
|
+
vec2 p = uv.xy / vec2(1.0).xy;
|
|
333
|
+
vec2 dir = p - vec2(.5);
|
|
334
|
+
float dist = length(dir);
|
|
335
|
+
float x = (a - b) * cos(progress) + b * cos(progress * ((a / b) - 1.) );
|
|
336
|
+
float y = (a - b) * sin(progress) - b * sin(progress * ((a / b) - 1.));
|
|
337
|
+
vec2 offset = dir * vec2(sin(progress * dist * amplitude * x), sin(progress * dist * amplitude * y)) / smoothness;
|
|
338
|
+
return mix(getFromColor(p + offset), getToColor(p), smoothstep(0.2, 1.0, progress));
|
|
339
|
+
}
|
|
340
|
+
`,author:"mandubian",license:"MIT",createdAt:"Thu, 1 Jun 2017 13:03:12 +0200",updatedAt:"Thu, 1 Jun 2017 13:03:12 +0200"},{name:"CrossZoom",paramsTypes:{strength:"float"},defaultParams:{strength:.4},glsl:`// License: MIT
|
|
341
|
+
// Author: rectalogic
|
|
342
|
+
// ported by gre from https://gist.github.com/rectalogic/b86b90161503a0023231
|
|
343
|
+
|
|
344
|
+
// Converted from https://github.com/rectalogic/rendermix-basic-effects/blob/master/assets/com/rendermix/CrossZoom/CrossZoom.frag
|
|
345
|
+
// Which is based on https://github.com/evanw/glfx.js/blob/master/src/filters/blur/zoomblur.js
|
|
346
|
+
// With additional easing functions from https://github.com/rectalogic/rendermix-basic-effects/blob/master/assets/com/rendermix/Easing/Easing.glsllib
|
|
347
|
+
|
|
348
|
+
uniform float strength; // = 0.4
|
|
349
|
+
|
|
350
|
+
const float PI = 3.141592653589793;
|
|
351
|
+
|
|
352
|
+
float Linear_ease(in float begin, in float change, in float duration, in float time) {
|
|
353
|
+
return change * time / duration + begin;
|
|
354
|
+
}
|
|
355
|
+
|
|
356
|
+
float Exponential_easeInOut(in float begin, in float change, in float duration, in float time) {
|
|
357
|
+
if (time == 0.0)
|
|
358
|
+
return begin;
|
|
359
|
+
else if (time == duration)
|
|
360
|
+
return begin + change;
|
|
361
|
+
time = time / (duration / 2.0);
|
|
362
|
+
if (time < 1.0)
|
|
363
|
+
return change / 2.0 * pow(2.0, 10.0 * (time - 1.0)) + begin;
|
|
364
|
+
return change / 2.0 * (-pow(2.0, -10.0 * (time - 1.0)) + 2.0) + begin;
|
|
365
|
+
}
|
|
366
|
+
|
|
367
|
+
float Sinusoidal_easeInOut(in float begin, in float change, in float duration, in float time) {
|
|
368
|
+
return -change / 2.0 * (cos(PI * time / duration) - 1.0) + begin;
|
|
369
|
+
}
|
|
370
|
+
|
|
371
|
+
float rand (vec2 co) {
|
|
372
|
+
return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
vec3 crossFade(in vec2 uv, in float dissolve) {
|
|
376
|
+
return mix(getFromColor(uv).rgb, getToColor(uv).rgb, dissolve);
|
|
377
|
+
}
|
|
378
|
+
|
|
379
|
+
vec4 transition(vec2 uv) {
|
|
380
|
+
vec2 texCoord = uv.xy / vec2(1.0).xy;
|
|
381
|
+
|
|
382
|
+
// Linear interpolate center across center half of the image
|
|
383
|
+
vec2 center = vec2(Linear_ease(0.25, 0.5, 1.0, progress), 0.5);
|
|
384
|
+
float dissolve = Exponential_easeInOut(0.0, 1.0, 1.0, progress);
|
|
385
|
+
|
|
386
|
+
// Mirrored sinusoidal loop. 0->strength then strength->0
|
|
387
|
+
float strength = Sinusoidal_easeInOut(0.0, strength, 0.5, progress);
|
|
388
|
+
|
|
389
|
+
vec3 color = vec3(0.0);
|
|
390
|
+
float total = 0.0;
|
|
391
|
+
vec2 toCenter = center - texCoord;
|
|
392
|
+
|
|
393
|
+
/* randomize the lookup values to hide the fixed number of samples */
|
|
394
|
+
float offset = rand(uv);
|
|
395
|
+
|
|
396
|
+
for (float t = 0.0; t <= 40.0; t++) {
|
|
397
|
+
float percent = (t + offset) / 40.0;
|
|
398
|
+
float weight = 4.0 * (percent - percent * percent);
|
|
399
|
+
color += crossFade(texCoord + toCenter * percent * strength, dissolve) * weight;
|
|
400
|
+
total += weight;
|
|
401
|
+
}
|
|
402
|
+
return vec4(color / total, 1.0);
|
|
403
|
+
}
|
|
404
|
+
`,license:"MIT",author:"rectalogic",createdAt:"Mon, 12 Jun 2017 12:33:07 +0800",updatedAt:"Mon, 12 Jun 2017 12:33:07 +0800"},{name:"Directional",paramsTypes:{direction:"vec2"},defaultParams:{direction:[0,1]},glsl:`// Author: Ga\xEBtan Renaudeau
|
|
405
|
+
// License: MIT
|
|
406
|
+
|
|
407
|
+
uniform vec2 direction; // = vec2(0.0, 1.0)
|
|
408
|
+
|
|
409
|
+
vec4 transition (vec2 uv) {
|
|
410
|
+
vec2 p = uv + progress * sign(direction);
|
|
411
|
+
vec2 f = fract(p);
|
|
412
|
+
return mix(
|
|
413
|
+
getToColor(f),
|
|
414
|
+
getFromColor(f),
|
|
415
|
+
step(0.0, p.y) * step(p.y, 1.0) * step(0.0, p.x) * step(p.x, 1.0)
|
|
416
|
+
);
|
|
417
|
+
}
|
|
418
|
+
`,author:"Ga\xEBtan Renaudeau",license:"MIT",createdAt:"Thu, 19 Apr 2018 12:20:29 +0200",updatedAt:"Thu, 19 Apr 2018 12:20:29 +0200"},{name:"DoomScreenTransition",paramsTypes:{bars:"int",amplitude:"float",noise:"float",frequency:"float",dripScale:"float"},defaultParams:{bars:30,amplitude:2,noise:.1,frequency:.5,dripScale:.5},glsl:`// Author: Zeh Fernando
|
|
419
|
+
// License: MIT
|
|
420
|
+
|
|
421
|
+
|
|
422
|
+
// Transition parameters --------
|
|
423
|
+
|
|
424
|
+
// Number of total bars/columns
|
|
425
|
+
uniform int bars; // = 30
|
|
426
|
+
|
|
427
|
+
// Multiplier for speed ratio. 0 = no variation when going down, higher = some elements go much faster
|
|
428
|
+
uniform float amplitude; // = 2
|
|
429
|
+
|
|
430
|
+
// Further variations in speed. 0 = no noise, 1 = super noisy (ignore frequency)
|
|
431
|
+
uniform float noise; // = 0.1
|
|
432
|
+
|
|
433
|
+
// Speed variation horizontally. the bigger the value, the shorter the waves
|
|
434
|
+
uniform float frequency; // = 0.5
|
|
435
|
+
|
|
436
|
+
// How much the bars seem to "run" from the middle of the screen first (sticking to the sides). 0 = no drip, 1 = curved drip
|
|
437
|
+
uniform float dripScale; // = 0.5
|
|
438
|
+
|
|
439
|
+
|
|
440
|
+
// The code proper --------
|
|
441
|
+
|
|
442
|
+
float rand(int num) {
|
|
443
|
+
return fract(mod(float(num) * 67123.313, 12.0) * sin(float(num) * 10.3) * cos(float(num)));
|
|
444
|
+
}
|
|
445
|
+
|
|
446
|
+
float wave(int num) {
|
|
447
|
+
float fn = float(num) * frequency * 0.1 * float(bars);
|
|
448
|
+
return cos(fn * 0.5) * cos(fn * 0.13) * sin((fn+10.0) * 0.3) / 2.0 + 0.5;
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
float drip(int num) {
|
|
452
|
+
return sin(float(num) / float(bars - 1) * 3.141592) * dripScale;
|
|
453
|
+
}
|
|
454
|
+
|
|
455
|
+
float pos(int num) {
|
|
456
|
+
return (noise == 0.0 ? wave(num) : mix(wave(num), rand(num), noise)) + (dripScale == 0.0 ? 0.0 : drip(num));
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
vec4 transition(vec2 uv) {
|
|
460
|
+
int bar = int(uv.x * (float(bars)));
|
|
461
|
+
float scale = 1.0 + pos(bar) * amplitude;
|
|
462
|
+
float phase = progress * scale;
|
|
463
|
+
float posY = uv.y / vec2(1.0).y;
|
|
464
|
+
vec2 p;
|
|
465
|
+
vec4 c;
|
|
466
|
+
if (phase + posY < 1.0) {
|
|
467
|
+
p = vec2(uv.x, uv.y + mix(0.0, vec2(1.0).y, phase)) / vec2(1.0).xy;
|
|
468
|
+
c = getFromColor(p);
|
|
469
|
+
} else {
|
|
470
|
+
p = uv.xy / vec2(1.0).xy;
|
|
471
|
+
c = getToColor(p);
|
|
472
|
+
}
|
|
473
|
+
|
|
474
|
+
// Finally, apply the color
|
|
475
|
+
return c;
|
|
476
|
+
}
|
|
477
|
+
`,author:"Zeh Fernando",license:"MIT",createdAt:"Tue, 30 May 2017 09:39:09 -0700",updatedAt:"Tue, 30 May 2017 09:39:09 -0700"},{name:"Dreamy",paramsTypes:{},defaultParams:{},glsl:`// Author: mikolalysenko
|
|
478
|
+
// License: MIT
|
|
479
|
+
|
|
480
|
+
vec2 offset(float progress, float x, float theta) {
|
|
481
|
+
float phase = progress*progress + progress + theta;
|
|
482
|
+
float shifty = 0.03*progress*cos(10.0*(progress+x));
|
|
483
|
+
return vec2(0, shifty);
|
|
484
|
+
}
|
|
485
|
+
vec4 transition(vec2 p) {
|
|
486
|
+
return mix(getFromColor(p + offset(progress, p.x, 0.0)), getToColor(p + offset(1.0-progress, p.x, 3.14)), progress);
|
|
487
|
+
}
|
|
488
|
+
`,author:"mikolalysenko",license:"MIT",createdAt:"Mon, 12 Jun 2017 12:27:38 +0800",updatedAt:"Mon, 12 Jun 2017 12:27:38 +0800"},{name:"DreamyZoom",paramsTypes:{rotation:"float",scale:"float"},defaultParams:{rotation:6,scale:1.2},glsl:`// Author: Zeh Fernando
|
|
489
|
+
// License: MIT
|
|
490
|
+
|
|
491
|
+
// Definitions --------
|
|
492
|
+
#define DEG2RAD 0.03926990816987241548078304229099 // 1/180*PI
|
|
493
|
+
|
|
494
|
+
|
|
495
|
+
// Transition parameters --------
|
|
496
|
+
|
|
497
|
+
// In degrees
|
|
498
|
+
uniform float rotation; // = 6
|
|
499
|
+
|
|
500
|
+
// Multiplier
|
|
501
|
+
uniform float scale; // = 1.2
|
|
502
|
+
|
|
503
|
+
|
|
504
|
+
// The code proper --------
|
|
505
|
+
|
|
506
|
+
vec4 transition(vec2 uv) {
|
|
507
|
+
// Massage parameters
|
|
508
|
+
float phase = progress < 0.5 ? progress * 2.0 : (progress - 0.5) * 2.0;
|
|
509
|
+
float angleOffset = progress < 0.5 ? mix(0.0, rotation * DEG2RAD, phase) : mix(-rotation * DEG2RAD, 0.0, phase);
|
|
510
|
+
float newScale = progress < 0.5 ? mix(1.0, scale, phase) : mix(scale, 1.0, phase);
|
|
511
|
+
|
|
512
|
+
vec2 center = vec2(0, 0);
|
|
513
|
+
|
|
514
|
+
// Calculate the source point
|
|
515
|
+
vec2 assumedCenter = vec2(0.5, 0.5);
|
|
516
|
+
vec2 p = (uv.xy - vec2(0.5, 0.5)) / newScale * vec2(ratio, 1.0);
|
|
517
|
+
|
|
518
|
+
// This can probably be optimized (with distance())
|
|
519
|
+
float angle = atan(p.y, p.x) + angleOffset;
|
|
520
|
+
float dist = distance(center, p);
|
|
521
|
+
p.x = cos(angle) * dist / ratio + 0.5;
|
|
522
|
+
p.y = sin(angle) * dist + 0.5;
|
|
523
|
+
vec4 c = progress < 0.5 ? getFromColor(p) : getToColor(p);
|
|
524
|
+
|
|
525
|
+
// Finally, apply the color
|
|
526
|
+
return c + (progress < 0.5 ? mix(0.0, 1.0, phase) : mix(1.0, 0.0, phase));
|
|
527
|
+
}
|
|
528
|
+
`,author:"Zeh Fernando",license:"MIT",createdAt:"Tue, 30 May 2017 10:44:06 -0700",updatedAt:"Tue, 30 May 2017 10:44:06 -0700"},{name:"GlitchDisplace",paramsTypes:{},defaultParams:{},glsl:`// Author: Matt DesLauriers
|
|
529
|
+
// License: MIT
|
|
530
|
+
|
|
531
|
+
highp float random(vec2 co)
|
|
532
|
+
{
|
|
533
|
+
highp float a = 12.9898;
|
|
534
|
+
highp float b = 78.233;
|
|
535
|
+
highp float c = 43758.5453;
|
|
536
|
+
highp float dt= dot(co.xy ,vec2(a,b));
|
|
537
|
+
highp float sn= mod(dt,3.14);
|
|
538
|
+
return fract(sin(sn) * c);
|
|
539
|
+
}
|
|
540
|
+
float voronoi( in vec2 x ) {
|
|
541
|
+
vec2 p = floor( x );
|
|
542
|
+
vec2 f = fract( x );
|
|
543
|
+
float res = 8.0;
|
|
544
|
+
for( float j=-1.; j<=1.; j++ )
|
|
545
|
+
for( float i=-1.; i<=1.; i++ ) {
|
|
546
|
+
vec2 b = vec2( i, j );
|
|
547
|
+
vec2 r = b - f + random( p + b );
|
|
548
|
+
float d = dot( r, r );
|
|
549
|
+
res = min( res, d );
|
|
550
|
+
}
|
|
551
|
+
return sqrt( res );
|
|
552
|
+
}
|
|
553
|
+
|
|
554
|
+
vec2 displace(vec4 tex, vec2 texCoord, float dotDepth, float textureDepth, float strength) {
|
|
555
|
+
float b = voronoi(.003 * texCoord + 2.0);
|
|
556
|
+
float g = voronoi(0.2 * texCoord);
|
|
557
|
+
float r = voronoi(texCoord - 1.0);
|
|
558
|
+
vec4 dt = tex * 1.0;
|
|
559
|
+
vec4 dis = dt * dotDepth + 1.0 - tex * textureDepth;
|
|
560
|
+
|
|
561
|
+
dis.x = dis.x - 1.0 + textureDepth*dotDepth;
|
|
562
|
+
dis.y = dis.y - 1.0 + textureDepth*dotDepth;
|
|
563
|
+
dis.x *= strength;
|
|
564
|
+
dis.y *= strength;
|
|
565
|
+
vec2 res_uv = texCoord ;
|
|
566
|
+
res_uv.x = res_uv.x + dis.x - 0.0;
|
|
567
|
+
res_uv.y = res_uv.y + dis.y;
|
|
568
|
+
return res_uv;
|
|
569
|
+
}
|
|
570
|
+
|
|
571
|
+
float ease1(float t) {
|
|
572
|
+
return t == 0.0 || t == 1.0
|
|
573
|
+
? t
|
|
574
|
+
: t < 0.5
|
|
575
|
+
? +0.5 * pow(2.0, (20.0 * t) - 10.0)
|
|
576
|
+
: -0.5 * pow(2.0, 10.0 - (t * 20.0)) + 1.0;
|
|
577
|
+
}
|
|
578
|
+
float ease2(float t) {
|
|
579
|
+
return t == 1.0 ? t : 1.0 - pow(2.0, -10.0 * t);
|
|
580
|
+
}
|
|
581
|
+
|
|
582
|
+
|
|
583
|
+
|
|
584
|
+
vec4 transition(vec2 uv) {
|
|
585
|
+
vec2 p = uv.xy / vec2(1.0).xy;
|
|
586
|
+
vec4 color1 = getFromColor(p);
|
|
587
|
+
vec4 color2 = getToColor(p);
|
|
588
|
+
vec2 disp = displace(color1, p, 0.33, 0.7, 1.0-ease1(progress));
|
|
589
|
+
vec2 disp2 = displace(color2, p, 0.33, 0.5, ease2(progress));
|
|
590
|
+
vec4 dColor1 = getToColor(disp);
|
|
591
|
+
vec4 dColor2 = getFromColor(disp2);
|
|
592
|
+
float val = ease1(progress);
|
|
593
|
+
vec3 gray = vec3(dot(min(dColor2, dColor1).rgb, vec3(0.299, 0.587, 0.114)));
|
|
594
|
+
dColor2 = vec4(gray, 1.0);
|
|
595
|
+
dColor2 *= 2.0;
|
|
596
|
+
color1 = mix(color1, dColor2, smoothstep(0.0, 0.5, progress));
|
|
597
|
+
color2 = mix(color2, dColor1, smoothstep(1.0, 0.5, progress));
|
|
598
|
+
return mix(color1, color2, val);
|
|
599
|
+
//gl_FragColor = mix(gl_FragColor, dColor, smoothstep(0.0, 0.5, progress));
|
|
600
|
+
|
|
601
|
+
//gl_FragColor = mix(texture2D(from, p), texture2D(to, p), progress);
|
|
602
|
+
}
|
|
603
|
+
`,author:"Matt DesLauriers",license:"MIT",createdAt:"Tue, 30 May 2017 14:53:04 -0400",updatedAt:"Tue, 30 May 2017 14:53:04 -0400"},{name:"GlitchMemories",paramsTypes:{},defaultParams:{},glsl:`// author: Gunnar Roth
|
|
604
|
+
// based on work from natewave
|
|
605
|
+
// license: MIT
|
|
606
|
+
vec4 transition(vec2 p) {
|
|
607
|
+
vec2 block = floor(p.xy / vec2(16));
|
|
608
|
+
vec2 uv_noise = block / vec2(64);
|
|
609
|
+
uv_noise += floor(vec2(progress) * vec2(1200.0, 3500.0)) / vec2(64);
|
|
610
|
+
vec2 dist = progress > 0.0 ? (fract(uv_noise) - 0.5) * 0.3 *(1.0 -progress) : vec2(0.0);
|
|
611
|
+
vec2 red = p + dist * 0.2;
|
|
612
|
+
vec2 green = p + dist * .3;
|
|
613
|
+
vec2 blue = p + dist * .5;
|
|
614
|
+
|
|
615
|
+
return vec4(mix(getFromColor(red), getToColor(red), progress).r,mix(getFromColor(green), getToColor(green), progress).g,mix(getFromColor(blue), getToColor(blue), progress).b,1.0);
|
|
616
|
+
}
|
|
617
|
+
|
|
618
|
+
`,author:"Gunnar Roth",license:"MIT",createdAt:"Wed, 21 Feb 2018 00:52:15 +0100",updatedAt:"Wed, 21 Feb 2018 19:32:02 +0100"},{name:"GridFlip",paramsTypes:{size:"ivec2",pause:"float",dividerWidth:"float",bgcolor:"vec4",randomness:"float"},defaultParams:{size:[4,4],pause:.1,dividerWidth:.05,bgcolor:[0,0,0,1],randomness:.1},glsl:`// License: MIT
|
|
619
|
+
// Author: TimDonselaar
|
|
620
|
+
// ported by gre from https://gist.github.com/TimDonselaar/9bcd1c4b5934ba60087bdb55c2ea92e5
|
|
621
|
+
|
|
622
|
+
uniform ivec2 size; // = ivec2(4)
|
|
623
|
+
uniform float pause; // = 0.1
|
|
624
|
+
uniform float dividerWidth; // = 0.05
|
|
625
|
+
uniform vec4 bgcolor; // = vec4(0.0, 0.0, 0.0, 1.0)
|
|
626
|
+
uniform float randomness; // = 0.1
|
|
627
|
+
|
|
628
|
+
float rand (vec2 co) {
|
|
629
|
+
return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);
|
|
630
|
+
}
|
|
631
|
+
|
|
632
|
+
float getDelta(vec2 p) {
|
|
633
|
+
vec2 rectanglePos = floor(vec2(size) * p);
|
|
634
|
+
vec2 rectangleSize = vec2(1.0 / vec2(size).x, 1.0 / vec2(size).y);
|
|
635
|
+
float top = rectangleSize.y * (rectanglePos.y + 1.0);
|
|
636
|
+
float bottom = rectangleSize.y * rectanglePos.y;
|
|
637
|
+
float left = rectangleSize.x * rectanglePos.x;
|
|
638
|
+
float right = rectangleSize.x * (rectanglePos.x + 1.0);
|
|
639
|
+
float minX = min(abs(p.x - left), abs(p.x - right));
|
|
640
|
+
float minY = min(abs(p.y - top), abs(p.y - bottom));
|
|
641
|
+
return min(minX, minY);
|
|
642
|
+
}
|
|
643
|
+
|
|
644
|
+
float getDividerSize() {
|
|
645
|
+
vec2 rectangleSize = vec2(1.0 / vec2(size).x, 1.0 / vec2(size).y);
|
|
646
|
+
return min(rectangleSize.x, rectangleSize.y) * dividerWidth;
|
|
647
|
+
}
|
|
648
|
+
|
|
649
|
+
vec4 transition(vec2 p) {
|
|
650
|
+
if(progress < pause) {
|
|
651
|
+
float currentProg = progress / pause;
|
|
652
|
+
float a = 1.0;
|
|
653
|
+
if(getDelta(p) < getDividerSize()) {
|
|
654
|
+
a = 1.0 - currentProg;
|
|
655
|
+
}
|
|
656
|
+
return mix(bgcolor, getFromColor(p), a);
|
|
657
|
+
}
|
|
658
|
+
else if(progress < 1.0 - pause){
|
|
659
|
+
if(getDelta(p) < getDividerSize()) {
|
|
660
|
+
return bgcolor;
|
|
661
|
+
} else {
|
|
662
|
+
float currentProg = (progress - pause) / (1.0 - pause * 2.0);
|
|
663
|
+
vec2 q = p;
|
|
664
|
+
vec2 rectanglePos = floor(vec2(size) * q);
|
|
665
|
+
|
|
666
|
+
float r = rand(rectanglePos) - randomness;
|
|
667
|
+
float cp = smoothstep(0.0, 1.0 - r, currentProg);
|
|
668
|
+
|
|
669
|
+
float rectangleSize = 1.0 / vec2(size).x;
|
|
670
|
+
float delta = rectanglePos.x * rectangleSize;
|
|
671
|
+
float offset = rectangleSize / 2.0 + delta;
|
|
672
|
+
|
|
673
|
+
p.x = (p.x - offset)/abs(cp - 0.5)*0.5 + offset;
|
|
674
|
+
vec4 a = getFromColor(p);
|
|
675
|
+
vec4 b = getToColor(p);
|
|
676
|
+
|
|
677
|
+
float s = step(abs(vec2(size).x * (q.x - delta) - 0.5), abs(cp - 0.5));
|
|
678
|
+
return mix(bgcolor, mix(b, a, step(cp, 0.5)), s);
|
|
679
|
+
}
|
|
680
|
+
}
|
|
681
|
+
else {
|
|
682
|
+
float currentProg = (progress - 1.0 + pause) / pause;
|
|
683
|
+
float a = 1.0;
|
|
684
|
+
if(getDelta(p) < getDividerSize()) {
|
|
685
|
+
a = currentProg;
|
|
686
|
+
}
|
|
687
|
+
return mix(bgcolor, getToColor(p), a);
|
|
688
|
+
}
|
|
689
|
+
}
|
|
690
|
+
`,license:"MIT",author:"TimDonselaar",createdAt:"Mon, 12 Jun 2017 11:32:51 +0800",updatedAt:"Mon, 12 Jun 2017 11:32:51 +0800"},{name:"InvertedPageCurl",paramsTypes:{},defaultParams:{},glsl:`// author: Hewlett-Packard
|
|
691
|
+
// license: BSD 3 Clause
|
|
692
|
+
// Adapted by Sergey Kosarevsky from:
|
|
693
|
+
// http://rectalogic.github.io/webvfx/examples_2transition-shader-pagecurl_8html-example.html
|
|
694
|
+
|
|
695
|
+
/*
|
|
696
|
+
Copyright (c) 2010 Hewlett-Packard Development Company, L.P. All rights reserved.
|
|
697
|
+
|
|
698
|
+
Redistribution and use in source and binary forms, with or without
|
|
699
|
+
modification, are permitted provided that the following conditions are
|
|
700
|
+
met:
|
|
701
|
+
|
|
702
|
+
* Redistributions of source code must retain the above copyright
|
|
703
|
+
notice, this list of conditions and the following disclaimer.
|
|
704
|
+
* Redistributions in binary form must reproduce the above
|
|
705
|
+
copyright notice, this list of conditions and the following disclaimer
|
|
706
|
+
in the documentation and/or other materials provided with the
|
|
707
|
+
distribution.
|
|
708
|
+
* Neither the name of Hewlett-Packard nor the names of its
|
|
709
|
+
contributors may be used to endorse or promote products derived from
|
|
710
|
+
this software without specific prior written permission.
|
|
711
|
+
|
|
712
|
+
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
713
|
+
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
714
|
+
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
715
|
+
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
716
|
+
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
717
|
+
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
718
|
+
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
719
|
+
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
720
|
+
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
721
|
+
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
722
|
+
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
723
|
+
in vec2 texCoord;
|
|
724
|
+
*/
|
|
725
|
+
|
|
726
|
+
const float MIN_AMOUNT = -0.16;
|
|
727
|
+
const float MAX_AMOUNT = 1.5;
|
|
728
|
+
float amount = progress * (MAX_AMOUNT - MIN_AMOUNT) + MIN_AMOUNT;
|
|
729
|
+
|
|
730
|
+
const float PI = 3.141592653589793;
|
|
731
|
+
|
|
732
|
+
const float scale = 512.0;
|
|
733
|
+
const float sharpness = 3.0;
|
|
734
|
+
|
|
735
|
+
float cylinderCenter = amount;
|
|
736
|
+
// 360 degrees * amount
|
|
737
|
+
float cylinderAngle = 2.0 * PI * amount;
|
|
738
|
+
|
|
739
|
+
const float cylinderRadius = 1.0 / PI / 2.0;
|
|
740
|
+
|
|
741
|
+
vec3 hitPoint(float hitAngle, float yc, vec3 point, mat3 rrotation)
|
|
742
|
+
{
|
|
743
|
+
float hitPoint = hitAngle / (2.0 * PI);
|
|
744
|
+
point.y = hitPoint;
|
|
745
|
+
return rrotation * point;
|
|
746
|
+
}
|
|
747
|
+
|
|
748
|
+
vec4 antiAlias(vec4 color1, vec4 color2, float distanc)
|
|
749
|
+
{
|
|
750
|
+
distanc *= scale;
|
|
751
|
+
if (distanc < 0.0) return color2;
|
|
752
|
+
if (distanc > 2.0) return color1;
|
|
753
|
+
float dd = pow(1.0 - distanc / 2.0, sharpness);
|
|
754
|
+
return ((color2 - color1) * dd) + color1;
|
|
755
|
+
}
|
|
756
|
+
|
|
757
|
+
float distanceToEdge(vec3 point)
|
|
758
|
+
{
|
|
759
|
+
float dx = abs(point.x > 0.5 ? 1.0 - point.x : point.x);
|
|
760
|
+
float dy = abs(point.y > 0.5 ? 1.0 - point.y : point.y);
|
|
761
|
+
if (point.x < 0.0) dx = -point.x;
|
|
762
|
+
if (point.x > 1.0) dx = point.x - 1.0;
|
|
763
|
+
if (point.y < 0.0) dy = -point.y;
|
|
764
|
+
if (point.y > 1.0) dy = point.y - 1.0;
|
|
765
|
+
if ((point.x < 0.0 || point.x > 1.0) && (point.y < 0.0 || point.y > 1.0)) return sqrt(dx * dx + dy * dy);
|
|
766
|
+
return min(dx, dy);
|
|
767
|
+
}
|
|
768
|
+
|
|
769
|
+
vec4 seeThrough(float yc, vec2 p, mat3 rotation, mat3 rrotation)
|
|
770
|
+
{
|
|
771
|
+
float hitAngle = PI - (acos(yc / cylinderRadius) - cylinderAngle);
|
|
772
|
+
vec3 point = hitPoint(hitAngle, yc, rotation * vec3(p, 1.0), rrotation);
|
|
773
|
+
if (yc <= 0.0 && (point.x < 0.0 || point.y < 0.0 || point.x > 1.0 || point.y > 1.0))
|
|
774
|
+
{
|
|
775
|
+
return getToColor(p);
|
|
22
776
|
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
777
|
+
|
|
778
|
+
if (yc > 0.0) return getFromColor(p);
|
|
779
|
+
|
|
780
|
+
vec4 color = getFromColor(point.xy);
|
|
781
|
+
vec4 tcolor = vec4(0.0);
|
|
782
|
+
|
|
783
|
+
return antiAlias(color, tcolor, distanceToEdge(point));
|
|
784
|
+
}
|
|
785
|
+
|
|
786
|
+
vec4 seeThroughWithShadow(float yc, vec2 p, vec3 point, mat3 rotation, mat3 rrotation)
|
|
787
|
+
{
|
|
788
|
+
float shadow = distanceToEdge(point) * 30.0;
|
|
789
|
+
shadow = (1.0 - shadow) / 3.0;
|
|
790
|
+
|
|
791
|
+
if (shadow < 0.0) shadow = 0.0; else shadow *= amount;
|
|
792
|
+
|
|
793
|
+
vec4 shadowColor = seeThrough(yc, p, rotation, rrotation);
|
|
794
|
+
shadowColor.r -= shadow;
|
|
795
|
+
shadowColor.g -= shadow;
|
|
796
|
+
shadowColor.b -= shadow;
|
|
797
|
+
|
|
798
|
+
return shadowColor;
|
|
799
|
+
}
|
|
800
|
+
|
|
801
|
+
vec4 backside(float yc, vec3 point)
|
|
802
|
+
{
|
|
803
|
+
vec4 color = getFromColor(point.xy);
|
|
804
|
+
float gray = (color.r + color.b + color.g) / 15.0;
|
|
805
|
+
gray += (8.0 / 10.0) * (pow(1.0 - abs(yc / cylinderRadius), 2.0 / 10.0) / 2.0 + (5.0 / 10.0));
|
|
806
|
+
color.rgb = vec3(gray);
|
|
807
|
+
return color;
|
|
808
|
+
}
|
|
809
|
+
|
|
810
|
+
vec4 behindSurface(vec2 p, float yc, vec3 point, mat3 rrotation)
|
|
811
|
+
{
|
|
812
|
+
float shado = (1.0 - ((-cylinderRadius - yc) / amount * 7.0)) / 6.0;
|
|
813
|
+
shado *= 1.0 - abs(point.x - 0.5);
|
|
814
|
+
|
|
815
|
+
yc = (-cylinderRadius - cylinderRadius - yc);
|
|
816
|
+
|
|
817
|
+
float hitAngle = (acos(yc / cylinderRadius) + cylinderAngle) - PI;
|
|
818
|
+
point = hitPoint(hitAngle, yc, point, rrotation);
|
|
819
|
+
|
|
820
|
+
if (yc < 0.0 && point.x >= 0.0 && point.y >= 0.0 && point.x <= 1.0 && point.y <= 1.0 && (hitAngle < PI || amount > 0.5))
|
|
821
|
+
{
|
|
822
|
+
shado = 1.0 - (sqrt(pow(point.x - 0.5, 2.0) + pow(point.y - 0.5, 2.0)) / (71.0 / 100.0));
|
|
823
|
+
shado *= pow(-yc / cylinderRadius, 3.0);
|
|
824
|
+
shado *= 0.5;
|
|
26
825
|
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
826
|
+
else
|
|
827
|
+
{
|
|
828
|
+
shado = 0.0;
|
|
30
829
|
}
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
830
|
+
return vec4(getToColor(p).rgb - shado, 1.0);
|
|
831
|
+
}
|
|
832
|
+
|
|
833
|
+
vec4 transition(vec2 p) {
|
|
834
|
+
|
|
835
|
+
const float angle = 100.0 * PI / 180.0;
|
|
836
|
+
float c = cos(-angle);
|
|
837
|
+
float s = sin(-angle);
|
|
838
|
+
|
|
839
|
+
mat3 rotation = mat3( c, s, 0,
|
|
840
|
+
-s, c, 0,
|
|
841
|
+
-0.801, 0.8900, 1
|
|
842
|
+
);
|
|
843
|
+
c = cos(angle);
|
|
844
|
+
s = sin(angle);
|
|
845
|
+
|
|
846
|
+
mat3 rrotation = mat3( c, s, 0,
|
|
847
|
+
-s, c, 0,
|
|
848
|
+
0.98500, 0.985, 1
|
|
849
|
+
);
|
|
850
|
+
|
|
851
|
+
vec3 point = rotation * vec3(p, 1.0);
|
|
852
|
+
|
|
853
|
+
float yc = point.y - cylinderCenter;
|
|
854
|
+
|
|
855
|
+
if (yc < -cylinderRadius)
|
|
856
|
+
{
|
|
857
|
+
// Behind surface
|
|
858
|
+
return behindSurface(p,yc, point, rrotation);
|
|
35
859
|
}
|
|
36
|
-
|
|
37
|
-
|
|
860
|
+
|
|
861
|
+
if (yc > cylinderRadius)
|
|
862
|
+
{
|
|
863
|
+
// Flat surface
|
|
864
|
+
return getFromColor(p);
|
|
38
865
|
}
|
|
39
|
-
|
|
40
|
-
|
|
866
|
+
|
|
867
|
+
float hitAngle = (acos(yc / cylinderRadius) + cylinderAngle) - PI;
|
|
868
|
+
|
|
869
|
+
float hitAngleMod = mod(hitAngle, 2.0 * PI);
|
|
870
|
+
if ((hitAngleMod > PI && amount < 0.5) || (hitAngleMod > PI/2.0 && amount < 0.0))
|
|
871
|
+
{
|
|
872
|
+
return seeThrough(yc, p, rotation, rrotation);
|
|
41
873
|
}
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
874
|
+
|
|
875
|
+
point = hitPoint(hitAngle, yc, point, rrotation);
|
|
876
|
+
|
|
877
|
+
if (point.x < 0.0 || point.y < 0.0 || point.x > 1.0 || point.y > 1.0)
|
|
878
|
+
{
|
|
879
|
+
return seeThroughWithShadow(yc, p, point, rotation, rrotation);
|
|
47
880
|
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
881
|
+
|
|
882
|
+
vec4 color = backside(yc, point);
|
|
883
|
+
|
|
884
|
+
vec4 otherColor;
|
|
885
|
+
if (yc < 0.0)
|
|
886
|
+
{
|
|
887
|
+
float shado = 1.0 - (sqrt(pow(point.x - 0.5, 2.0) + pow(point.y - 0.5, 2.0)) / 0.71);
|
|
888
|
+
shado *= pow(-yc / cylinderRadius, 3.0);
|
|
889
|
+
shado *= 0.5;
|
|
890
|
+
otherColor = vec4(0.0, 0.0, 0.0, shado);
|
|
57
891
|
}
|
|
58
|
-
|
|
59
|
-
|
|
892
|
+
else
|
|
893
|
+
{
|
|
894
|
+
otherColor = getFromColor(p);
|
|
60
895
|
}
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
896
|
+
|
|
897
|
+
color = antiAlias(color, otherColor, cylinderRadius - abs(yc));
|
|
898
|
+
|
|
899
|
+
vec4 cl = seeThroughWithShadow(yc, p, point, rotation, rrotation);
|
|
900
|
+
float dist = distanceToEdge(point);
|
|
901
|
+
|
|
902
|
+
return antiAlias(color, cl, dist);
|
|
903
|
+
}
|
|
904
|
+
`,author:"Hewlett-Packard",license:"BSD 3 Clause",createdAt:"Wed, 21 Feb 2018 01:13:49 +0100",updatedAt:"Wed, 21 Feb 2018 16:00:02 +0100"},{name:"LinearBlur",paramsTypes:{intensity:"float"},defaultParams:{intensity:.1},glsl:`// author: gre
|
|
905
|
+
// license: MIT
|
|
906
|
+
uniform float intensity; // = 0.1
|
|
907
|
+
const int passes = 6;
|
|
908
|
+
|
|
909
|
+
vec4 transition(vec2 uv) {
|
|
910
|
+
vec4 c1 = vec4(0.0);
|
|
911
|
+
vec4 c2 = vec4(0.0);
|
|
912
|
+
|
|
913
|
+
float disp = intensity*(0.5-distance(0.5, progress));
|
|
914
|
+
for (int xi=0; xi<passes; xi++)
|
|
915
|
+
{
|
|
916
|
+
float x = float(xi) / float(passes) - 0.5;
|
|
917
|
+
for (int yi=0; yi<passes; yi++)
|
|
918
|
+
{
|
|
919
|
+
float y = float(yi) / float(passes) - 0.5;
|
|
920
|
+
vec2 v = vec2(x,y);
|
|
921
|
+
float d = disp;
|
|
922
|
+
c1 += getFromColor( uv + d*v);
|
|
923
|
+
c2 += getToColor( uv + d*v);
|
|
69
924
|
}
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
`,[e,t]}setOptions(e){if(this.options.container!==e.container){let t=this.parentFromOptionsContainer(e.container);t.appendChild(this.container),this.parent=t}e.dragToSeek!==!0&&typeof this.options.dragToSeek!="object"||this.initDrag(),this.options=e,this.reRender()}getWrapper(){return this.wrapper}getWidth(){return this.scrollContainer.clientWidth}getScroll(){return this.scrollContainer.scrollLeft}setScroll(e){this.scrollContainer.scrollLeft=e}setScrollPercentage(e){let{scrollWidth:t}=this.scrollContainer,n=t*e;this.setScroll(n)}destroy(){var e,t;this.subscriptions.forEach(n=>n()),this.container.remove(),(e=this.resizeObserver)===null||e===void 0||e.disconnect(),(t=this.unsubscribeOnScroll)===null||t===void 0||t.forEach(n=>n()),this.unsubscribeOnScroll=[]}createDelay(e=10){let t,n,s=()=>{t&&clearTimeout(t),n&&n()};return this.timeouts.push(s),()=>new Promise((a,i)=>{s(),n=i,t=setTimeout(()=>{t=void 0,n=void 0,a()},e)})}convertColorValues(e){if(!Array.isArray(e))return e||"";if(e.length<2)return e[0]||"";let t=document.createElement("canvas"),n=t.getContext("2d"),s=t.height*(window.devicePixelRatio||1),a=n.createLinearGradient(0,0,0,s),i=1/(e.length-1);return e.forEach((o,c)=>{let l=c*i;a.addColorStop(l,o)}),a}getPixelRatio(){return Math.max(1,window.devicePixelRatio||1)}renderBarWaveform(e,t,n,s){let a=e[0],i=e[1]||e[0],o=a.length,{width:c,height:l}=n.canvas,u=l/2,d=this.getPixelRatio(),f=t.barWidth?t.barWidth*d:1,m=t.barGap?t.barGap*d:t.barWidth?f/2:0,h=t.barRadius||0,g=c/(f+m)/o,y=h&&"roundRect"in n?"roundRect":"rect";n.beginPath();let S=0,p=0,w=0;for(let k=0;k<=o;k++){let x=Math.round(k*g);if(x>S){let F=Math.round(p*u*s),A=F+Math.round(w*u*s)||1,_=u-F;t.barAlign==="top"?_=0:t.barAlign==="bottom"&&(_=l-A),n[y](S*(f+m),_,f,A,h),S=x,p=0,w=0}let C=Math.abs(a[k]||0),v=Math.abs(i[k]||0);C>p&&(p=C),v>w&&(w=v)}n.fill(),n.closePath()}renderLineWaveform(e,t,n,s){let a=i=>{let o=e[i]||e[0],c=o.length,{height:l}=n.canvas,u=l/2,d=n.canvas.width/c;n.moveTo(0,u);let f=0,m=0;for(let h=0;h<=c;h++){let g=Math.round(h*d);if(g>f){let S=u+(Math.round(m*u*s)||1)*(i===0?-1:1);n.lineTo(f,S),f=g,m=0}let y=Math.abs(o[h]||0);y>m&&(m=y)}n.lineTo(f,u)};n.beginPath(),a(0),a(1),n.fill(),n.closePath()}renderWaveform(e,t,n){if(n.fillStyle=this.convertColorValues(t.waveColor),t.renderFunction)return void t.renderFunction(e,n);let s=t.barHeight||1;if(t.normalize){let a=Array.from(e[0]).reduce((i,o)=>Math.max(i,Math.abs(o)),0);s=a?1/a:1}t.barWidth||t.barGap||t.barAlign?this.renderBarWaveform(e,t,n,s):this.renderLineWaveform(e,t,n,s)}renderSingleCanvas(e,t,n,s,a,i,o){let c=this.getPixelRatio(),l=document.createElement("canvas");l.width=Math.round(n*c),l.height=Math.round(s*c),l.style.width=`${n}px`,l.style.height=`${s}px`,l.style.left=`${Math.round(a)}px`,i.appendChild(l);let u=l.getContext("2d");if(this.renderWaveform(e,t,u),l.width>0&&l.height>0){let d=l.cloneNode(),f=d.getContext("2d");f.drawImage(l,0,0),f.globalCompositeOperation="source-in",f.fillStyle=this.convertColorValues(t.progressColor),f.fillRect(0,0,l.width,l.height),o.appendChild(d)}}renderMultiCanvas(e,t,n,s,a,i){let o=this.getPixelRatio(),{clientWidth:c}=this.scrollContainer,l=n/o,u=Math.min(r.MAX_CANVAS_WIDTH,c,l),d={};if(t.barWidth||t.barGap){let y=t.barWidth||.5,S=y+(t.barGap||y/2);u%S!=0&&(u=Math.floor(u/S)*S)}if(u===0)return;let f=y=>{if(y<0||y>=m||d[y])return;d[y]=!0;let S=y*u,p=Math.min(l-S,u);if(t.barWidth||t.barGap){let k=t.barWidth||.5,x=k+(t.barGap||k/2);p=Math.floor(p/x)*x}if(p<=0)return;let w=e.map(k=>{let x=Math.floor(S/l*k.length),C=Math.floor((S+p)/l*k.length);return k.slice(x,C)});this.renderSingleCanvas(w,t,p,s,S,a,i)},m=Math.ceil(l/u);if(!this.isScrollable){for(let y=0;y<m;y++)f(y);return}let h=this.scrollContainer.scrollLeft/l,g=Math.floor(h*m);if(f(g-1),f(g),f(g+1),m>1){let y=this.on("scroll",()=>{let{scrollLeft:S}=this.scrollContainer,p=Math.floor(S/l*m);Object.keys(d).length>r.MAX_NODES&&(a.innerHTML="",i.innerHTML="",d={}),f(p-1),f(p),f(p+1)});this.unsubscribeOnScroll.push(y)}}renderChannel(e,t,n,s){var{overlay:a}=t,i=function(u,d){var f={};for(var m in u)Object.prototype.hasOwnProperty.call(u,m)&&d.indexOf(m)<0&&(f[m]=u[m]);if(u!=null&&typeof Object.getOwnPropertySymbols=="function"){var h=0;for(m=Object.getOwnPropertySymbols(u);h<m.length;h++)d.indexOf(m[h])<0&&Object.prototype.propertyIsEnumerable.call(u,m[h])&&(f[m[h]]=u[m[h]])}return f}(t,["overlay"]);let o=document.createElement("div"),c=this.getHeight(i.height,i.splitChannels);o.style.height=`${c}px`,a&&s>0&&(o.style.marginTop=`-${c}px`),this.canvasWrapper.style.minHeight=`${c}px`,this.canvasWrapper.appendChild(o);let l=o.cloneNode();this.progressWrapper.appendChild(l),this.renderMultiCanvas(e,i,n,c,o,l)}render(e){return H(this,void 0,void 0,function*(){var t;this.timeouts.forEach(c=>c()),this.timeouts=[],this.canvasWrapper.innerHTML="",this.progressWrapper.innerHTML="",this.options.width!=null&&(this.scrollContainer.style.width=typeof this.options.width=="number"?`${this.options.width}px`:this.options.width);let n=this.getPixelRatio(),s=this.scrollContainer.clientWidth,a=Math.ceil(e.duration*(this.options.minPxPerSec||0));this.isScrollable=a>s;let i=this.options.fillParent&&!this.isScrollable,o=(i?s:a)*n;if(this.wrapper.style.width=i?"100%":`${a}px`,this.scrollContainer.style.overflowX=this.isScrollable?"auto":"hidden",this.scrollContainer.classList.toggle("noScrollbar",!!this.options.hideScrollbar),this.cursor.style.backgroundColor=`${this.options.cursorColor||this.options.progressColor}`,this.cursor.style.width=`${this.options.cursorWidth}px`,this.audioData=e,this.emit("render"),this.options.splitChannels)for(let c=0;c<e.numberOfChannels;c++){let l=Object.assign(Object.assign({},this.options),(t=this.options.splitChannels)===null||t===void 0?void 0:t[c]);this.renderChannel([e.getChannelData(c)],l,o,c)}else{let c=[e.getChannelData(0)];e.numberOfChannels>1&&c.push(e.getChannelData(1)),this.renderChannel(c,this.options,o,0)}Promise.resolve().then(()=>this.emit("rendered"))})}reRender(){if(this.unsubscribeOnScroll.forEach(n=>n()),this.unsubscribeOnScroll=[],!this.audioData)return;let{scrollWidth:e}=this.scrollContainer,{right:t}=this.progressWrapper.getBoundingClientRect();if(this.render(this.audioData),this.isScrollable&&e!==this.scrollContainer.scrollWidth){let{right:n}=this.progressWrapper.getBoundingClientRect(),s=n-t;s*=2,s=s<0?Math.floor(s):Math.ceil(s),s/=2,this.scrollContainer.scrollLeft+=s}}zoom(e){this.options.minPxPerSec=e,this.reRender()}scrollIntoView(e,t=!1){let{scrollLeft:n,scrollWidth:s,clientWidth:a}=this.scrollContainer,i=e*s,o=n,c=n+a,l=a/2;if(this.isDragging)i+30>c?this.scrollContainer.scrollLeft+=30:i-30<o&&(this.scrollContainer.scrollLeft-=30);else{(i<o||i>c)&&(this.scrollContainer.scrollLeft=i-(this.options.autoCenter?l:0));let u=i-n-l;t&&this.options.autoCenter&&u>0&&(this.scrollContainer.scrollLeft+=Math.min(u,10))}{let u=this.scrollContainer.scrollLeft,d=u/s,f=(u+a)/s;this.emit("scroll",d,f,u,u+a)}}renderProgress(e,t){if(isNaN(e))return;let n=100*e;this.canvasWrapper.style.clipPath=`polygon(${n}% 0%, 100% 0%, 100% 100%, ${n}% 100%)`,this.progressWrapper.style.width=`${n}%`,this.cursor.style.left=`${n}%`,this.cursor.style.transform=`translateX(-${Math.round(n)===100?this.options.cursorWidth:0}px)`,this.isScrollable&&this.options.autoScroll&&this.scrollIntoView(e,t)}exportImage(e,t,n){return H(this,void 0,void 0,function*(){let s=this.canvasWrapper.querySelectorAll("canvas");if(!s.length)throw new Error("No waveform data");if(n==="dataURL"){let a=Array.from(s).map(i=>i.toDataURL(e,t));return Promise.resolve(a)}return Promise.all(Array.from(s).map(a=>new Promise((i,o)=>{a.toBlob(c=>{c?i(c):o(new Error("Could not export image"))},e,t)})))})}};jt.MAX_CANVAS_WIDTH=8e3,jt.MAX_NODES=10;var as=class extends Ge{constructor(){super(...arguments),this.unsubscribe=()=>{}}start(){this.unsubscribe=this.on("tick",()=>{requestAnimationFrame(()=>{this.emit("tick")})}),this.emit("tick")}stop(){this.unsubscribe()}destroy(){this.unsubscribe()}},qt=class extends Ge{constructor(e=new AudioContext){super(),this.bufferNode=null,this.playStartTime=0,this.playedDuration=0,this._muted=!1,this._playbackRate=1,this._duration=void 0,this.buffer=null,this.currentSrc="",this.paused=!0,this.crossOrigin=null,this.seeking=!1,this.autoplay=!1,this.addEventListener=this.on,this.removeEventListener=this.un,this.audioContext=e,this.gainNode=this.audioContext.createGain(),this.gainNode.connect(this.audioContext.destination)}load(){return H(this,void 0,void 0,function*(){})}get src(){return this.currentSrc}set src(e){if(this.currentSrc=e,this._duration=void 0,!e)return this.buffer=null,void this.emit("emptied");fetch(e).then(t=>{if(t.status>=400)throw new Error(`Failed to fetch ${e}: ${t.status} (${t.statusText})`);return t.arrayBuffer()}).then(t=>this.currentSrc!==e?null:this.audioContext.decodeAudioData(t)).then(t=>{this.currentSrc===e&&(this.buffer=t,this.emit("loadedmetadata"),this.emit("canplay"),this.autoplay&&this.play())})}_play(){var e;if(!this.paused)return;this.paused=!1,(e=this.bufferNode)===null||e===void 0||e.disconnect(),this.bufferNode=this.audioContext.createBufferSource(),this.buffer&&(this.bufferNode.buffer=this.buffer),this.bufferNode.playbackRate.value=this._playbackRate,this.bufferNode.connect(this.gainNode);let t=this.playedDuration*this._playbackRate;(t>=this.duration||t<0)&&(t=0,this.playedDuration=0),this.bufferNode.start(this.audioContext.currentTime,t),this.playStartTime=this.audioContext.currentTime,this.bufferNode.onended=()=>{this.currentTime>=this.duration&&(this.pause(),this.emit("ended"))}}_pause(){var e;this.paused=!0,(e=this.bufferNode)===null||e===void 0||e.stop(),this.playedDuration+=this.audioContext.currentTime-this.playStartTime}play(){return H(this,void 0,void 0,function*(){this.paused&&(this._play(),this.emit("play"))})}pause(){this.paused||(this._pause(),this.emit("pause"))}stopAt(e){let t=e-this.currentTime,n=this.bufferNode;n?.stop(this.audioContext.currentTime+t),n?.addEventListener("ended",()=>{n===this.bufferNode&&(this.bufferNode=null,this.pause())},{once:!0})}setSinkId(e){return H(this,void 0,void 0,function*(){return this.audioContext.setSinkId(e)})}get playbackRate(){return this._playbackRate}set playbackRate(e){this._playbackRate=e,this.bufferNode&&(this.bufferNode.playbackRate.value=e)}get currentTime(){return(this.paused?this.playedDuration:this.playedDuration+(this.audioContext.currentTime-this.playStartTime))*this._playbackRate}set currentTime(e){let t=!this.paused;t&&this._pause(),this.playedDuration=e/this._playbackRate,t&&this._play(),this.emit("seeking"),this.emit("timeupdate")}get duration(){var e,t;return(e=this._duration)!==null&&e!==void 0?e:((t=this.buffer)===null||t===void 0?void 0:t.duration)||0}set duration(e){this._duration=e}get volume(){return this.gainNode.gain.value}set volume(e){this.gainNode.gain.value=e,this.emit("volumechange")}get muted(){return this._muted}set muted(e){this._muted!==e&&(this._muted=e,this._muted?this.gainNode.disconnect():this.gainNode.connect(this.audioContext.destination))}canPlayType(e){return/^(audio|video)\//.test(e)}getGainNode(){return this.gainNode}getChannelData(){let e=[];if(!this.buffer)return e;let t=this.buffer.numberOfChannels;for(let n=0;n<t;n++)e.push(this.buffer.getChannelData(n));return e}},Oa={waveColor:"#999",progressColor:"#555",cursorWidth:1,minPxPerSec:0,fillParent:!0,interact:!0,dragToSeek:!1,autoScroll:!0,autoCenter:!0,sampleRate:8e3},wt=class r extends is{static create(e){return new r(e)}constructor(e){let t=e.media||(e.backend==="WebAudio"?new qt:void 0);super({media:t,mediaControls:e.mediaControls,autoplay:e.autoplay,playbackRate:e.audioRate}),this.plugins=[],this.decodedData=null,this.stopAtPosition=null,this.subscriptions=[],this.mediaSubscriptions=[],this.abortController=null,this.options=Object.assign({},Oa,e),this.timer=new as;let n=t?void 0:this.getMediaElement();this.renderer=new jt(this.options,n),this.initPlayerEvents(),this.initRendererEvents(),this.initTimerEvents(),this.initPlugins();let s=this.options.url||this.getSrc()||"";Promise.resolve().then(()=>{this.emit("init");let{peaks:a,duration:i}=this.options;(s||a&&i)&&this.load(s,a,i).catch(()=>null)})}updateProgress(e=this.getCurrentTime()){return this.renderer.renderProgress(e/this.getDuration(),this.isPlaying()),e}initTimerEvents(){this.subscriptions.push(this.timer.on("tick",()=>{if(!this.isSeeking()){let e=this.updateProgress();this.emit("timeupdate",e),this.emit("audioprocess",e),this.stopAtPosition!=null&&this.isPlaying()&&e>=this.stopAtPosition&&this.pause()}}))}initPlayerEvents(){this.isPlaying()&&(this.emit("play"),this.timer.start()),this.mediaSubscriptions.push(this.onMediaEvent("timeupdate",()=>{let e=this.updateProgress();this.emit("timeupdate",e)}),this.onMediaEvent("play",()=>{this.emit("play"),this.timer.start()}),this.onMediaEvent("pause",()=>{this.emit("pause"),this.timer.stop(),this.stopAtPosition=null}),this.onMediaEvent("emptied",()=>{this.timer.stop(),this.stopAtPosition=null}),this.onMediaEvent("ended",()=>{this.emit("timeupdate",this.getDuration()),this.emit("finish"),this.stopAtPosition=null}),this.onMediaEvent("seeking",()=>{this.emit("seeking",this.getCurrentTime())}),this.onMediaEvent("error",()=>{var e;this.emit("error",(e=this.getMediaElement().error)!==null&&e!==void 0?e:new Error("Media error")),this.stopAtPosition=null}))}initRendererEvents(){this.subscriptions.push(this.renderer.on("click",(e,t)=>{this.options.interact&&(this.seekTo(e),this.emit("interaction",e*this.getDuration()),this.emit("click",e,t))}),this.renderer.on("dblclick",(e,t)=>{this.emit("dblclick",e,t)}),this.renderer.on("scroll",(e,t,n,s)=>{let a=this.getDuration();this.emit("scroll",e*a,t*a,n,s)}),this.renderer.on("render",()=>{this.emit("redraw")}),this.renderer.on("rendered",()=>{this.emit("redrawcomplete")}),this.renderer.on("dragstart",e=>{this.emit("dragstart",e)}),this.renderer.on("dragend",e=>{this.emit("dragend",e)}));{let e;this.subscriptions.push(this.renderer.on("drag",t=>{if(!this.options.interact)return;let n;this.renderer.renderProgress(t),clearTimeout(e),this.isPlaying()?n=0:this.options.dragToSeek===!0?n=200:typeof this.options.dragToSeek=="object"&&this.options.dragToSeek!==void 0&&(n=this.options.dragToSeek.debounceTime),e=setTimeout(()=>{this.seekTo(t)},n),this.emit("interaction",t*this.getDuration()),this.emit("drag",t)}))}}initPlugins(){var e;!((e=this.options.plugins)===null||e===void 0)&&e.length&&this.options.plugins.forEach(t=>{this.registerPlugin(t)})}unsubscribePlayerEvents(){this.mediaSubscriptions.forEach(e=>e()),this.mediaSubscriptions=[]}setOptions(e){this.options=Object.assign({},this.options,e),e.duration&&!e.peaks&&(this.decodedData=on.createBuffer(this.exportPeaks(),e.duration)),e.peaks&&e.duration&&(this.decodedData=on.createBuffer(e.peaks,e.duration)),this.renderer.setOptions(this.options),e.audioRate&&this.setPlaybackRate(e.audioRate),e.mediaControls!=null&&(this.getMediaElement().controls=e.mediaControls)}registerPlugin(e){if(this.plugins.includes(e))return e;e._init(this),this.plugins.push(e);let t=e.once("destroy",()=>{this.plugins=this.plugins.filter(n=>n!==e),this.subscriptions=this.subscriptions.filter(n=>n!==t)});return this.subscriptions.push(t),e}unregisterPlugin(e){this.plugins=this.plugins.filter(t=>t!==e),e.destroy()}getWrapper(){return this.renderer.getWrapper()}getWidth(){return this.renderer.getWidth()}getScroll(){return this.renderer.getScroll()}setScroll(e){return this.renderer.setScroll(e)}setScrollTime(e){let t=e/this.getDuration();this.renderer.setScrollPercentage(t)}getActivePlugins(){return this.plugins}loadAudio(e,t,n,s){return H(this,void 0,void 0,function*(){var a;if(this.emit("load",e),!this.options.media&&this.isPlaying()&&this.pause(),this.decodedData=null,this.stopAtPosition=null,!t&&!n){let o=this.options.fetchParams||{};window.AbortController&&!o.signal&&(this.abortController=new AbortController,o.signal=(a=this.abortController)===null||a===void 0?void 0:a.signal);let c=u=>this.emit("loading",u);t=yield Ra.fetchBlob(e,c,o);let l=this.options.blobMimeType;l&&(t=new Blob([t],{type:l}))}this.setSrc(e,t);let i=yield new Promise(o=>{let c=s||this.getDuration();c?o(c):this.mediaSubscriptions.push(this.onMediaEvent("loadedmetadata",()=>o(this.getDuration()),{once:!0}))});if(!e&&!t){let o=this.getMediaElement();o instanceof qt&&(o.duration=i)}if(n)this.decodedData=on.createBuffer(n,i||0);else if(t){let o=yield t.arrayBuffer();this.decodedData=yield on.decode(o,this.options.sampleRate)}this.decodedData&&(this.emit("decode",this.getDuration()),this.renderer.render(this.decodedData)),this.emit("ready",this.getDuration())})}load(e,t,n){return H(this,void 0,void 0,function*(){try{return yield this.loadAudio(e,void 0,t,n)}catch(s){throw this.emit("error",s),s}})}loadBlob(e,t,n){return H(this,void 0,void 0,function*(){try{return yield this.loadAudio("",e,t,n)}catch(s){throw this.emit("error",s),s}})}zoom(e){if(!this.decodedData)throw new Error("No audio loaded");this.renderer.zoom(e),this.emit("zoom",e)}getDecodedData(){return this.decodedData}exportPeaks({channels:e=2,maxLength:t=8e3,precision:n=1e4}={}){if(!this.decodedData)throw new Error("The audio has not been decoded yet");let s=Math.min(e,this.decodedData.numberOfChannels),a=[];for(let i=0;i<s;i++){let o=this.decodedData.getChannelData(i),c=[],l=o.length/t;for(let u=0;u<t;u++){let d=o.slice(Math.floor(u*l),Math.ceil((u+1)*l)),f=0;for(let m=0;m<d.length;m++){let h=d[m];Math.abs(h)>Math.abs(f)&&(f=h)}c.push(Math.round(f*n)/n)}a.push(c)}return a}getDuration(){let e=super.getDuration()||0;return e!==0&&e!==1/0||!this.decodedData||(e=this.decodedData.duration),e}toggleInteraction(e){this.options.interact=e}setTime(e){this.stopAtPosition=null,super.setTime(e),this.updateProgress(e),this.emit("timeupdate",e)}seekTo(e){let t=this.getDuration()*e;this.setTime(t)}play(e,t){let n=Object.create(null,{play:{get:()=>super.play}});return H(this,void 0,void 0,function*(){e!=null&&this.setTime(e);let s=yield n.play.call(this);return t!=null&&(this.media instanceof qt?this.media.stopAt(t):this.stopAtPosition=t),s})}playPause(){return H(this,void 0,void 0,function*(){return this.isPlaying()?this.pause():this.play()})}stop(){this.pause(),this.setTime(0)}skip(e){this.setTime(this.getCurrentTime()+e)}empty(){this.load("",[[0]],.001)}setMediaElement(e){this.unsubscribePlayerEvents(),super.setMediaElement(e),this.initPlayerEvents()}exportImage(){return H(this,arguments,void 0,function*(e="image/png",t=1,n="dataURL"){return this.renderer.exportImage(e,t,n)})}destroy(){var e;this.emit("destroy"),(e=this.abortController)===null||e===void 0||e.abort(),this.plugins.forEach(t=>t.destroy()),this.subscriptions.forEach(t=>t()),this.unsubscribePlayerEvents(),this.timer.destroy(),this.renderer.destroy(),super.destroy()}};wt.BasePlugin=class extends Ge{constructor(r){super(),this.subscriptions=[],this.isDestroyed=!1,this.options=r}onInit(){}_init(r){this.isDestroyed&&(this.subscriptions=[],this.isDestroyed=!1),this.wavesurfer=r,this.onInit()}destroy(){this.emit("destroy"),this.subscriptions.forEach(r=>r()),this.subscriptions=[],this.isDestroyed=!0,this.wavesurfer=void 0}},wt.dom=Ba;var cn=class r{wavesurfer;constructor(e,t,n){this.wavesurfer=wt.create({container:t,waveColor:"rgb(200, 0, 200)",progressColor:"rgb(100, 0, 100)",barWidth:10,barRadius:10,barGap:2,peaks:[e],duration:n})}static async init(e,t){let n=await an.driver,s=n.decodeAudio({source:e}).getReader(),a=[],i=[],o=1024,c=await n.getAudioDuration(e);for(;;){let{done:l,value:u}=await s.read();if(l)break;let d=u.numberOfFrames,f=new Float32Array(d);u.copyTo(f,{planeIndex:0});for(let m=0;m<f.length;m++)if(i.push(f[m]),i.length>=o){let h=i.splice(0,o),g=Math.min(...h),y=Math.max(...h);a.push(g,y)}u.close()}return new r(a,t,c??0)}set width(e){this.wavesurfer.setOptions({width:e})}};async function Ni(){let r=document.querySelector(".waveform-demo"),e=document.querySelector(".width"),t=await cn.init("/assets/temp/gl.mp4",r);e.addEventListener("change",()=>{let n=+e.value;t.width=n})}var ln=class r{videoTrack;options;#e;#t=new Map;#r=[0,0];constructor(e,t){this.videoTrack=e,this.options=t,this.#e=new Mt(e,t.canvasSinkOptions)}static async init(e,t){let s=await new Ae({formats:xt,source:await Wt(e)}).getPrimaryVideoTrack();if(s)return new r(s,{frequency:t.frequency??1,canvasSinkOptions:t.canvasSinkOptions??{width:80,height:50,fit:"fill"},onChange:t.onChange});throw new Error("Source has no video track")}set frequency(e){e!==this.options.frequency&&(this.options.frequency=e,this.#a())}get frequency(){return this.options.frequency}#n([e,t]){let n=t-e;return[e-n,t+n]}async#o(){let[e,t]=this.#r,n=new Set,s=await this.videoTrack.computeDuration();for(let c=e;c<=t;c+=this.options.frequency)c>=0&&c<=s&&n.add(+c.toFixed(3));let a=[...n].filter(c=>!this.#t.has(c)),i=0;for await(let c of this.#e.canvasesAtTimestamps(a))if(c){let l=a[i++];this.#t.set(l,c)}for(let c of this.#t.keys())n.has(c)||this.#t.delete(c);let o=[...this.#t.entries()].map(([c,l])=>({time:c,canvas:l}));this.options.onChange(o)}set range(e){let t=this.#n(e);this.#r[0]===t[0]&&this.#r[1]===t[1]||(this.#r=t,this.#a())}#s=null;#i=!1;async#a(){if(this.#s){this.#i=!0;return}this.#s=this.#o(),await this.#s,this.#s=null,this.#i&&(this.#i=!1,await this.#a())}getThumbnail(e){return this.#t.get(e)}};async function Vi(r){let e=document.querySelector(".range"),t=document.querySelector(".range-view"),n=document.querySelector(".range-size"),s=document.querySelector(".frequency"),a=document.querySelector(".frequency-view"),i=document.querySelector("#filmstrip"),o=1e3/10/1e3,c=.5,l=await ln.init(r,{onChange(u){let d=u.sort((f,m)=>f.time-m.time);i.replaceChildren(...d.map(({time:f,canvas:m})=>za(f,m.canvas)))},frequency:o,canvasSinkOptions:{width:80,height:50,fit:"fill"}});n.addEventListener("change",()=>{c=+n.value;let[u,d]=[+e.value,+e.value+c];l.range=[u,d],t.textContent=`visible time range: [${u}, ${d}]`}),e.addEventListener("change",()=>{let[u,d]=[+e.value,+e.value+c];l.range=[u,d],t.textContent=`visible time range: [${u}, ${d}]`}),s.addEventListener("change",()=>{l.frequency=1e3/+s.value/1e3,a.textContent=`frame every ${l.frequency.toFixed(3)} second (${s.value} frames per second)`}),l.range=[10,10.5]}function za(r,e){let t=document.createElement("div");t.style.position="relative",t.style.display="inline-block",t.style.marginRight="4px",t.appendChild(e);let n=document.createElement("div");return n.textContent=`${r.toFixed(2)}s`,n.style.position="absolute",n.style.top="2px",n.style.right="4px",n.style.fontSize="10px",n.style.color="white",n.style.background="rgba(0,0,0,0.6)",n.style.padding="2px 4px",n.style.borderRadius="4px",n.style.pointerEvents="none",t.appendChild(n),t}async function Ui(r,e){let t=await e.arrayBuffer(),s=await new AudioContext({sampleRate:16e3}).decodeAudioData(t),a;if(s.numberOfChannels===2){let o=Math.sqrt(2),c=s.getChannelData(0),l=s.getChannelData(1);a=new Float32Array(c.length);for(let u=0;u<s.length;++u)a[u]=o*(c[u]+l[u])/2}else a=s.getChannelData(0);let i=await r.getAudioDuration(e);return{audio:a,duration:i}}async function Li({driver:r,spec:e,workerUrl:t,onLoading:n}){let s=Sn(),a=Sn(),i=await Je.thread({label:"OmnitoolSpeechTranscriber",workerUrl:t,setupHost:()=>({loading:async o=>n(o),deliverReport:async o=>s.pub(o),deliverTranscription:async o=>a.pub(o)})});return await i.work.prepare(e),{transcribe:Es(async o=>{let{source:c,language:l}=o,{audio:u,duration:d}=await Ui(r,c),f=_s(s(o.onReport),a(o.onTranscription)),m=await i.work.transcribe({duration:d,language:l,audio:u.buffer});return f(),m}),dispose:i.terminate()}}async function Hi(r){let e=await Li({driver:r,spec:{model:"onnx-community/whisper-tiny_timestamped",device:"webgpu",strideLength:5,chunkLength:30,dtype:"fp32"},workerUrl:new URL("/features/speech/transcribe/worker.bundle.min.js",import.meta.url),onLoading({progress:t,total:n}){console.log(t,n,"total")}});return{transcribe:async t=>{let n=await e.transcribe({source:t,language:"english",onReport(s){console.log("report",s)},onTranscription(s){console.log("transcript",s)}});console.log(n,"transcript result")}}}function os(r,e){let t={width:1920,height:1080},n=document.createElement("canvas");n.width=t.width,n.height=t.height;let s=n.getContext("2d");async function a(){let i=r.decodeVideo({source:e,async onFrame(c){let l=await r.composite([{kind:"image",frame:c},{kind:"text",content:"omnitool",fontSize:50,color:"green"}]);return c.close(),s?.drawImage(l,0,0),l}}),o=r.decodeAudio({source:e});await r.encode({video:i,audio:o,config:{audio:{codec:"opus",bitrate:128e3},video:{codec:"vp9",bitrate:1e6}}})}return{canvas:n,run:a}}var $t=await an.driver,Ma=document.querySelector(".results"),Na=document.querySelector(".fetch"),Va=document.querySelector(".import");Na?.addEventListener("click",Ha);Va?.addEventListener("click",La);Ni();var Ua=await Hi($t);await $t.thread.work.hello(),$t.machina.count===1?console.log("\u2705 driver works"):console.error("\u274C FAIL driver call didn't work");async function La(){let[r]=await window.showOpenFilePicker(),e=await r.getFile(),t=os($t,e);await Vi(e),Wi(t,r.name),await Ua.transcribe(e)}async function Ha(){let r=["/assets/temp/gl.mp4"];for(let e of r){let t=os($t,"/assets/temp/gl.mp4");Wi(t,e)}}async function Wi(r,e){let t=document.createElement("div");Ma.append(t);let n=document.createElement("p");n.textContent=e,t.append(n),t.append(r.canvas),await r.run()}
|
|
925
|
+
}
|
|
926
|
+
c1 /= float(passes*passes);
|
|
927
|
+
c2 /= float(passes*passes);
|
|
928
|
+
return mix(c1, c2, progress);
|
|
929
|
+
}
|
|
930
|
+
`,author:"gre",license:"MIT",createdAt:"Fri, 23 Feb 2018 15:18:22 +0100",updatedAt:"Fri, 23 Feb 2018 15:18:22 +0100"},{name:"Mosaic",paramsTypes:{endx:"int",endy:"int"},defaultParams:{endx:2,endy:-1},glsl:`// License: MIT
|
|
931
|
+
// Author: Xaychru
|
|
932
|
+
// ported by gre from https://gist.github.com/Xaychru/130bb7b7affedbda9df5
|
|
933
|
+
|
|
934
|
+
#define PI 3.14159265358979323
|
|
935
|
+
#define POW2(X) X*X
|
|
936
|
+
#define POW3(X) X*X*X
|
|
937
|
+
uniform int endx; // = 2
|
|
938
|
+
uniform int endy; // = -1
|
|
939
|
+
|
|
940
|
+
float Rand(vec2 v) {
|
|
941
|
+
return fract(sin(dot(v.xy ,vec2(12.9898,78.233))) * 43758.5453);
|
|
942
|
+
}
|
|
943
|
+
vec2 Rotate(vec2 v, float a) {
|
|
944
|
+
mat2 rm = mat2(cos(a), -sin(a),
|
|
945
|
+
sin(a), cos(a));
|
|
946
|
+
return rm*v;
|
|
947
|
+
}
|
|
948
|
+
float CosInterpolation(float x) {
|
|
949
|
+
return -cos(x*PI)/2.+.5;
|
|
950
|
+
}
|
|
951
|
+
vec4 transition(vec2 uv) {
|
|
952
|
+
vec2 p = uv.xy / vec2(1.0).xy - .5;
|
|
953
|
+
vec2 rp = p;
|
|
954
|
+
float rpr = (progress*2.-1.);
|
|
955
|
+
float z = -(rpr*rpr*2.) + 3.;
|
|
956
|
+
float az = abs(z);
|
|
957
|
+
rp *= az;
|
|
958
|
+
rp += mix(vec2(.5, .5), vec2(float(endx) + .5, float(endy) + .5), POW2(CosInterpolation(progress)));
|
|
959
|
+
vec2 mrp = mod(rp, 1.);
|
|
960
|
+
vec2 crp = rp;
|
|
961
|
+
bool onEnd = int(floor(crp.x))==endx&&int(floor(crp.y))==endy;
|
|
962
|
+
if(!onEnd) {
|
|
963
|
+
float ang = float(int(Rand(floor(crp))*4.))*.5*PI;
|
|
964
|
+
mrp = vec2(.5) + Rotate(mrp-vec2(.5), ang);
|
|
965
|
+
}
|
|
966
|
+
if(onEnd || Rand(floor(crp))>.5) {
|
|
967
|
+
return getToColor(mrp);
|
|
968
|
+
} else {
|
|
969
|
+
return getFromColor(mrp);
|
|
970
|
+
}
|
|
971
|
+
}
|
|
972
|
+
`,license:"MIT",author:"Xaychru",createdAt:"Mon, 12 Jun 2017 10:26:51 +0800",updatedAt:"Mon, 12 Jun 2017 10:26:51 +0800"},{name:"PolkaDotsCurtain",paramsTypes:{dots:"float",center:"vec2"},defaultParams:{dots:20,center:[0,0]},glsl:`// author: bobylito
|
|
973
|
+
// license: MIT
|
|
974
|
+
const float SQRT_2 = 1.414213562373;
|
|
975
|
+
uniform float dots;// = 20.0;
|
|
976
|
+
uniform vec2 center;// = vec2(0, 0);
|
|
977
|
+
|
|
978
|
+
vec4 transition(vec2 uv) {
|
|
979
|
+
bool nextImage = distance(fract(uv * dots), vec2(0.5, 0.5)) < ( progress / distance(uv, center));
|
|
980
|
+
return nextImage ? getToColor(uv) : getFromColor(uv);
|
|
981
|
+
}
|
|
982
|
+
`,author:"bobylito",license:"MIT",createdAt:"Tue, 20 Feb 2018 23:41:45 +0100",updatedAt:"Tue, 20 Feb 2018 23:41:45 +0100"},{name:"Radial",paramsTypes:{smoothness:"float"},defaultParams:{smoothness:1},glsl:`// License: MIT
|
|
983
|
+
// Author: Xaychru
|
|
984
|
+
// ported by gre from https://gist.github.com/Xaychru/ce1d48f0ce00bb379750
|
|
985
|
+
|
|
986
|
+
uniform float smoothness; // = 1.0
|
|
987
|
+
|
|
988
|
+
const float PI = 3.141592653589;
|
|
989
|
+
|
|
990
|
+
vec4 transition(vec2 p) {
|
|
991
|
+
vec2 rp = p*2.-1.;
|
|
992
|
+
return mix(
|
|
993
|
+
getToColor(p),
|
|
994
|
+
getFromColor(p),
|
|
995
|
+
smoothstep(0., smoothness, atan(rp.y,rp.x) - (progress-.5) * PI * 2.5)
|
|
996
|
+
);
|
|
997
|
+
}
|
|
998
|
+
`,license:"MIT",author:"Xaychru",createdAt:"Mon, 12 Jun 2017 10:36:24 +0800",updatedAt:"Mon, 12 Jun 2017 10:36:24 +0800"},{name:"SimpleZoom",paramsTypes:{zoom_quickness:"float"},defaultParams:{zoom_quickness:.8},glsl:`// Author: 0gust1
|
|
999
|
+
// License: MIT
|
|
1000
|
+
|
|
1001
|
+
uniform float zoom_quickness; // = 0.8
|
|
1002
|
+
float nQuick = clamp(zoom_quickness,0.2,1.0);
|
|
1003
|
+
|
|
1004
|
+
vec2 zoom(vec2 uv, float amount) {
|
|
1005
|
+
return 0.5 + ((uv - 0.5) * (1.0-amount));
|
|
1006
|
+
}
|
|
1007
|
+
|
|
1008
|
+
vec4 transition (vec2 uv) {
|
|
1009
|
+
return mix(
|
|
1010
|
+
getFromColor(zoom(uv, smoothstep(0.0, nQuick, progress))),
|
|
1011
|
+
getToColor(uv),
|
|
1012
|
+
smoothstep(nQuick-0.2, 1.0, progress)
|
|
1013
|
+
);
|
|
1014
|
+
}`,author:"0gust1",license:"MIT",createdAt:"Tue, 6 Mar 2018 00:43:47 +0100",updatedAt:"Tue, 6 Mar 2018 00:43:47 +0100"},{name:"StereoViewer",paramsTypes:{zoom:"float",corner_radius:"float"},defaultParams:{zoom:.88,corner_radius:.22},glsl:`// Tunable parameters
|
|
1015
|
+
// How much to zoom (out) for the effect ~ 0.5 - 1.0
|
|
1016
|
+
uniform float zoom; // = 0.88
|
|
1017
|
+
// Corner radius as a fraction of the image height
|
|
1018
|
+
uniform float corner_radius; // = 0.22
|
|
1019
|
+
|
|
1020
|
+
// author: Ted Schundler
|
|
1021
|
+
// license: BSD 2 Clause
|
|
1022
|
+
// Free for use and modification by anyone with credit
|
|
1023
|
+
|
|
1024
|
+
// Copyright (c) 2016, Theodore K Schundler
|
|
1025
|
+
// All rights reserved.
|
|
1026
|
+
|
|
1027
|
+
// Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
|
|
1028
|
+
|
|
1029
|
+
// 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
|
|
1030
|
+
|
|
1031
|
+
// 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
|
|
1032
|
+
|
|
1033
|
+
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
1034
|
+
|
|
1035
|
+
///////////////////////////////////////////////////////////////////////////////
|
|
1036
|
+
// Stereo Viewer Toy Transition //
|
|
1037
|
+
// //
|
|
1038
|
+
// Inspired by ViewMaster / Image3D image viewer devices. //
|
|
1039
|
+
// This effect is similar to what you see when you press the device's lever. //
|
|
1040
|
+
// There is a quick zoom in / out to make the transition 'valid' for GLSL.io //
|
|
1041
|
+
///////////////////////////////////////////////////////////////////////////////
|
|
1042
|
+
|
|
1043
|
+
const vec4 black = vec4(0.0, 0.0, 0.0, 1.0);
|
|
1044
|
+
const vec2 c00 = vec2(0.0, 0.0); // the four corner points
|
|
1045
|
+
const vec2 c01 = vec2(0.0, 1.0);
|
|
1046
|
+
const vec2 c11 = vec2(1.0, 1.0);
|
|
1047
|
+
const vec2 c10 = vec2(1.0, 0.0);
|
|
1048
|
+
|
|
1049
|
+
// Check if a point is within a given corner
|
|
1050
|
+
bool in_corner(vec2 p, vec2 corner, vec2 radius) {
|
|
1051
|
+
// determine the direction we want to be filled
|
|
1052
|
+
vec2 axis = (c11 - corner) - corner;
|
|
1053
|
+
|
|
1054
|
+
// warp the point so we are always testing the bottom left point with the
|
|
1055
|
+
// circle centered on the origin
|
|
1056
|
+
p = p - (corner + axis * radius);
|
|
1057
|
+
p *= axis / radius;
|
|
1058
|
+
return (p.x > 0.0 && p.y > -1.0) || (p.y > 0.0 && p.x > -1.0) || dot(p, p) < 1.0;
|
|
1059
|
+
}
|
|
1060
|
+
|
|
1061
|
+
// Check all four corners
|
|
1062
|
+
// return a float for v2 for anti-aliasing?
|
|
1063
|
+
bool test_rounded_mask(vec2 p, vec2 corner_size) {
|
|
1064
|
+
return
|
|
1065
|
+
in_corner(p, c00, corner_size) &&
|
|
1066
|
+
in_corner(p, c01, corner_size) &&
|
|
1067
|
+
in_corner(p, c10, corner_size) &&
|
|
1068
|
+
in_corner(p, c11, corner_size);
|
|
1069
|
+
}
|
|
1070
|
+
|
|
1071
|
+
// Screen blend mode - https://en.wikipedia.org/wiki/Blend_modes
|
|
1072
|
+
// This more closely approximates what you see than linear blending
|
|
1073
|
+
vec4 screen(vec4 a, vec4 b) {
|
|
1074
|
+
return 1.0 - (1.0 - a) * (1.0 -b);
|
|
1075
|
+
}
|
|
1076
|
+
|
|
1077
|
+
// Given RGBA, find a value that when screened with itself
|
|
1078
|
+
// will yield the original value.
|
|
1079
|
+
vec4 unscreen(vec4 c) {
|
|
1080
|
+
return 1.0 - sqrt(1.0 - c);
|
|
1081
|
+
}
|
|
1082
|
+
|
|
1083
|
+
// Grab a pixel, only if it isn't masked out by the rounded corners
|
|
1084
|
+
vec4 sample_with_corners_from(vec2 p, vec2 corner_size) {
|
|
1085
|
+
p = (p - 0.5) / zoom + 0.5;
|
|
1086
|
+
if (!test_rounded_mask(p, corner_size)) {
|
|
1087
|
+
return black;
|
|
1088
|
+
}
|
|
1089
|
+
return unscreen(getFromColor(p));
|
|
1090
|
+
}
|
|
1091
|
+
|
|
1092
|
+
vec4 sample_with_corners_to(vec2 p, vec2 corner_size) {
|
|
1093
|
+
p = (p - 0.5) / zoom + 0.5;
|
|
1094
|
+
if (!test_rounded_mask(p, corner_size)) {
|
|
1095
|
+
return black;
|
|
1096
|
+
}
|
|
1097
|
+
return unscreen(getToColor(p));
|
|
1098
|
+
}
|
|
1099
|
+
|
|
1100
|
+
// special sampling used when zooming - extra zoom parameter and don't unscreen
|
|
1101
|
+
vec4 simple_sample_with_corners_from(vec2 p, vec2 corner_size, float zoom_amt) {
|
|
1102
|
+
p = (p - 0.5) / (1.0 - zoom_amt + zoom * zoom_amt) + 0.5;
|
|
1103
|
+
if (!test_rounded_mask(p, corner_size)) {
|
|
1104
|
+
return black;
|
|
1105
|
+
}
|
|
1106
|
+
return getFromColor(p);
|
|
1107
|
+
}
|
|
1108
|
+
|
|
1109
|
+
vec4 simple_sample_with_corners_to(vec2 p, vec2 corner_size, float zoom_amt) {
|
|
1110
|
+
p = (p - 0.5) / (1.0 - zoom_amt + zoom * zoom_amt) + 0.5;
|
|
1111
|
+
if (!test_rounded_mask(p, corner_size)) {
|
|
1112
|
+
return black;
|
|
1113
|
+
}
|
|
1114
|
+
return getToColor(p);
|
|
1115
|
+
}
|
|
1116
|
+
|
|
1117
|
+
// Basic 2D affine transform matrix helpers
|
|
1118
|
+
// These really shouldn't be used in a fragment shader - I should work out the
|
|
1119
|
+
// the math for a translate & rotate function as a pair of dot products instead
|
|
1120
|
+
|
|
1121
|
+
mat3 rotate2d(float angle, float ratio) {
|
|
1122
|
+
float s = sin(angle);
|
|
1123
|
+
float c = cos(angle);
|
|
1124
|
+
return mat3(
|
|
1125
|
+
c, s ,0.0,
|
|
1126
|
+
-s, c, 0.0,
|
|
1127
|
+
0.0, 0.0, 1.0);
|
|
1128
|
+
}
|
|
1129
|
+
|
|
1130
|
+
mat3 translate2d(float x, float y) {
|
|
1131
|
+
return mat3(
|
|
1132
|
+
1.0, 0.0, 0,
|
|
1133
|
+
0.0, 1.0, 0,
|
|
1134
|
+
-x, -y, 1.0);
|
|
1135
|
+
}
|
|
1136
|
+
|
|
1137
|
+
mat3 scale2d(float x, float y) {
|
|
1138
|
+
return mat3(
|
|
1139
|
+
x, 0.0, 0,
|
|
1140
|
+
0.0, y, 0,
|
|
1141
|
+
0, 0, 1.0);
|
|
1142
|
+
}
|
|
1143
|
+
|
|
1144
|
+
// Split an image and rotate one up and one down along off screen pivot points
|
|
1145
|
+
vec4 get_cross_rotated(vec3 p3, float angle, vec2 corner_size, float ratio) {
|
|
1146
|
+
angle = angle * angle; // easing
|
|
1147
|
+
angle /= 2.4; // works out to be a good number of radians
|
|
1148
|
+
|
|
1149
|
+
mat3 center_and_scale = translate2d(-0.5, -0.5) * scale2d(1.0, ratio);
|
|
1150
|
+
mat3 unscale_and_uncenter = scale2d(1.0, 1.0/ratio) * translate2d(0.5,0.5);
|
|
1151
|
+
mat3 slide_left = translate2d(-2.0,0.0);
|
|
1152
|
+
mat3 slide_right = translate2d(2.0,0.0);
|
|
1153
|
+
mat3 rotate = rotate2d(angle, ratio);
|
|
1154
|
+
|
|
1155
|
+
mat3 op_a = center_and_scale * slide_right * rotate * slide_left * unscale_and_uncenter;
|
|
1156
|
+
mat3 op_b = center_and_scale * slide_left * rotate * slide_right * unscale_and_uncenter;
|
|
1157
|
+
|
|
1158
|
+
vec4 a = sample_with_corners_from((op_a * p3).xy, corner_size);
|
|
1159
|
+
vec4 b = sample_with_corners_from((op_b * p3).xy, corner_size);
|
|
1160
|
+
|
|
1161
|
+
return screen(a, b);
|
|
1162
|
+
}
|
|
1163
|
+
|
|
1164
|
+
// Image stays put, but this time move two masks
|
|
1165
|
+
vec4 get_cross_masked(vec3 p3, float angle, vec2 corner_size, float ratio) {
|
|
1166
|
+
angle = 1.0 - angle;
|
|
1167
|
+
angle = angle * angle; // easing
|
|
1168
|
+
angle /= 2.4;
|
|
1169
|
+
|
|
1170
|
+
vec4 img;
|
|
1171
|
+
|
|
1172
|
+
mat3 center_and_scale = translate2d(-0.5, -0.5) * scale2d(1.0, ratio);
|
|
1173
|
+
mat3 unscale_and_uncenter = scale2d(1.0 / zoom, 1.0 / (zoom * ratio)) * translate2d(0.5,0.5);
|
|
1174
|
+
mat3 slide_left = translate2d(-2.0,0.0);
|
|
1175
|
+
mat3 slide_right = translate2d(2.0,0.0);
|
|
1176
|
+
mat3 rotate = rotate2d(angle, ratio);
|
|
1177
|
+
|
|
1178
|
+
mat3 op_a = center_and_scale * slide_right * rotate * slide_left * unscale_and_uncenter;
|
|
1179
|
+
mat3 op_b = center_and_scale * slide_left * rotate * slide_right * unscale_and_uncenter;
|
|
1180
|
+
|
|
1181
|
+
bool mask_a = test_rounded_mask((op_a * p3).xy, corner_size);
|
|
1182
|
+
bool mask_b = test_rounded_mask((op_b * p3).xy, corner_size);
|
|
1183
|
+
|
|
1184
|
+
if (mask_a || mask_b) {
|
|
1185
|
+
img = sample_with_corners_to(p3.xy, corner_size);
|
|
1186
|
+
return screen(mask_a ? img : black, mask_b ? img : black);
|
|
1187
|
+
} else {
|
|
1188
|
+
return black;
|
|
1189
|
+
}
|
|
1190
|
+
}
|
|
1191
|
+
|
|
1192
|
+
vec4 transition(vec2 uv) {
|
|
1193
|
+
float a;
|
|
1194
|
+
vec2 p=uv.xy/vec2(1.0).xy;
|
|
1195
|
+
vec3 p3 = vec3(p.xy, 1.0); // for 2D matrix transforms
|
|
1196
|
+
|
|
1197
|
+
// corner is warped to represent to size after mapping to 1.0, 1.0
|
|
1198
|
+
vec2 corner_size = vec2(corner_radius / ratio, corner_radius);
|
|
1199
|
+
|
|
1200
|
+
if (progress <= 0.0) {
|
|
1201
|
+
// 0.0: start with the base frame always
|
|
1202
|
+
return getFromColor(p);
|
|
1203
|
+
} else if (progress < 0.1) {
|
|
1204
|
+
// 0.0-0.1: zoom out and add rounded corners
|
|
1205
|
+
a = progress / 0.1;
|
|
1206
|
+
return simple_sample_with_corners_from(p, corner_size * a, a);
|
|
1207
|
+
} else if (progress < 0.48) {
|
|
1208
|
+
// 0.1-0.48: Split original image apart
|
|
1209
|
+
a = (progress - 0.1)/0.38;
|
|
1210
|
+
return get_cross_rotated(p3, a, corner_size, ratio);
|
|
1211
|
+
} else if (progress < 0.9) {
|
|
1212
|
+
// 0.48-0.52: black
|
|
1213
|
+
// 0.52 - 0.9: unmask new image
|
|
1214
|
+
return get_cross_masked(p3, (progress - 0.52)/0.38, corner_size, ratio);
|
|
1215
|
+
} else if (progress < 1.0) {
|
|
1216
|
+
// zoom out and add rounded corners
|
|
1217
|
+
a = (1.0 - progress) / 0.1;
|
|
1218
|
+
return simple_sample_with_corners_to(p, corner_size * a, a);
|
|
1219
|
+
} else {
|
|
1220
|
+
// 1.0 end with base frame
|
|
1221
|
+
return getToColor(p);
|
|
1222
|
+
}
|
|
1223
|
+
}
|
|
1224
|
+
`,author:"Ted Schundler",license:"BSD 2 Clause",createdAt:"Tue, 20 Feb 2018 23:20:29 +0100",updatedAt:"Wed, 21 Feb 2018 15:42:00 +0100"},{name:"Swirl",paramsTypes:{},defaultParams:{},glsl:`// License: MIT
|
|
1225
|
+
// Author: Sergey Kosarevsky
|
|
1226
|
+
// ( http://www.linderdaum.com )
|
|
1227
|
+
// ported by gre from https://gist.github.com/corporateshark/cacfedb8cca0f5ce3f7c
|
|
1228
|
+
|
|
1229
|
+
vec4 transition(vec2 UV)
|
|
1230
|
+
{
|
|
1231
|
+
float Radius = 1.0;
|
|
1232
|
+
|
|
1233
|
+
float T = progress;
|
|
1234
|
+
|
|
1235
|
+
UV -= vec2( 0.5, 0.5 );
|
|
1236
|
+
|
|
1237
|
+
float Dist = length(UV);
|
|
1238
|
+
|
|
1239
|
+
if ( Dist < Radius )
|
|
1240
|
+
{
|
|
1241
|
+
float Percent = (Radius - Dist) / Radius;
|
|
1242
|
+
float A = ( T <= 0.5 ) ? mix( 0.0, 1.0, T/0.5 ) : mix( 1.0, 0.0, (T-0.5)/0.5 );
|
|
1243
|
+
float Theta = Percent * Percent * A * 8.0 * 3.14159;
|
|
1244
|
+
float S = sin( Theta );
|
|
1245
|
+
float C = cos( Theta );
|
|
1246
|
+
UV = vec2( dot(UV, vec2(C, -S)), dot(UV, vec2(S, C)) );
|
|
1247
|
+
}
|
|
1248
|
+
UV += vec2( 0.5, 0.5 );
|
|
1249
|
+
|
|
1250
|
+
vec4 C0 = getFromColor(UV);
|
|
1251
|
+
vec4 C1 = getToColor(UV);
|
|
1252
|
+
|
|
1253
|
+
return mix( C0, C1, T );
|
|
1254
|
+
}
|
|
1255
|
+
`,license:"MIT",author:"Sergey Kosarevsky",createdAt:"Mon, 12 Jun 2017 12:38:27 +0800",updatedAt:"Mon, 12 Jun 2017 12:38:27 +0800"},{name:"WaterDrop",paramsTypes:{amplitude:"float",speed:"float"},defaultParams:{amplitude:30,speed:30},glsl:`// author: Pawe\u0142 P\u0142\xF3ciennik
|
|
1256
|
+
// license: MIT
|
|
1257
|
+
uniform float amplitude; // = 30
|
|
1258
|
+
uniform float speed; // = 30
|
|
1259
|
+
|
|
1260
|
+
vec4 transition(vec2 p) {
|
|
1261
|
+
vec2 dir = p - vec2(.5);
|
|
1262
|
+
float dist = length(dir);
|
|
1263
|
+
|
|
1264
|
+
if (dist > progress) {
|
|
1265
|
+
return mix(getFromColor( p), getToColor( p), progress);
|
|
1266
|
+
} else {
|
|
1267
|
+
vec2 offset = dir * sin(dist * amplitude - progress * speed);
|
|
1268
|
+
return mix(getFromColor( p + offset), getToColor( p), progress);
|
|
1269
|
+
}
|
|
1270
|
+
}
|
|
1271
|
+
`,author:"Pawe\u0142 P\u0142\xF3ciennik",license:"MIT",createdAt:"Wed, 21 Feb 2018 19:37:15 +0100",updatedAt:"Wed, 21 Feb 2018 19:37:15 +0100"},{name:"ZoomInCircles",paramsTypes:{},defaultParams:{},glsl:`// License: MIT
|
|
1272
|
+
// Author: dycm8009
|
|
1273
|
+
// ported by gre from https://gist.github.com/dycm8009/948e99b1800e81ad909a
|
|
1274
|
+
|
|
1275
|
+
vec2 zoom(vec2 uv, float amount) {
|
|
1276
|
+
return 0.5 + ((uv - 0.5) * amount);
|
|
1277
|
+
}
|
|
1278
|
+
|
|
1279
|
+
vec2 ratio2 = vec2(1.0, 1.0 / ratio);
|
|
1280
|
+
|
|
1281
|
+
vec4 transition(vec2 uv) {
|
|
1282
|
+
// TODO: some timing are hardcoded but should be one or many parameters
|
|
1283
|
+
// TODO: should also be able to configure how much circles
|
|
1284
|
+
// TODO: if() branching should be avoided when possible, prefer use of step() & other functions
|
|
1285
|
+
vec2 r = 2.0 * ((vec2(uv.xy) - 0.5) * ratio2);
|
|
1286
|
+
float pro = progress / 0.8;
|
|
1287
|
+
float z = pro * 0.2;
|
|
1288
|
+
float t = 0.0;
|
|
1289
|
+
if (pro > 1.0) {
|
|
1290
|
+
z = 0.2 + (pro - 1.0) * 5.;
|
|
1291
|
+
t = clamp((progress - 0.8) / 0.07, 0.0, 1.0);
|
|
1292
|
+
}
|
|
1293
|
+
if (length(r) < 0.5+z) {
|
|
1294
|
+
// uv = zoom(uv, 0.9 - 0.1 * pro);
|
|
1295
|
+
}
|
|
1296
|
+
else if (length(r) < 0.8+z*1.5) {
|
|
1297
|
+
uv = zoom(uv, 1.0 - 0.15 * pro);
|
|
1298
|
+
t = t * 0.5;
|
|
1299
|
+
}
|
|
1300
|
+
else if (length(r) < 1.2+z*2.5) {
|
|
1301
|
+
uv = zoom(uv, 1.0 - 0.2 * pro);
|
|
1302
|
+
t = t * 0.2;
|
|
1303
|
+
}
|
|
1304
|
+
else {
|
|
1305
|
+
uv = zoom(uv, 1.0 - 0.25 * pro);
|
|
1306
|
+
}
|
|
1307
|
+
return mix(getFromColor(uv), getToColor(uv), t);
|
|
1308
|
+
}
|
|
1309
|
+
`,license:"MIT",author:"dycm8009",createdAt:"Mon, 12 Jun 2017 11:24:34 +0800",updatedAt:"Mon, 12 Jun 2017 11:24:34 +0800"},{name:"angular",paramsTypes:{startingAngle:"float"},defaultParams:{startingAngle:90},glsl:`// Author: Fernando Kuteken
|
|
1310
|
+
// License: MIT
|
|
1311
|
+
|
|
1312
|
+
#define PI 3.141592653589
|
|
1313
|
+
|
|
1314
|
+
uniform float startingAngle; // = 90;
|
|
1315
|
+
|
|
1316
|
+
vec4 transition (vec2 uv) {
|
|
1317
|
+
|
|
1318
|
+
float offset = startingAngle * PI / 180.0;
|
|
1319
|
+
float angle = atan(uv.y - 0.5, uv.x - 0.5) + offset;
|
|
1320
|
+
float normalizedAngle = (angle + PI) / (2.0 * PI);
|
|
1321
|
+
|
|
1322
|
+
normalizedAngle = normalizedAngle - floor(normalizedAngle);
|
|
1323
|
+
|
|
1324
|
+
return mix(
|
|
1325
|
+
getFromColor(uv),
|
|
1326
|
+
getToColor(uv),
|
|
1327
|
+
step(normalizedAngle, progress)
|
|
1328
|
+
);
|
|
1329
|
+
}
|
|
1330
|
+
`,author:"Fernando Kuteken",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"burn",paramsTypes:{color:"vec3"},defaultParams:{color:[.9,.4,.2]},glsl:`// author: gre
|
|
1331
|
+
// License: MIT
|
|
1332
|
+
uniform vec3 color /* = vec3(0.9, 0.4, 0.2) */;
|
|
1333
|
+
vec4 transition (vec2 uv) {
|
|
1334
|
+
return mix(
|
|
1335
|
+
getFromColor(uv) + vec4(progress*color, 1.0),
|
|
1336
|
+
getToColor(uv) + vec4((1.0-progress)*color, 1.0),
|
|
1337
|
+
progress
|
|
1338
|
+
);
|
|
1339
|
+
}
|
|
1340
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"cannabisleaf",paramsTypes:{},defaultParams:{},glsl:`// Author: @Flexi23
|
|
1341
|
+
// License: MIT
|
|
1342
|
+
|
|
1343
|
+
// inspired by http://www.wolframalpha.com/input/?i=cannabis+curve
|
|
1344
|
+
|
|
1345
|
+
vec4 transition (vec2 uv) {
|
|
1346
|
+
if(progress == 0.0){
|
|
1347
|
+
return getFromColor(uv);
|
|
1348
|
+
}
|
|
1349
|
+
vec2 leaf_uv = (uv - vec2(0.5))/10./pow(progress,3.5);
|
|
1350
|
+
leaf_uv.y += 0.35;
|
|
1351
|
+
float r = 0.18;
|
|
1352
|
+
float o = atan(leaf_uv.y, leaf_uv.x);
|
|
1353
|
+
return mix(getFromColor(uv), getToColor(uv), 1.-step(1. - length(leaf_uv)+r*(1.+sin(o))*(1.+0.9 * cos(8.*o))*(1.+0.1*cos(24.*o))*(0.9+0.05*cos(200.*o)), 1.));
|
|
1354
|
+
}
|
|
1355
|
+
`,author:"@Flexi23",license:"MIT",createdAt:"Thu, 1 Jun 2017 15:58:58 +0200",updatedAt:"Thu, 1 Jun 2017 15:58:58 +0200"},{name:"circle",paramsTypes:{center:"vec2",backColor:"vec3"},defaultParams:{center:[.5,.5],backColor:[.1,.1,.1]},glsl:`// Author: Fernando Kuteken
|
|
1356
|
+
// License: MIT
|
|
1357
|
+
|
|
1358
|
+
uniform vec2 center; // = vec2(0.5, 0.5);
|
|
1359
|
+
uniform vec3 backColor; // = vec3(0.1, 0.1, 0.1);
|
|
1360
|
+
|
|
1361
|
+
vec4 transition (vec2 uv) {
|
|
1362
|
+
|
|
1363
|
+
float distance = length(uv - center);
|
|
1364
|
+
float radius = sqrt(8.0) * abs(progress - 0.5);
|
|
1365
|
+
|
|
1366
|
+
if (distance > radius) {
|
|
1367
|
+
return vec4(backColor, 1.0);
|
|
1368
|
+
}
|
|
1369
|
+
else {
|
|
1370
|
+
if (progress < 0.5) return getFromColor(uv);
|
|
1371
|
+
else return getToColor(uv);
|
|
1372
|
+
}
|
|
1373
|
+
}
|
|
1374
|
+
`,author:"Fernando Kuteken",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"circleopen",paramsTypes:{smoothness:"float",opening:"bool"},defaultParams:{smoothness:.3,opening:!0},glsl:`// author: gre
|
|
1375
|
+
// License: MIT
|
|
1376
|
+
uniform float smoothness; // = 0.3
|
|
1377
|
+
uniform bool opening; // = true
|
|
1378
|
+
|
|
1379
|
+
const vec2 center = vec2(0.5, 0.5);
|
|
1380
|
+
const float SQRT_2 = 1.414213562373;
|
|
1381
|
+
|
|
1382
|
+
vec4 transition (vec2 uv) {
|
|
1383
|
+
float x = opening ? progress : 1.-progress;
|
|
1384
|
+
float m = smoothstep(-smoothness, 0.0, SQRT_2*distance(center, uv) - x*(1.+smoothness));
|
|
1385
|
+
return mix(getFromColor(uv), getToColor(uv), opening ? 1.-m : m);
|
|
1386
|
+
}
|
|
1387
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"colorphase",paramsTypes:{fromStep:"vec4",toStep:"vec4"},defaultParams:{fromStep:[0,.2,.4,0],toStep:[.6,.8,1,1]},glsl:`// Author: gre
|
|
1388
|
+
// License: MIT
|
|
1389
|
+
|
|
1390
|
+
// Usage: fromStep and toStep must be in [0.0, 1.0] range
|
|
1391
|
+
// and all(fromStep) must be < all(toStep)
|
|
1392
|
+
|
|
1393
|
+
uniform vec4 fromStep; // = vec4(0.0, 0.2, 0.4, 0.0)
|
|
1394
|
+
uniform vec4 toStep; // = vec4(0.6, 0.8, 1.0, 1.0)
|
|
1395
|
+
|
|
1396
|
+
vec4 transition (vec2 uv) {
|
|
1397
|
+
vec4 a = getFromColor(uv);
|
|
1398
|
+
vec4 b = getToColor(uv);
|
|
1399
|
+
return mix(a, b, smoothstep(fromStep, toStep, vec4(progress)));
|
|
1400
|
+
}
|
|
1401
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"crosshatch",paramsTypes:{center:"vec2",threshold:"float",fadeEdge:"float"},defaultParams:{center:[.5,.5],threshold:3,fadeEdge:.1},glsl:`// License: MIT
|
|
1402
|
+
// Author: pthrasher
|
|
1403
|
+
// adapted by gre from https://gist.github.com/pthrasher/04fd9a7de4012cbb03f6
|
|
1404
|
+
|
|
1405
|
+
uniform vec2 center; // = vec2(0.5)
|
|
1406
|
+
uniform float threshold; // = 3.0
|
|
1407
|
+
uniform float fadeEdge; // = 0.1
|
|
1408
|
+
|
|
1409
|
+
float rand(vec2 co) {
|
|
1410
|
+
return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);
|
|
1411
|
+
}
|
|
1412
|
+
vec4 transition(vec2 p) {
|
|
1413
|
+
float dist = distance(center, p) / threshold;
|
|
1414
|
+
float r = progress - min(rand(vec2(p.y, 0.0)), rand(vec2(0.0, p.x)));
|
|
1415
|
+
return mix(getFromColor(p), getToColor(p), mix(0.0, mix(step(dist, r), 1.0, smoothstep(1.0-fadeEdge, 1.0, progress)), smoothstep(0.0, fadeEdge, progress)));
|
|
1416
|
+
}
|
|
1417
|
+
`,license:"MIT",author:"pthrasher",createdAt:"Mon, 12 Jun 2017 10:02:12 +0800",updatedAt:"Mon, 12 Jun 2017 10:02:12 +0800"},{name:"crosswarp",paramsTypes:{},defaultParams:{},glsl:`// Author: Eke P\xE9ter <peterekepeter@gmail.com>
|
|
1418
|
+
// License: MIT
|
|
1419
|
+
vec4 transition(vec2 p) {
|
|
1420
|
+
float x = progress;
|
|
1421
|
+
x=smoothstep(.0,1.0,(x*2.0+p.x-1.0));
|
|
1422
|
+
return mix(getFromColor((p-.5)*(1.-x)+.5), getToColor((p-.5)*x+.5), x);
|
|
1423
|
+
}
|
|
1424
|
+
`,author:"Eke P\xE9ter <peterekepeter@gmail.com>",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"cube",paramsTypes:{persp:"float",unzoom:"float",reflection:"float",floating:"float"},defaultParams:{persp:.7,unzoom:.3,reflection:.4,floating:3},glsl:`// Author: gre
|
|
1425
|
+
// License: MIT
|
|
1426
|
+
uniform float persp; // = 0.7
|
|
1427
|
+
uniform float unzoom; // = 0.3
|
|
1428
|
+
uniform float reflection; // = 0.4
|
|
1429
|
+
uniform float floating; // = 3.0
|
|
1430
|
+
|
|
1431
|
+
vec2 project (vec2 p) {
|
|
1432
|
+
return p * vec2(1.0, -1.2) + vec2(0.0, -floating/100.);
|
|
1433
|
+
}
|
|
1434
|
+
|
|
1435
|
+
bool inBounds (vec2 p) {
|
|
1436
|
+
return all(lessThan(vec2(0.0), p)) && all(lessThan(p, vec2(1.0)));
|
|
1437
|
+
}
|
|
1438
|
+
|
|
1439
|
+
vec4 bgColor (vec2 p, vec2 pfr, vec2 pto) {
|
|
1440
|
+
vec4 c = vec4(0.0, 0.0, 0.0, 1.0);
|
|
1441
|
+
pfr = project(pfr);
|
|
1442
|
+
// FIXME avoid branching might help perf!
|
|
1443
|
+
if (inBounds(pfr)) {
|
|
1444
|
+
c += mix(vec4(0.0), getFromColor(pfr), reflection * mix(1.0, 0.0, pfr.y));
|
|
1445
|
+
}
|
|
1446
|
+
pto = project(pto);
|
|
1447
|
+
if (inBounds(pto)) {
|
|
1448
|
+
c += mix(vec4(0.0), getToColor(pto), reflection * mix(1.0, 0.0, pto.y));
|
|
1449
|
+
}
|
|
1450
|
+
return c;
|
|
1451
|
+
}
|
|
1452
|
+
|
|
1453
|
+
// p : the position
|
|
1454
|
+
// persp : the perspective in [ 0, 1 ]
|
|
1455
|
+
// center : the xcenter in [0, 1] \\ 0.5 excluded
|
|
1456
|
+
vec2 xskew (vec2 p, float persp, float center) {
|
|
1457
|
+
float x = mix(p.x, 1.0-p.x, center);
|
|
1458
|
+
return (
|
|
1459
|
+
(
|
|
1460
|
+
vec2( x, (p.y - 0.5*(1.0-persp) * x) / (1.0+(persp-1.0)*x) )
|
|
1461
|
+
- vec2(0.5-distance(center, 0.5), 0.0)
|
|
1462
|
+
)
|
|
1463
|
+
* vec2(0.5 / distance(center, 0.5) * (center<0.5 ? 1.0 : -1.0), 1.0)
|
|
1464
|
+
+ vec2(center<0.5 ? 0.0 : 1.0, 0.0)
|
|
1465
|
+
);
|
|
1466
|
+
}
|
|
1467
|
+
|
|
1468
|
+
vec4 transition(vec2 op) {
|
|
1469
|
+
float uz = unzoom * 2.0*(0.5-distance(0.5, progress));
|
|
1470
|
+
vec2 p = -uz*0.5+(1.0+uz) * op;
|
|
1471
|
+
vec2 fromP = xskew(
|
|
1472
|
+
(p - vec2(progress, 0.0)) / vec2(1.0-progress, 1.0),
|
|
1473
|
+
1.0-mix(progress, 0.0, persp),
|
|
1474
|
+
0.0
|
|
1475
|
+
);
|
|
1476
|
+
vec2 toP = xskew(
|
|
1477
|
+
p / vec2(progress, 1.0),
|
|
1478
|
+
mix(pow(progress, 2.0), 1.0, persp),
|
|
1479
|
+
1.0
|
|
1480
|
+
);
|
|
1481
|
+
// FIXME avoid branching might help perf!
|
|
1482
|
+
if (inBounds(fromP)) {
|
|
1483
|
+
return getFromColor(fromP);
|
|
1484
|
+
}
|
|
1485
|
+
else if (inBounds(toP)) {
|
|
1486
|
+
return getToColor(toP);
|
|
1487
|
+
}
|
|
1488
|
+
return bgColor(op, fromP, toP);
|
|
1489
|
+
}
|
|
1490
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"directionalwarp",paramsTypes:{direction:"vec2"},defaultParams:{direction:[-1,1]},glsl:`// Author: pschroen
|
|
1491
|
+
// License: MIT
|
|
1492
|
+
|
|
1493
|
+
uniform vec2 direction; // = vec2(-1.0, 1.0)
|
|
1494
|
+
|
|
1495
|
+
const float smoothness = 0.5;
|
|
1496
|
+
const vec2 center = vec2(0.5, 0.5);
|
|
1497
|
+
|
|
1498
|
+
vec4 transition (vec2 uv) {
|
|
1499
|
+
vec2 v = normalize(direction);
|
|
1500
|
+
v /= abs(v.x) + abs(v.y);
|
|
1501
|
+
float d = v.x * center.x + v.y * center.y;
|
|
1502
|
+
float m = 1.0 - smoothstep(-smoothness, 0.0, v.x * uv.x + v.y * uv.y - (d - 0.5 + progress * (1.0 + smoothness)));
|
|
1503
|
+
return mix(getFromColor((uv - 0.5) * (1.0 - m) + 0.5), getToColor((uv - 0.5) * m + 0.5), m);
|
|
1504
|
+
}
|
|
1505
|
+
`,author:"pschroen",license:"MIT",createdAt:"Wed, 13 Dec 2017 12:08:49 -0500",updatedAt:"Wed, 13 Dec 2017 12:08:49 -0500"},{name:"directionalwipe",paramsTypes:{direction:"vec2",smoothness:"float"},defaultParams:{direction:[1,-1],smoothness:.5},glsl:`// Author: gre
|
|
1506
|
+
// License: MIT
|
|
1507
|
+
|
|
1508
|
+
uniform vec2 direction; // = vec2(1.0, -1.0)
|
|
1509
|
+
uniform float smoothness; // = 0.5
|
|
1510
|
+
|
|
1511
|
+
const vec2 center = vec2(0.5, 0.5);
|
|
1512
|
+
|
|
1513
|
+
vec4 transition (vec2 uv) {
|
|
1514
|
+
vec2 v = normalize(direction);
|
|
1515
|
+
v /= abs(v.x)+abs(v.y);
|
|
1516
|
+
float d = v.x * center.x + v.y * center.y;
|
|
1517
|
+
float m =
|
|
1518
|
+
(1.0-step(progress, 0.0)) * // there is something wrong with our formula that makes m not equals 0.0 with progress is 0.0
|
|
1519
|
+
(1.0 - smoothstep(-smoothness, 0.0, v.x * uv.x + v.y * uv.y - (d-0.5+progress*(1.+smoothness))));
|
|
1520
|
+
return mix(getFromColor(uv), getToColor(uv), m);
|
|
1521
|
+
}
|
|
1522
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"displacement",paramsTypes:{displacementMap:"sampler2D",strength:"float"},defaultParams:{displacementMap:null,strength:.5},glsl:`// Author: Travis Fischer
|
|
1523
|
+
// License: MIT
|
|
1524
|
+
//
|
|
1525
|
+
// Adapted from a Codrops article by Robin Delaporte
|
|
1526
|
+
// https://tympanus.net/Development/DistortionHoverEffect
|
|
1527
|
+
|
|
1528
|
+
uniform sampler2D displacementMap;
|
|
1529
|
+
|
|
1530
|
+
uniform float strength; // = 0.5
|
|
1531
|
+
|
|
1532
|
+
vec4 transition (vec2 uv) {
|
|
1533
|
+
float displacement = texture2D(displacementMap, uv).r * strength;
|
|
1534
|
+
|
|
1535
|
+
vec2 uvFrom = vec2(uv.x + progress * displacement, uv.y);
|
|
1536
|
+
vec2 uvTo = vec2(uv.x - (1.0 - progress) * displacement, uv.y);
|
|
1537
|
+
|
|
1538
|
+
return mix(
|
|
1539
|
+
getFromColor(uvFrom),
|
|
1540
|
+
getToColor(uvTo),
|
|
1541
|
+
progress
|
|
1542
|
+
);
|
|
1543
|
+
}
|
|
1544
|
+
`,author:"Travis Fischer",license:"MIT",createdAt:"Tue, 10 Apr 2018 23:03:38 -0400",updatedAt:"Tue, 10 Apr 2018 23:03:38 -0400"},{name:"doorway",paramsTypes:{reflection:"float",perspective:"float",depth:"float"},defaultParams:{reflection:.4,perspective:.4,depth:3},glsl:`// author: gre
|
|
1545
|
+
// License: MIT
|
|
1546
|
+
uniform float reflection; // = 0.4
|
|
1547
|
+
uniform float perspective; // = 0.4
|
|
1548
|
+
uniform float depth; // = 3
|
|
1549
|
+
|
|
1550
|
+
const vec4 black = vec4(0.0, 0.0, 0.0, 1.0);
|
|
1551
|
+
const vec2 boundMin = vec2(0.0, 0.0);
|
|
1552
|
+
const vec2 boundMax = vec2(1.0, 1.0);
|
|
1553
|
+
|
|
1554
|
+
bool inBounds (vec2 p) {
|
|
1555
|
+
return all(lessThan(boundMin, p)) && all(lessThan(p, boundMax));
|
|
1556
|
+
}
|
|
1557
|
+
|
|
1558
|
+
vec2 project (vec2 p) {
|
|
1559
|
+
return p * vec2(1.0, -1.2) + vec2(0.0, -0.02);
|
|
1560
|
+
}
|
|
1561
|
+
|
|
1562
|
+
vec4 bgColor (vec2 p, vec2 pto) {
|
|
1563
|
+
vec4 c = black;
|
|
1564
|
+
pto = project(pto);
|
|
1565
|
+
if (inBounds(pto)) {
|
|
1566
|
+
c += mix(black, getToColor(pto), reflection * mix(1.0, 0.0, pto.y));
|
|
1567
|
+
}
|
|
1568
|
+
return c;
|
|
1569
|
+
}
|
|
1570
|
+
|
|
1571
|
+
|
|
1572
|
+
vec4 transition (vec2 p) {
|
|
1573
|
+
vec2 pfr = vec2(-1.), pto = vec2(-1.);
|
|
1574
|
+
float middleSlit = 2.0 * abs(p.x-0.5) - progress;
|
|
1575
|
+
if (middleSlit > 0.0) {
|
|
1576
|
+
pfr = p + (p.x > 0.5 ? -1.0 : 1.0) * vec2(0.5*progress, 0.0);
|
|
1577
|
+
float d = 1.0/(1.0+perspective*progress*(1.0-middleSlit));
|
|
1578
|
+
pfr.y -= d/2.;
|
|
1579
|
+
pfr.y *= d;
|
|
1580
|
+
pfr.y += d/2.;
|
|
1581
|
+
}
|
|
1582
|
+
float size = mix(1.0, depth, 1.-progress);
|
|
1583
|
+
pto = (p + vec2(-0.5, -0.5)) * vec2(size, size) + vec2(0.5, 0.5);
|
|
1584
|
+
if (inBounds(pfr)) {
|
|
1585
|
+
return getFromColor(pfr);
|
|
1586
|
+
}
|
|
1587
|
+
else if (inBounds(pto)) {
|
|
1588
|
+
return getToColor(pto);
|
|
1589
|
+
}
|
|
1590
|
+
else {
|
|
1591
|
+
return bgColor(p, pto);
|
|
1592
|
+
}
|
|
1593
|
+
}
|
|
1594
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"fade",paramsTypes:{},defaultParams:{},glsl:`// author: gre
|
|
1595
|
+
// license: MIT
|
|
1596
|
+
|
|
1597
|
+
vec4 transition (vec2 uv) {
|
|
1598
|
+
return mix(
|
|
1599
|
+
getFromColor(uv),
|
|
1600
|
+
getToColor(uv),
|
|
1601
|
+
progress
|
|
1602
|
+
);
|
|
1603
|
+
}
|
|
1604
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"fadecolor",paramsTypes:{color:"vec3",colorPhase:"float"},defaultParams:{color:[0,0,0],colorPhase:.4},glsl:`// author: gre
|
|
1605
|
+
// License: MIT
|
|
1606
|
+
uniform vec3 color;// = vec3(0.0)
|
|
1607
|
+
uniform float colorPhase/* = 0.4 */; // if 0.0, there is no black phase, if 0.9, the black phase is very important
|
|
1608
|
+
vec4 transition (vec2 uv) {
|
|
1609
|
+
return mix(
|
|
1610
|
+
mix(vec4(color, 1.0), getFromColor(uv), smoothstep(1.0-colorPhase, 0.0, progress)),
|
|
1611
|
+
mix(vec4(color, 1.0), getToColor(uv), smoothstep( colorPhase, 1.0, progress)),
|
|
1612
|
+
progress);
|
|
1613
|
+
}
|
|
1614
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"fadegrayscale",paramsTypes:{intensity:"float"},defaultParams:{intensity:.3},glsl:`// Author: gre
|
|
1615
|
+
// License: MIT
|
|
1616
|
+
|
|
1617
|
+
uniform float intensity; // = 0.3; // if 0.0, the image directly turn grayscale, if 0.9, the grayscale transition phase is very important
|
|
1618
|
+
|
|
1619
|
+
vec3 grayscale (vec3 color) {
|
|
1620
|
+
return vec3(0.2126*color.r + 0.7152*color.g + 0.0722*color.b);
|
|
1621
|
+
}
|
|
1622
|
+
|
|
1623
|
+
vec4 transition (vec2 uv) {
|
|
1624
|
+
vec4 fc = getFromColor(uv);
|
|
1625
|
+
vec4 tc = getToColor(uv);
|
|
1626
|
+
return mix(
|
|
1627
|
+
mix(vec4(grayscale(fc.rgb), 1.0), fc, smoothstep(1.0-intensity, 0.0, progress)),
|
|
1628
|
+
mix(vec4(grayscale(tc.rgb), 1.0), tc, smoothstep( intensity, 1.0, progress)),
|
|
1629
|
+
progress);
|
|
1630
|
+
}
|
|
1631
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"flyeye",paramsTypes:{size:"float",zoom:"float",colorSeparation:"float"},defaultParams:{size:.04,zoom:50,colorSeparation:.3},glsl:`// Author: gre
|
|
1632
|
+
// License: MIT
|
|
1633
|
+
uniform float size; // = 0.04
|
|
1634
|
+
uniform float zoom; // = 50.0
|
|
1635
|
+
uniform float colorSeparation; // = 0.3
|
|
1636
|
+
|
|
1637
|
+
vec4 transition(vec2 p) {
|
|
1638
|
+
float inv = 1. - progress;
|
|
1639
|
+
vec2 disp = size*vec2(cos(zoom*p.x), sin(zoom*p.y));
|
|
1640
|
+
vec4 texTo = getToColor(p + inv*disp);
|
|
1641
|
+
vec4 texFrom = vec4(
|
|
1642
|
+
getFromColor(p + progress*disp*(1.0 - colorSeparation)).r,
|
|
1643
|
+
getFromColor(p + progress*disp).g,
|
|
1644
|
+
getFromColor(p + progress*disp*(1.0 + colorSeparation)).b,
|
|
1645
|
+
1.0);
|
|
1646
|
+
return texTo*progress + texFrom*inv;
|
|
1647
|
+
}
|
|
1648
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"heart",paramsTypes:{},defaultParams:{},glsl:`// Author: gre
|
|
1649
|
+
// License: MIT
|
|
1650
|
+
|
|
1651
|
+
float inHeart (vec2 p, vec2 center, float size) {
|
|
1652
|
+
if (size==0.0) return 0.0;
|
|
1653
|
+
vec2 o = (p-center)/(1.6*size);
|
|
1654
|
+
float a = o.x*o.x+o.y*o.y-0.3;
|
|
1655
|
+
return step(a*a*a, o.x*o.x*o.y*o.y*o.y);
|
|
1656
|
+
}
|
|
1657
|
+
vec4 transition (vec2 uv) {
|
|
1658
|
+
return mix(
|
|
1659
|
+
getFromColor(uv),
|
|
1660
|
+
getToColor(uv),
|
|
1661
|
+
inHeart(uv, vec2(0.5, 0.4), progress)
|
|
1662
|
+
);
|
|
1663
|
+
}
|
|
1664
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"hexagonalize",paramsTypes:{steps:"int",horizontalHexagons:"float"},defaultParams:{steps:50,horizontalHexagons:20},glsl:`// Author: Fernando Kuteken
|
|
1665
|
+
// License: MIT
|
|
1666
|
+
// Hexagonal math from: http://www.redblobgames.com/grids/hexagons/
|
|
1667
|
+
|
|
1668
|
+
uniform int steps; // = 50;
|
|
1669
|
+
uniform float horizontalHexagons; //= 20;
|
|
1670
|
+
|
|
1671
|
+
struct Hexagon {
|
|
1672
|
+
float q;
|
|
1673
|
+
float r;
|
|
1674
|
+
float s;
|
|
1675
|
+
};
|
|
1676
|
+
|
|
1677
|
+
Hexagon createHexagon(float q, float r){
|
|
1678
|
+
Hexagon hex;
|
|
1679
|
+
hex.q = q;
|
|
1680
|
+
hex.r = r;
|
|
1681
|
+
hex.s = -q - r;
|
|
1682
|
+
return hex;
|
|
1683
|
+
}
|
|
1684
|
+
|
|
1685
|
+
Hexagon roundHexagon(Hexagon hex){
|
|
1686
|
+
|
|
1687
|
+
float q = floor(hex.q + 0.5);
|
|
1688
|
+
float r = floor(hex.r + 0.5);
|
|
1689
|
+
float s = floor(hex.s + 0.5);
|
|
1690
|
+
|
|
1691
|
+
float deltaQ = abs(q - hex.q);
|
|
1692
|
+
float deltaR = abs(r - hex.r);
|
|
1693
|
+
float deltaS = abs(s - hex.s);
|
|
1694
|
+
|
|
1695
|
+
if (deltaQ > deltaR && deltaQ > deltaS)
|
|
1696
|
+
q = -r - s;
|
|
1697
|
+
else if (deltaR > deltaS)
|
|
1698
|
+
r = -q - s;
|
|
1699
|
+
else
|
|
1700
|
+
s = -q - r;
|
|
1701
|
+
|
|
1702
|
+
return createHexagon(q, r);
|
|
1703
|
+
}
|
|
1704
|
+
|
|
1705
|
+
Hexagon hexagonFromPoint(vec2 point, float size) {
|
|
1706
|
+
|
|
1707
|
+
point.y /= ratio;
|
|
1708
|
+
point = (point - 0.5) / size;
|
|
1709
|
+
|
|
1710
|
+
float q = (sqrt(3.0) / 3.0) * point.x + (-1.0 / 3.0) * point.y;
|
|
1711
|
+
float r = 0.0 * point.x + 2.0 / 3.0 * point.y;
|
|
1712
|
+
|
|
1713
|
+
Hexagon hex = createHexagon(q, r);
|
|
1714
|
+
return roundHexagon(hex);
|
|
1715
|
+
|
|
1716
|
+
}
|
|
1717
|
+
|
|
1718
|
+
vec2 pointFromHexagon(Hexagon hex, float size) {
|
|
1719
|
+
|
|
1720
|
+
float x = (sqrt(3.0) * hex.q + (sqrt(3.0) / 2.0) * hex.r) * size + 0.5;
|
|
1721
|
+
float y = (0.0 * hex.q + (3.0 / 2.0) * hex.r) * size + 0.5;
|
|
1722
|
+
|
|
1723
|
+
return vec2(x, y * ratio);
|
|
1724
|
+
}
|
|
1725
|
+
|
|
1726
|
+
vec4 transition (vec2 uv) {
|
|
1727
|
+
|
|
1728
|
+
float dist = 2.0 * min(progress, 1.0 - progress);
|
|
1729
|
+
dist = steps > 0 ? ceil(dist * float(steps)) / float(steps) : dist;
|
|
1730
|
+
|
|
1731
|
+
float size = (sqrt(3.0) / 3.0) * dist / horizontalHexagons;
|
|
1732
|
+
|
|
1733
|
+
vec2 point = dist > 0.0 ? pointFromHexagon(hexagonFromPoint(uv, size), size) : uv;
|
|
1734
|
+
|
|
1735
|
+
return mix(getFromColor(point), getToColor(point), progress);
|
|
1736
|
+
|
|
1737
|
+
}
|
|
1738
|
+
`,author:"Fernando Kuteken",license:"MIT",createdAt:"Tue, 30 May 2017 21:55:47 -0300",updatedAt:"Tue, 30 May 2017 21:55:47 -0300"},{name:"kaleidoscope",paramsTypes:{speed:"float",angle:"float",power:"float"},defaultParams:{speed:1,angle:1,power:1.5},glsl:`// Author: nwoeanhinnogaehr
|
|
1739
|
+
// License: MIT
|
|
1740
|
+
|
|
1741
|
+
uniform float speed; // = 1.0;
|
|
1742
|
+
uniform float angle; // = 1.0;
|
|
1743
|
+
uniform float power; // = 1.5;
|
|
1744
|
+
|
|
1745
|
+
vec4 transition(vec2 uv) {
|
|
1746
|
+
vec2 p = uv.xy / vec2(1.0).xy;
|
|
1747
|
+
vec2 q = p;
|
|
1748
|
+
float t = pow(progress, power)*speed;
|
|
1749
|
+
p = p -0.5;
|
|
1750
|
+
for (int i = 0; i < 7; i++) {
|
|
1751
|
+
p = vec2(sin(t)*p.x + cos(t)*p.y, sin(t)*p.y - cos(t)*p.x);
|
|
1752
|
+
t += angle;
|
|
1753
|
+
p = abs(mod(p, 2.0) - 1.0);
|
|
1754
|
+
}
|
|
1755
|
+
abs(mod(p, 1.0));
|
|
1756
|
+
return mix(
|
|
1757
|
+
mix(getFromColor(q), getToColor(q), progress),
|
|
1758
|
+
mix(getFromColor(p), getToColor(p), progress), 1.0 - 2.0*abs(progress - 0.5));
|
|
1759
|
+
}
|
|
1760
|
+
`,author:"nwoeanhinnogaehr",license:"MIT",createdAt:"Wed, 31 May 2017 21:48:26 -0400",updatedAt:"Wed, 31 May 2017 21:48:26 -0400"},{name:"luma",paramsTypes:{luma:"sampler2D"},defaultParams:{luma:null},glsl:`// Author: gre
|
|
1761
|
+
// License: MIT
|
|
1762
|
+
|
|
1763
|
+
uniform sampler2D luma;
|
|
1764
|
+
|
|
1765
|
+
vec4 transition(vec2 uv) {
|
|
1766
|
+
return mix(
|
|
1767
|
+
getToColor(uv),
|
|
1768
|
+
getFromColor(uv),
|
|
1769
|
+
step(progress, texture2D(luma, uv).r)
|
|
1770
|
+
);
|
|
1771
|
+
}
|
|
1772
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"luminance_melt",paramsTypes:{direction:"bool",l_threshold:"float",above:"bool"},defaultParams:{direction:!0,l_threshold:.8,above:!1},glsl:`// Author: 0gust1
|
|
1773
|
+
// License: MIT
|
|
1774
|
+
//My own first transition \u2014 based on crosshatch code (from pthrasher), using simplex noise formula (copied and pasted)
|
|
1775
|
+
//-> cooler with high contrasted images (isolated dark subject on light background f.e.)
|
|
1776
|
+
//TODO : try to rebase it on DoomTransition (from zeh)?
|
|
1777
|
+
//optimizations :
|
|
1778
|
+
//luminance (see http://stackoverflow.com/questions/596216/formula-to-determine-brightness-of-rgb-color#answer-596241)
|
|
1779
|
+
// Y = (R+R+B+G+G+G)/6
|
|
1780
|
+
//or Y = (R+R+R+B+G+G+G+G)>>3
|
|
1781
|
+
|
|
1782
|
+
|
|
1783
|
+
//direction of movement : 0 : up, 1, down
|
|
1784
|
+
uniform bool direction; // = 1
|
|
1785
|
+
//luminance threshold
|
|
1786
|
+
uniform float l_threshold; // = 0.8
|
|
1787
|
+
//does the movement takes effect above or below luminance threshold ?
|
|
1788
|
+
uniform bool above; // = false
|
|
1789
|
+
|
|
1790
|
+
|
|
1791
|
+
//Random function borrowed from everywhere
|
|
1792
|
+
float rand(vec2 co){
|
|
1793
|
+
return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);
|
|
1794
|
+
}
|
|
1795
|
+
|
|
1796
|
+
|
|
1797
|
+
// Simplex noise :
|
|
1798
|
+
// Description : Array and textureless GLSL 2D simplex noise function.
|
|
1799
|
+
// Author : Ian McEwan, Ashima Arts.
|
|
1800
|
+
// Maintainer : ijm
|
|
1801
|
+
// Lastmod : 20110822 (ijm)
|
|
1802
|
+
// License : MIT
|
|
1803
|
+
// 2011 Ashima Arts. All rights reserved.
|
|
1804
|
+
// Distributed under the MIT License. See LICENSE file.
|
|
1805
|
+
// https://github.com/ashima/webgl-noise
|
|
1806
|
+
//
|
|
1807
|
+
|
|
1808
|
+
vec3 mod289(vec3 x) {
|
|
1809
|
+
return x - floor(x * (1.0 / 289.0)) * 289.0;
|
|
1810
|
+
}
|
|
1811
|
+
|
|
1812
|
+
vec2 mod289(vec2 x) {
|
|
1813
|
+
return x - floor(x * (1.0 / 289.0)) * 289.0;
|
|
1814
|
+
}
|
|
1815
|
+
|
|
1816
|
+
vec3 permute(vec3 x) {
|
|
1817
|
+
return mod289(((x*34.0)+1.0)*x);
|
|
1818
|
+
}
|
|
1819
|
+
|
|
1820
|
+
float snoise(vec2 v)
|
|
1821
|
+
{
|
|
1822
|
+
const vec4 C = vec4(0.211324865405187, // (3.0-sqrt(3.0))/6.0
|
|
1823
|
+
0.366025403784439, // 0.5*(sqrt(3.0)-1.0)
|
|
1824
|
+
-0.577350269189626, // -1.0 + 2.0 * C.x
|
|
1825
|
+
0.024390243902439); // 1.0 / 41.0
|
|
1826
|
+
// First corner
|
|
1827
|
+
vec2 i = floor(v + dot(v, C.yy) );
|
|
1828
|
+
vec2 x0 = v - i + dot(i, C.xx);
|
|
1829
|
+
|
|
1830
|
+
// Other corners
|
|
1831
|
+
vec2 i1;
|
|
1832
|
+
//i1.x = step( x0.y, x0.x ); // x0.x > x0.y ? 1.0 : 0.0
|
|
1833
|
+
//i1.y = 1.0 - i1.x;
|
|
1834
|
+
i1 = (x0.x > x0.y) ? vec2(1.0, 0.0) : vec2(0.0, 1.0);
|
|
1835
|
+
// x0 = x0 - 0.0 + 0.0 * C.xx ;
|
|
1836
|
+
// x1 = x0 - i1 + 1.0 * C.xx ;
|
|
1837
|
+
// x2 = x0 - 1.0 + 2.0 * C.xx ;
|
|
1838
|
+
vec4 x12 = x0.xyxy + C.xxzz;
|
|
1839
|
+
x12.xy -= i1;
|
|
1840
|
+
|
|
1841
|
+
// Permutations
|
|
1842
|
+
i = mod289(i); // Avoid truncation effects in permutation
|
|
1843
|
+
vec3 p = permute( permute( i.y + vec3(0.0, i1.y, 1.0 ))
|
|
1844
|
+
+ i.x + vec3(0.0, i1.x, 1.0 ));
|
|
1845
|
+
|
|
1846
|
+
vec3 m = max(0.5 - vec3(dot(x0,x0), dot(x12.xy,x12.xy), dot(x12.zw,x12.zw)), 0.0);
|
|
1847
|
+
m = m*m ;
|
|
1848
|
+
m = m*m ;
|
|
1849
|
+
|
|
1850
|
+
// Gradients: 41 points uniformly over a line, mapped onto a diamond.
|
|
1851
|
+
// The ring size 17*17 = 289 is close to a multiple of 41 (41*7 = 287)
|
|
1852
|
+
|
|
1853
|
+
vec3 x = 2.0 * fract(p * C.www) - 1.0;
|
|
1854
|
+
vec3 h = abs(x) - 0.5;
|
|
1855
|
+
vec3 ox = floor(x + 0.5);
|
|
1856
|
+
vec3 a0 = x - ox;
|
|
1857
|
+
|
|
1858
|
+
// Normalise gradients implicitly by scaling m
|
|
1859
|
+
// Approximation of: m *= inversesqrt( a0*a0 + h*h );
|
|
1860
|
+
m *= 1.79284291400159 - 0.85373472095314 * ( a0*a0 + h*h );
|
|
1861
|
+
|
|
1862
|
+
// Compute final noise value at P
|
|
1863
|
+
vec3 g;
|
|
1864
|
+
g.x = a0.x * x0.x + h.x * x0.y;
|
|
1865
|
+
g.yz = a0.yz * x12.xz + h.yz * x12.yw;
|
|
1866
|
+
return 130.0 * dot(m, g);
|
|
1867
|
+
}
|
|
1868
|
+
|
|
1869
|
+
// Simplex noise -- end
|
|
1870
|
+
|
|
1871
|
+
float luminance(vec4 color){
|
|
1872
|
+
//(0.299*R + 0.587*G + 0.114*B)
|
|
1873
|
+
return color.r*0.299+color.g*0.587+color.b*0.114;
|
|
1874
|
+
}
|
|
1875
|
+
|
|
1876
|
+
vec2 center = vec2(1.0, direction);
|
|
1877
|
+
|
|
1878
|
+
vec4 transition(vec2 uv) {
|
|
1879
|
+
vec2 p = uv.xy / vec2(1.0).xy;
|
|
1880
|
+
if (progress == 0.0) {
|
|
1881
|
+
return getFromColor(p);
|
|
1882
|
+
} else if (progress == 1.0) {
|
|
1883
|
+
return getToColor(p);
|
|
1884
|
+
} else {
|
|
1885
|
+
float x = progress;
|
|
1886
|
+
float dist = distance(center, p)- progress*exp(snoise(vec2(p.x, 0.0)));
|
|
1887
|
+
float r = x - rand(vec2(p.x, 0.1));
|
|
1888
|
+
float m;
|
|
1889
|
+
if(above){
|
|
1890
|
+
m = dist <= r && luminance(getFromColor(p))>l_threshold ? 1.0 : (progress*progress*progress);
|
|
1891
|
+
}
|
|
1892
|
+
else{
|
|
1893
|
+
m = dist <= r && luminance(getFromColor(p))<l_threshold ? 1.0 : (progress*progress*progress);
|
|
1894
|
+
}
|
|
1895
|
+
return mix(getFromColor(p), getToColor(p), m);
|
|
1896
|
+
}
|
|
1897
|
+
}
|
|
1898
|
+
`,author:"0gust1",license:"MIT",createdAt:"Wed, 24 Jan 2018 19:02:32 +0100",updatedAt:"Wed, 24 Jan 2018 19:02:32 +0100"},{name:"morph",paramsTypes:{strength:"float"},defaultParams:{strength:.1},glsl:`// Author: paniq
|
|
1899
|
+
// License: MIT
|
|
1900
|
+
uniform float strength; // = 0.1
|
|
1901
|
+
|
|
1902
|
+
vec4 transition(vec2 p) {
|
|
1903
|
+
vec4 ca = getFromColor(p);
|
|
1904
|
+
vec4 cb = getToColor(p);
|
|
1905
|
+
|
|
1906
|
+
vec2 oa = (((ca.rg+ca.b)*0.5)*2.0-1.0);
|
|
1907
|
+
vec2 ob = (((cb.rg+cb.b)*0.5)*2.0-1.0);
|
|
1908
|
+
vec2 oc = mix(oa,ob,0.5)*strength;
|
|
1909
|
+
|
|
1910
|
+
float w0 = progress;
|
|
1911
|
+
float w1 = 1.0-w0;
|
|
1912
|
+
return mix(getFromColor(p+oc*w0), getToColor(p-oc*w1), progress);
|
|
1913
|
+
}
|
|
1914
|
+
`,author:"paniq",license:"MIT",createdAt:"Thu, 10 Aug 2017 00:27:36 +0200",updatedAt:"Thu, 10 Aug 2017 00:32:01 +0200"},{name:"multiply_blend",paramsTypes:{},defaultParams:{},glsl:`// Author: Fernando Kuteken
|
|
1915
|
+
// License: MIT
|
|
1916
|
+
|
|
1917
|
+
vec4 blend(vec4 a, vec4 b) {
|
|
1918
|
+
return a * b;
|
|
1919
|
+
}
|
|
1920
|
+
|
|
1921
|
+
vec4 transition (vec2 uv) {
|
|
1922
|
+
|
|
1923
|
+
vec4 blended = blend(getFromColor(uv), getToColor(uv));
|
|
1924
|
+
|
|
1925
|
+
if (progress < 0.5)
|
|
1926
|
+
return mix(getFromColor(uv), blended, 2.0 * progress);
|
|
1927
|
+
else
|
|
1928
|
+
return mix(blended, getToColor(uv), 2.0 * progress - 1.0);
|
|
1929
|
+
}
|
|
1930
|
+
|
|
1931
|
+
`,author:"Fernando Kuteken",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"perlin",paramsTypes:{scale:"float",smoothness:"float",seed:"float"},defaultParams:{scale:4,smoothness:.01,seed:12.9898},glsl:`// Author: Rich Harris
|
|
1932
|
+
// License: MIT
|
|
1933
|
+
|
|
1934
|
+
#ifdef GL_ES
|
|
1935
|
+
precision mediump float;
|
|
1936
|
+
#endif
|
|
1937
|
+
|
|
1938
|
+
uniform float scale; // = 4.0
|
|
1939
|
+
uniform float smoothness; // = 0.01
|
|
1940
|
+
|
|
1941
|
+
uniform float seed; // = 12.9898
|
|
1942
|
+
|
|
1943
|
+
// http://byteblacksmith.com/improvements-to-the-canonical-one-liner-glsl-rand-for-opengl-es-2-0/
|
|
1944
|
+
float random(vec2 co)
|
|
1945
|
+
{
|
|
1946
|
+
highp float a = seed;
|
|
1947
|
+
highp float b = 78.233;
|
|
1948
|
+
highp float c = 43758.5453;
|
|
1949
|
+
highp float dt= dot(co.xy ,vec2(a,b));
|
|
1950
|
+
highp float sn= mod(dt,3.14);
|
|
1951
|
+
return fract(sin(sn) * c);
|
|
1952
|
+
}
|
|
1953
|
+
|
|
1954
|
+
// 2D Noise based on Morgan McGuire @morgan3d
|
|
1955
|
+
// https://www.shadertoy.com/view/4dS3Wd
|
|
1956
|
+
float noise (in vec2 st) {
|
|
1957
|
+
vec2 i = floor(st);
|
|
1958
|
+
vec2 f = fract(st);
|
|
1959
|
+
|
|
1960
|
+
// Four corners in 2D of a tile
|
|
1961
|
+
float a = random(i);
|
|
1962
|
+
float b = random(i + vec2(1.0, 0.0));
|
|
1963
|
+
float c = random(i + vec2(0.0, 1.0));
|
|
1964
|
+
float d = random(i + vec2(1.0, 1.0));
|
|
1965
|
+
|
|
1966
|
+
// Smooth Interpolation
|
|
1967
|
+
|
|
1968
|
+
// Cubic Hermine Curve. Same as SmoothStep()
|
|
1969
|
+
vec2 u = f*f*(3.0-2.0*f);
|
|
1970
|
+
// u = smoothstep(0.,1.,f);
|
|
1971
|
+
|
|
1972
|
+
// Mix 4 coorners porcentages
|
|
1973
|
+
return mix(a, b, u.x) +
|
|
1974
|
+
(c - a)* u.y * (1.0 - u.x) +
|
|
1975
|
+
(d - b) * u.x * u.y;
|
|
1976
|
+
}
|
|
1977
|
+
|
|
1978
|
+
vec4 transition (vec2 uv) {
|
|
1979
|
+
vec4 from = getFromColor(uv);
|
|
1980
|
+
vec4 to = getToColor(uv);
|
|
1981
|
+
float n = noise(uv * scale);
|
|
1982
|
+
|
|
1983
|
+
float p = mix(-smoothness, 1.0 + smoothness, progress);
|
|
1984
|
+
float lower = p - smoothness;
|
|
1985
|
+
float higher = p + smoothness;
|
|
1986
|
+
|
|
1987
|
+
float q = smoothstep(lower, higher, n);
|
|
1988
|
+
|
|
1989
|
+
return mix(
|
|
1990
|
+
from,
|
|
1991
|
+
to,
|
|
1992
|
+
1.0 - q
|
|
1993
|
+
);
|
|
1994
|
+
}
|
|
1995
|
+
`,author:"Rich Harris",license:"MIT",createdAt:"Tue, 23 Jan 2018 21:35:10 -0500",updatedAt:"Wed, 24 Jan 2018 07:35:04 -0500"},{name:"pinwheel",paramsTypes:{speed:"float"},defaultParams:{speed:2},glsl:`// Author: Mr Speaker
|
|
1996
|
+
// License: MIT
|
|
1997
|
+
|
|
1998
|
+
uniform float speed; // = 2.0;
|
|
1999
|
+
|
|
2000
|
+
vec4 transition(vec2 uv) {
|
|
2001
|
+
|
|
2002
|
+
vec2 p = uv.xy / vec2(1.0).xy;
|
|
2003
|
+
|
|
2004
|
+
float circPos = atan(p.y - 0.5, p.x - 0.5) + progress * speed;
|
|
2005
|
+
float modPos = mod(circPos, 3.1415 / 4.);
|
|
2006
|
+
float signed = sign(progress - modPos);
|
|
2007
|
+
|
|
2008
|
+
return mix(getToColor(p), getFromColor(p), step(signed, 0.5));
|
|
2009
|
+
|
|
2010
|
+
}
|
|
2011
|
+
`,author:"Mr Speaker",license:"MIT",createdAt:"Tue, 30 May 2017 09:04:31 -0400",updatedAt:"Tue, 30 May 2017 09:04:31 -0400"},{name:"pixelize",paramsTypes:{squaresMin:"ivec2",steps:"int"},defaultParams:{squaresMin:[20,20],steps:50},glsl:`// Author: gre
|
|
2012
|
+
// License: MIT
|
|
2013
|
+
// forked from https://gist.github.com/benraziel/c528607361d90a072e98
|
|
2014
|
+
|
|
2015
|
+
uniform ivec2 squaresMin/* = ivec2(20) */; // minimum number of squares (when the effect is at its higher level)
|
|
2016
|
+
uniform int steps /* = 50 */; // zero disable the stepping
|
|
2017
|
+
|
|
2018
|
+
float d = min(progress, 1.0 - progress);
|
|
2019
|
+
float dist = steps>0 ? ceil(d * float(steps)) / float(steps) : d;
|
|
2020
|
+
vec2 squareSize = 2.0 * dist / vec2(squaresMin);
|
|
2021
|
+
|
|
2022
|
+
vec4 transition(vec2 uv) {
|
|
2023
|
+
vec2 p = dist>0.0 ? (floor(uv / squareSize) + 0.5) * squareSize : uv;
|
|
2024
|
+
return mix(getFromColor(p), getToColor(p), progress);
|
|
2025
|
+
}
|
|
2026
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Wed, 31 May 2017 10:58:26 +0200"},{name:"polar_function",paramsTypes:{segments:"int"},defaultParams:{segments:5},glsl:`// Author: Fernando Kuteken
|
|
2027
|
+
// License: MIT
|
|
2028
|
+
|
|
2029
|
+
#define PI 3.14159265359
|
|
2030
|
+
|
|
2031
|
+
uniform int segments; // = 5;
|
|
2032
|
+
|
|
2033
|
+
vec4 transition (vec2 uv) {
|
|
2034
|
+
|
|
2035
|
+
float angle = atan(uv.y - 0.5, uv.x - 0.5) - 0.5 * PI;
|
|
2036
|
+
float normalized = (angle + 1.5 * PI) * (2.0 * PI);
|
|
2037
|
+
|
|
2038
|
+
float radius = (cos(float(segments) * angle) + 4.0) / 4.0;
|
|
2039
|
+
float difference = length(uv - vec2(0.5, 0.5));
|
|
2040
|
+
|
|
2041
|
+
if (difference > radius * progress)
|
|
2042
|
+
return getFromColor(uv);
|
|
2043
|
+
else
|
|
2044
|
+
return getToColor(uv);
|
|
2045
|
+
}
|
|
2046
|
+
`,author:"Fernando Kuteken",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"randomsquares",paramsTypes:{size:"ivec2",smoothness:"float"},defaultParams:{size:[10,10],smoothness:.5},glsl:`// Author: gre
|
|
2047
|
+
// License: MIT
|
|
2048
|
+
|
|
2049
|
+
uniform ivec2 size; // = ivec2(10, 10)
|
|
2050
|
+
uniform float smoothness; // = 0.5
|
|
2051
|
+
|
|
2052
|
+
float rand (vec2 co) {
|
|
2053
|
+
return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);
|
|
2054
|
+
}
|
|
2055
|
+
|
|
2056
|
+
vec4 transition(vec2 p) {
|
|
2057
|
+
float r = rand(floor(vec2(size) * p));
|
|
2058
|
+
float m = smoothstep(0.0, -smoothness, r - (progress * (1.0 + smoothness)));
|
|
2059
|
+
return mix(getFromColor(p), getToColor(p), m);
|
|
2060
|
+
}
|
|
2061
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"ripple",paramsTypes:{amplitude:"float",speed:"float"},defaultParams:{amplitude:100,speed:50},glsl:`// Author: gre
|
|
2062
|
+
// License: MIT
|
|
2063
|
+
uniform float amplitude; // = 100.0
|
|
2064
|
+
uniform float speed; // = 50.0
|
|
2065
|
+
|
|
2066
|
+
vec4 transition (vec2 uv) {
|
|
2067
|
+
vec2 dir = uv - vec2(.5);
|
|
2068
|
+
float dist = length(dir);
|
|
2069
|
+
vec2 offset = dir * (sin(progress * dist * amplitude - progress * speed) + .5) / 30.;
|
|
2070
|
+
return mix(
|
|
2071
|
+
getFromColor(uv + offset),
|
|
2072
|
+
getToColor(uv),
|
|
2073
|
+
smoothstep(0.2, 1.0, progress)
|
|
2074
|
+
);
|
|
2075
|
+
}
|
|
2076
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 15:15:27 +0200",updatedAt:"Tue, 30 May 2017 15:15:27 +0200"},{name:"rotate_scale_fade",paramsTypes:{center:"vec2",rotations:"float",scale:"float",backColor:"vec4"},defaultParams:{center:[.5,.5],rotations:1,scale:8,backColor:[.15,.15,.15,1]},glsl:`// Author: Fernando Kuteken
|
|
2077
|
+
// License: MIT
|
|
2078
|
+
|
|
2079
|
+
#define PI 3.14159265359
|
|
2080
|
+
|
|
2081
|
+
uniform vec2 center; // = vec2(0.5, 0.5);
|
|
2082
|
+
uniform float rotations; // = 1;
|
|
2083
|
+
uniform float scale; // = 8;
|
|
2084
|
+
uniform vec4 backColor; // = vec4(0.15, 0.15, 0.15, 1.0);
|
|
2085
|
+
|
|
2086
|
+
vec4 transition (vec2 uv) {
|
|
2087
|
+
|
|
2088
|
+
vec2 difference = uv - center;
|
|
2089
|
+
vec2 dir = normalize(difference);
|
|
2090
|
+
float dist = length(difference);
|
|
2091
|
+
|
|
2092
|
+
float angle = 2.0 * PI * rotations * progress;
|
|
2093
|
+
|
|
2094
|
+
float c = cos(angle);
|
|
2095
|
+
float s = sin(angle);
|
|
2096
|
+
|
|
2097
|
+
float currentScale = mix(scale, 1.0, 2.0 * abs(progress - 0.5));
|
|
2098
|
+
|
|
2099
|
+
vec2 rotatedDir = vec2(dir.x * c - dir.y * s, dir.x * s + dir.y * c);
|
|
2100
|
+
vec2 rotatedUv = center + rotatedDir * dist / currentScale;
|
|
2101
|
+
|
|
2102
|
+
if (rotatedUv.x < 0.0 || rotatedUv.x > 1.0 ||
|
|
2103
|
+
rotatedUv.y < 0.0 || rotatedUv.y > 1.0)
|
|
2104
|
+
return backColor;
|
|
2105
|
+
|
|
2106
|
+
return mix(getFromColor(rotatedUv), getToColor(rotatedUv), progress);
|
|
2107
|
+
}
|
|
2108
|
+
`,author:"Fernando Kuteken",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"squareswire",paramsTypes:{squares:"ivec2",direction:"vec2",smoothness:"float"},defaultParams:{squares:[10,10],direction:[1,-.5],smoothness:1.6},glsl:`// Author: gre
|
|
2109
|
+
// License: MIT
|
|
2110
|
+
|
|
2111
|
+
uniform ivec2 squares;// = ivec2(10,10)
|
|
2112
|
+
uniform vec2 direction;// = vec2(1.0, -0.5)
|
|
2113
|
+
uniform float smoothness; // = 1.6
|
|
2114
|
+
|
|
2115
|
+
const vec2 center = vec2(0.5, 0.5);
|
|
2116
|
+
vec4 transition (vec2 p) {
|
|
2117
|
+
vec2 v = normalize(direction);
|
|
2118
|
+
v /= abs(v.x)+abs(v.y);
|
|
2119
|
+
float d = v.x * center.x + v.y * center.y;
|
|
2120
|
+
float offset = smoothness;
|
|
2121
|
+
float pr = smoothstep(-offset, 0.0, v.x * p.x + v.y * p.y - (d-0.5+progress*(1.+offset)));
|
|
2122
|
+
vec2 squarep = fract(p*vec2(squares));
|
|
2123
|
+
vec2 squaremin = vec2(pr/2.0);
|
|
2124
|
+
vec2 squaremax = vec2(1.0 - pr/2.0);
|
|
2125
|
+
float a = (1.0 - step(progress, 0.0)) * step(squaremin.x, squarep.x) * step(squaremin.y, squarep.y) * step(squarep.x, squaremax.x) * step(squarep.y, squaremax.y);
|
|
2126
|
+
return mix(getFromColor(p), getToColor(p), a);
|
|
2127
|
+
}
|
|
2128
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"squeeze",paramsTypes:{colorSeparation:"float"},defaultParams:{colorSeparation:.04},glsl:`// Author: gre
|
|
2129
|
+
// License: MIT
|
|
2130
|
+
|
|
2131
|
+
uniform float colorSeparation; // = 0.04
|
|
2132
|
+
|
|
2133
|
+
vec4 transition (vec2 uv) {
|
|
2134
|
+
float y = 0.5 + (uv.y-0.5) / (1.0-progress);
|
|
2135
|
+
if (y < 0.0 || y > 1.0) {
|
|
2136
|
+
return getToColor(uv);
|
|
2137
|
+
}
|
|
2138
|
+
else {
|
|
2139
|
+
vec2 fp = vec2(uv.x, y);
|
|
2140
|
+
vec2 off = progress * vec2(0.0, colorSeparation);
|
|
2141
|
+
vec4 c = getFromColor(fp);
|
|
2142
|
+
vec4 cn = getFromColor(fp - off);
|
|
2143
|
+
vec4 cp = getFromColor(fp + off);
|
|
2144
|
+
return vec4(cn.r, c.g, cp.b, c.a);
|
|
2145
|
+
}
|
|
2146
|
+
}
|
|
2147
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"swap",paramsTypes:{reflection:"float",perspective:"float",depth:"float"},defaultParams:{reflection:.4,perspective:.2,depth:3},glsl:`// Author: gre
|
|
2148
|
+
// License: MIT
|
|
2149
|
+
// General parameters
|
|
2150
|
+
uniform float reflection; // = 0.4
|
|
2151
|
+
uniform float perspective; // = 0.2
|
|
2152
|
+
uniform float depth; // = 3.0
|
|
2153
|
+
|
|
2154
|
+
const vec4 black = vec4(0.0, 0.0, 0.0, 1.0);
|
|
2155
|
+
const vec2 boundMin = vec2(0.0, 0.0);
|
|
2156
|
+
const vec2 boundMax = vec2(1.0, 1.0);
|
|
2157
|
+
|
|
2158
|
+
bool inBounds (vec2 p) {
|
|
2159
|
+
return all(lessThan(boundMin, p)) && all(lessThan(p, boundMax));
|
|
2160
|
+
}
|
|
2161
|
+
|
|
2162
|
+
vec2 project (vec2 p) {
|
|
2163
|
+
return p * vec2(1.0, -1.2) + vec2(0.0, -0.02);
|
|
2164
|
+
}
|
|
2165
|
+
|
|
2166
|
+
vec4 bgColor (vec2 p, vec2 pfr, vec2 pto) {
|
|
2167
|
+
vec4 c = black;
|
|
2168
|
+
pfr = project(pfr);
|
|
2169
|
+
if (inBounds(pfr)) {
|
|
2170
|
+
c += mix(black, getFromColor(pfr), reflection * mix(1.0, 0.0, pfr.y));
|
|
2171
|
+
}
|
|
2172
|
+
pto = project(pto);
|
|
2173
|
+
if (inBounds(pto)) {
|
|
2174
|
+
c += mix(black, getToColor(pto), reflection * mix(1.0, 0.0, pto.y));
|
|
2175
|
+
}
|
|
2176
|
+
return c;
|
|
2177
|
+
}
|
|
2178
|
+
|
|
2179
|
+
vec4 transition(vec2 p) {
|
|
2180
|
+
vec2 pfr, pto = vec2(-1.);
|
|
2181
|
+
|
|
2182
|
+
float size = mix(1.0, depth, progress);
|
|
2183
|
+
float persp = perspective * progress;
|
|
2184
|
+
pfr = (p + vec2(-0.0, -0.5)) * vec2(size/(1.0-perspective*progress), size/(1.0-size*persp*p.x)) + vec2(0.0, 0.5);
|
|
2185
|
+
|
|
2186
|
+
size = mix(1.0, depth, 1.-progress);
|
|
2187
|
+
persp = perspective * (1.-progress);
|
|
2188
|
+
pto = (p + vec2(-1.0, -0.5)) * vec2(size/(1.0-perspective*(1.0-progress)), size/(1.0-size*persp*(0.5-p.x))) + vec2(1.0, 0.5);
|
|
2189
|
+
|
|
2190
|
+
if (progress < 0.5) {
|
|
2191
|
+
if (inBounds(pfr)) {
|
|
2192
|
+
return getFromColor(pfr);
|
|
2193
|
+
}
|
|
2194
|
+
if (inBounds(pto)) {
|
|
2195
|
+
return getToColor(pto);
|
|
2196
|
+
}
|
|
2197
|
+
}
|
|
2198
|
+
if (inBounds(pto)) {
|
|
2199
|
+
return getToColor(pto);
|
|
2200
|
+
}
|
|
2201
|
+
if (inBounds(pfr)) {
|
|
2202
|
+
return getFromColor(pfr);
|
|
2203
|
+
}
|
|
2204
|
+
return bgColor(p, pfr, pto);
|
|
2205
|
+
}
|
|
2206
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Sun, 18 Feb 2018 17:45:50 +0100"},{name:"undulatingBurnOut",paramsTypes:{smoothness:"float",center:"vec2",color:"vec3"},defaultParams:{smoothness:.03,center:[.5,.5],color:[0,0,0]},glsl:`// License: MIT
|
|
2207
|
+
// Author: pthrasher
|
|
2208
|
+
// adapted by gre from https://gist.github.com/pthrasher/8e6226b215548ba12734
|
|
2209
|
+
|
|
2210
|
+
uniform float smoothness; // = 0.03
|
|
2211
|
+
uniform vec2 center; // = vec2(0.5)
|
|
2212
|
+
uniform vec3 color; // = vec3(0.0)
|
|
2213
|
+
|
|
2214
|
+
const float M_PI = 3.14159265358979323846;
|
|
2215
|
+
|
|
2216
|
+
float quadraticInOut(float t) {
|
|
2217
|
+
float p = 2.0 * t * t;
|
|
2218
|
+
return t < 0.5 ? p : -p + (4.0 * t) - 1.0;
|
|
2219
|
+
}
|
|
2220
|
+
|
|
2221
|
+
float getGradient(float r, float dist) {
|
|
2222
|
+
float d = r - dist;
|
|
2223
|
+
return mix(
|
|
2224
|
+
smoothstep(-smoothness, 0.0, r - dist * (1.0 + smoothness)),
|
|
2225
|
+
-1.0 - step(0.005, d),
|
|
2226
|
+
step(-0.005, d) * step(d, 0.01)
|
|
2227
|
+
);
|
|
2228
|
+
}
|
|
2229
|
+
|
|
2230
|
+
float getWave(vec2 p){
|
|
2231
|
+
vec2 _p = p - center; // offset from center
|
|
2232
|
+
float rads = atan(_p.y, _p.x);
|
|
2233
|
+
float degs = degrees(rads) + 180.0;
|
|
2234
|
+
vec2 range = vec2(0.0, M_PI * 30.0);
|
|
2235
|
+
vec2 domain = vec2(0.0, 360.0);
|
|
2236
|
+
float ratio = (M_PI * 30.0) / 360.0;
|
|
2237
|
+
degs = degs * ratio;
|
|
2238
|
+
float x = progress;
|
|
2239
|
+
float magnitude = mix(0.02, 0.09, smoothstep(0.0, 1.0, x));
|
|
2240
|
+
float offset = mix(40.0, 30.0, smoothstep(0.0, 1.0, x));
|
|
2241
|
+
float ease_degs = quadraticInOut(sin(degs));
|
|
2242
|
+
float deg_wave_pos = (ease_degs * magnitude) * sin(x * offset);
|
|
2243
|
+
return x + deg_wave_pos;
|
|
2244
|
+
}
|
|
2245
|
+
|
|
2246
|
+
vec4 transition(vec2 p) {
|
|
2247
|
+
float dist = distance(center, p);
|
|
2248
|
+
float m = getGradient(getWave(p), dist);
|
|
2249
|
+
vec4 cfrom = getFromColor(p);
|
|
2250
|
+
vec4 cto = getToColor(p);
|
|
2251
|
+
return mix(mix(cfrom, cto, m), mix(cfrom, vec4(color, 1.0), 0.75), step(m, -2.0));
|
|
2252
|
+
}
|
|
2253
|
+
`,license:"MIT",author:"pthrasher",createdAt:"Mon, 12 Jun 2017 10:23:37 +0800",updatedAt:"Mon, 12 Jun 2017 10:23:37 +0800"},{name:"wind",paramsTypes:{size:"float"},defaultParams:{size:.2},glsl:`// Author: gre
|
|
2254
|
+
// License: MIT
|
|
2255
|
+
|
|
2256
|
+
// Custom parameters
|
|
2257
|
+
uniform float size; // = 0.2
|
|
2258
|
+
|
|
2259
|
+
float rand (vec2 co) {
|
|
2260
|
+
return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);
|
|
2261
|
+
}
|
|
2262
|
+
|
|
2263
|
+
vec4 transition (vec2 uv) {
|
|
2264
|
+
float r = rand(vec2(0, uv.y));
|
|
2265
|
+
float m = smoothstep(0.0, -size, uv.x*(1.0-size) + size*r - (progress * (1.0 + size)));
|
|
2266
|
+
return mix(
|
|
2267
|
+
getFromColor(uv),
|
|
2268
|
+
getToColor(uv),
|
|
2269
|
+
m
|
|
2270
|
+
);
|
|
2271
|
+
}
|
|
2272
|
+
`,author:"gre",license:"MIT",createdAt:"Tue, 30 May 2017 14:26:44 +0200",updatedAt:"Tue, 30 May 2017 14:26:44 +0200"},{name:"windowblinds",paramsTypes:{},defaultParams:{},glsl:`// Author: Fabien Benetou
|
|
2273
|
+
// License: MIT
|
|
2274
|
+
|
|
2275
|
+
vec4 transition (vec2 uv) {
|
|
2276
|
+
float t = progress;
|
|
2277
|
+
|
|
2278
|
+
if (mod(floor(uv.y*100.*progress),2.)==0.)
|
|
2279
|
+
t*=2.-.5;
|
|
2280
|
+
|
|
2281
|
+
return mix(
|
|
2282
|
+
getFromColor(uv),
|
|
2283
|
+
getToColor(uv),
|
|
2284
|
+
mix(t, progress, smoothstep(0.8, 1.0, progress))
|
|
2285
|
+
);
|
|
2286
|
+
}
|
|
2287
|
+
`,author:"Fabien Benetou",license:"MIT",createdAt:"Wed, 31 May 2017 14:11:48 +0200",updatedAt:"Wed, 31 May 2017 14:11:48 +0200"},{name:"windowslice",paramsTypes:{count:"float",smoothness:"float"},defaultParams:{count:10,smoothness:.5},glsl:`// Author: gre
|
|
2288
|
+
// License: MIT
|
|
2289
|
+
|
|
2290
|
+
uniform float count; // = 10.0
|
|
2291
|
+
uniform float smoothness; // = 0.5
|
|
2292
|
+
|
|
2293
|
+
vec4 transition (vec2 p) {
|
|
2294
|
+
float pr = smoothstep(-smoothness, 0.0, p.x - progress * (1.0 + smoothness));
|
|
2295
|
+
float s = step(pr, fract(count * p.x));
|
|
2296
|
+
return mix(getFromColor(p), getToColor(p), s);
|
|
2297
|
+
}
|
|
2298
|
+
`,author:"gre",license:"MIT",createdAt:"Wed, 28 Mar 2018 17:23:26 +0200",updatedAt:"Wed, 28 Mar 2018 17:23:26 +0200"},{name:"wipeDown",paramsTypes:{},defaultParams:{},glsl:`// Author: Jake Nelson
|
|
2299
|
+
// License: MIT
|
|
2300
|
+
|
|
2301
|
+
vec4 transition(vec2 uv) {
|
|
2302
|
+
vec2 p=uv.xy/vec2(1.0).xy;
|
|
2303
|
+
vec4 a=getFromColor(p);
|
|
2304
|
+
vec4 b=getToColor(p);
|
|
2305
|
+
return mix(a, b, step(1.0-p.y,progress));
|
|
2306
|
+
}
|
|
2307
|
+
`,author:"Jake Nelson",license:"MIT",createdAt:"Wed, 1 Nov 2017 15:26:01 -0500",updatedAt:"Thu, 2 Nov 2017 18:39:26 -0500"},{name:"wipeLeft",paramsTypes:{},defaultParams:{},glsl:`// Author: Jake Nelson
|
|
2308
|
+
// License: MIT
|
|
2309
|
+
|
|
2310
|
+
vec4 transition(vec2 uv) {
|
|
2311
|
+
vec2 p=uv.xy/vec2(1.0).xy;
|
|
2312
|
+
vec4 a=getFromColor(p);
|
|
2313
|
+
vec4 b=getToColor(p);
|
|
2314
|
+
return mix(a, b, step(1.0-p.x,progress));
|
|
2315
|
+
}
|
|
2316
|
+
`,author:"Jake Nelson",license:"MIT",createdAt:"Wed, 1 Nov 2017 15:26:28 -0500",updatedAt:"Fri, 3 Nov 2017 18:03:50 +0100"},{name:"wipeRight",paramsTypes:{},defaultParams:{},glsl:`// Author: Jake Nelson
|
|
2317
|
+
// License: MIT
|
|
2318
|
+
|
|
2319
|
+
vec4 transition(vec2 uv) {
|
|
2320
|
+
vec2 p=uv.xy/vec2(1.0).xy;
|
|
2321
|
+
vec4 a=getFromColor(p);
|
|
2322
|
+
vec4 b=getToColor(p);
|
|
2323
|
+
return mix(a, b, step(0.0+p.x,progress));
|
|
2324
|
+
}
|
|
2325
|
+
`,author:"Jake Nelson",license:"MIT",createdAt:"Wed, 1 Nov 2017 15:27:02 -0500",updatedAt:"Thu, 2 Nov 2017 18:40:22 -0500"},{name:"wipeUp",paramsTypes:{},defaultParams:{},glsl:`// Author: Jake Nelson
|
|
2326
|
+
// License: MIT
|
|
2327
|
+
|
|
2328
|
+
vec4 transition(vec2 uv) {
|
|
2329
|
+
vec2 p=uv.xy/vec2(1.0).xy;
|
|
2330
|
+
vec4 a=getFromColor(p);
|
|
2331
|
+
vec4 b=getToColor(p);
|
|
2332
|
+
return mix(a, b, step(0.0+p.y,progress));
|
|
2333
|
+
}
|
|
2334
|
+
`,author:"Jake Nelson",license:"MIT",createdAt:"Wed, 1 Nov 2017 15:24:36 -0500",updatedAt:"Thu, 2 Nov 2017 18:37:42 -0500"}]});var gt=Object.freeze({eq(r,e){if(r.length!==e.length)return!1;for(let t=0;t<=r.length;t++)if(r.at(t)!==e.at(t))return!1;return!0},random(r){return crypto.getRandomValues(new Uint8Array(r))}});var X=class{lexicon;static lexicons=Object.freeze({base2:{characters:"01"},hex:{characters:"0123456789abcdef"},base36:{characters:"0123456789abcdefghijklmnopqrstuvwxyz"},base58:{characters:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"},base62:{characters:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"},base64url:{negativePrefix:"~",characters:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_"},base64:{characters:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",padding:{character:"=",size:4}}});lookup;negativePrefix;constructor(e){this.lexicon=e,this.lookup=Object.fromEntries([...e.characters].map((t,n)=>[t,n])),this.negativePrefix=e.negativePrefix??"-"}toBytes(e){let t=Math.log2(this.lexicon.characters.length);if(Number.isInteger(t)){let a=0,c=0,l=[];for(let d of e){if(d===this.lexicon.padding?.character)continue;let u=this.lookup[d];if(u===void 0)throw new Error(`Invalid character: ${d}`);for(a=a<<t|u,c+=t;c>=8;)c-=8,l.push(a>>c&255)}return new Uint8Array(l)}let n=0n,o=BigInt(this.lexicon.characters.length),i=!1;e.startsWith(this.negativePrefix)&&(e=e.slice(this.negativePrefix.length),i=!0);for(let a of e){let c=this.lookup[a];if(c===void 0)throw new Error(`Invalid character: ${a}`);n=n*o+BigInt(c)}let s=[];for(;n>0n;)s.unshift(Number(n%256n)),n=n/256n;return new Uint8Array(s)}fromBytes(e){let t=Math.log2(this.lexicon.characters.length);if(Number.isInteger(t)){let s=0,a=0,c="";for(let l of e)for(s=s<<8|l,a+=8;a>=t;){a-=t;let d=s>>a&(1<<t)-1;c+=this.lexicon.characters[d]}if(a>0){let l=s<<t-a&(1<<t)-1;c+=this.lexicon.characters[l]}if(this.lexicon.padding)for(;c.length%this.lexicon.padding.size!==0;)c+=this.lexicon.padding.character;return c}let n=0n;for(let s of e)n=(n<<8n)+BigInt(s);if(n===0n)return this.lexicon.characters[0];let o=BigInt(this.lexicon.characters.length),i="";for(;n>0n;)i=this.lexicon.characters[Number(n%o)]+i,n=n/o;return i}toInteger(e){if(!e)return 0;let t=0n,n=!1,o=BigInt(this.lexicon.characters.length);e.startsWith(this.negativePrefix)&&(e=e.slice(this.negativePrefix.length),n=!0);for(let i of e){let s=this.lookup[i];if(s===void 0)throw new Error(`Invalid character: ${i}`);t=t*o+BigInt(s)}return Number(n?-t:t)}fromInteger(e){e=Math.floor(e);let t=e<0,n=BigInt(t?-e:e);if(n===0n)return this.lexicon.characters[0];let o=BigInt(this.lexicon.characters.length),i="";for(;n>0n;)i=this.lexicon.characters[Number(n%o)]+i,n=n/o;return t?`${this.negativePrefix}${i}`:i}random(e=32){return this.fromBytes(gt.random(e))}};var he=new X(X.lexicons.hex),cl=new X(X.lexicons.base2),ll=new X(X.lexicons.base36),xo=new X(X.lexicons.base58),ul=new X(X.lexicons.base62),dl=new X(X.lexicons.base64),fl=new X(X.lexicons.base64url);var bo=["doz","mar","bin","wan","sam","lit","sig","hid","fid","lis","sog","dir","wac","sab","wis","sib","rig","sol","dop","mod","fog","lid","hop","dar","dor","lor","hod","fol","rin","tog","sil","mir","hol","pas","lac","rov","liv","dal","sat","lib","tab","han","tic","pid","tor","bol","fos","dot","los","dil","for","pil","ram","tir","win","tad","bic","dif","roc","wid","bis","das","mid","lop","ril","nar","dap","mol","san","loc","nov","sit","nid","tip","sic","rop","wit","nat","pan","min","rit","pod","mot","tam","tol","sav","pos","nap","nop","som","fin","fon","ban","mor","wor","sip","ron","nor","bot","wic","soc","wat","dol","mag","pic","dav","bid","bal","tim","tas","mal","lig","siv","tag","pad","sal","div","dac","tan","sid","fab","tar","mon","ran","nis","wol","mis","pal","las","dis","map","rab","tob","rol","lat","lon","nod","nav","fig","nom","nib","pag","sop","ral","bil","had","doc","rid","moc","pac","rav","rip","fal","tod","til","tin","hap","mic","fan","pat","tac","lab","mog","sim","son","pin","lom","ric","tap","fir","has","bos","bat","poc","hac","tid","hav","sap","lin","dib","hos","dab","bit","bar","rac","par","lod","dos","bor","toc","hil","mac","tom","dig","fil","fas","mit","hob","har","mig","hin","rad","mas","hal","rag","lag","fad","top","mop","hab","nil","nos","mil","fop","fam","dat","nol","din","hat","nac","ris","fot","rib","hoc","nim","lar","fit","wal","rap","sar","nal","mos","lan","don","dan","lad","dov","riv","bac","pol","lap","tal","pit","nam","bon","ros","ton","fod","pon","sov","noc","sor","lav","mat","mip","fip"];var yo=["zod","nec","bud","wes","sev","per","sut","let","ful","pen","syt","dur","wep","ser","wyl","sun","ryp","syx","dyr","nup","heb","peg","lup","dep","dys","put","lug","hec","ryt","tyv","syd","nex","lun","mep","lut","sep","pes","del","sul","ped","tem","led","tul","met","wen","byn","hex","feb","pyl","dul","het","mev","rut","tyl","wyd","tep","bes","dex","sef","wyc","bur","der","nep","pur","rys","reb","den","nut","sub","pet","rul","syn","reg","tyd","sup","sem","wyn","rec","meg","net","sec","mul","nym","tev","web","sum","mut","nyx","rex","teb","fus","hep","ben","mus","wyx","sym","sel","ruc","dec","wex","syr","wet","dyl","myn","mes","det","bet","bel","tux","tug","myr","pel","syp","ter","meb","set","dut","deg","tex","sur","fel","tud","nux","rux","ren","wyt","nub","med","lyt","dus","neb","rum","tyn","seg","lyx","pun","res","red","fun","rev","ref","mec","ted","rus","bex","leb","dux","ryn","num","pyx","ryg","ryx","fep","tyr","tus","tyc","leg","nem","fer","mer","ten","lus","nus","syl","tec","mex","pub","rym","tuc","fyl","lep","deb","ber","mug","hut","tun","byl","sud","pem","dev","lur","def","bus","bep","run","mel","pex","dyt","byt","typ","lev","myl","wed","duc","fur","fex","nul","luc","len","ner","lex","rup","ned","lec","ryd","lyd","fen","wel","nyd","hus","rel","rud","nes","hes","fet","des","ret","dun","ler","nyr","seb","hul","ryl","lud","rem","lys","fyn","wer","ryc","sug","nys","nyl","lyn","dyn","dem","lux","fed","sed","bec","mun","lyr","tes","mud","nyt","byr","sen","weg","fyr","mur","tel","rep","teg","pec","nel","nev","fes"];var Se={defaults:{groupSize:4,wordSeparator:".",groupSeparator:" "},random(r,e){let t=gt.random(r);return this.fromBytes(t,e)},fromBytes(r,e={}){let{groupSize:t=Se.defaults.groupSize,wordSeparator:n=Se.defaults.wordSeparator,groupSeparator:o=Se.defaults.groupSeparator}=e,i=[],s=[];r.forEach((c,l)=>{let d=l%2===0?bo:yo;s.push(d[c]),s.length===2&&(i.push(s.join("")),s=[])}),s.length&&i.push(s.join(""));let a=[];for(let c=0;c<i.length;c+=t)a.push(i.slice(c,c+t).join(n));return a.join(o)},toBytes(r){let e=r.toLowerCase().replace(/[^a-z]/g,"");if(e.length/3%1!==0)throw new Error(`invalid triplet count, ${e.length} does not divide into triplets`);let n=[];for(let o=0;o<e.length;o+=3)n.push(e.slice(o,o+3));return new Uint8Array(n.map((o,i)=>{let a=(i%2===0?bo:yo).findIndex(c=>c===o);if(a===-1)throw new Error(`unknown triplet ${o}`);return a}))},toHex(r){return he.fromBytes(Se.toBytes(r))},fromHex(r,e){return Se.fromBytes(he.toBytes(r),e)}};var ge={defaults:{delimiter:".",sigilBytes:4,previewBytes:8},toBytes(r){r=r.trim();let e=r.split(/[^a-zA-Z0-9]+/m).filter(Boolean).map(o=>o.trim());if(e.length<2)return Se.toBytes(e.join(""));let t=e.pop(),n=e.join("");return new Uint8Array([...Se.toBytes(n),...xo.toBytes(t)])},parse(r,e){let t=ge.toBytes(r);return ge.build.fromBytes(t,e)},build:{fromBytes(r,e={}){let{delimiter:t,previewBytes:n,sigilBytes:o}={...ge.defaults,...e},i=d=>r.length>0?Se.fromBytes(r.slice(0,d),{wordSeparator:t,groupSeparator:t}):"",s=i(o),a=i(n),c=r.length>n?xo.fromBytes(r.slice(n)):"",l=[a,c].filter(d=>d.length>0).join(t);return{raw:r,full:l,preview:a,bulk:c,sigil:s,bytes:r,thumbprint:l}},fromHex(r,e){let t=he.toBytes(r);return ge.build.fromBytes(t,e)}},toHex(r){let e=ge.toBytes(r);return he.fromBytes(e)},fromBytes(r,e){return ge.build.fromBytes(r,e).full},fromHex(r,e){return ge.fromBytes(he.toBytes(r),e)},sigil:{fromHex(r,e){return ge.build.fromHex(r,e).sigil},fromBytes(r,e){return ge.build.fromBytes(r,e).sigil}}},Ri=ge;var _r=Object.freeze({fromBytes(r){return[...r].map(e=>e.toString(16).padStart(2,"0")).join("")},toBytes(r){if(r.length%2!==0)throw new Error("must have even number of hex characters");let e=new Uint8Array(r.length/2);for(let t=0;t<r.length;t+=2)e[t/2]=parseInt(r.slice(t,t+2),16);return e},random(r=32){return this.fromBytes(gt.random(r))},string(r){return _r.fromBytes(r)},bytes(r){return _r.toBytes(r)}});function xe(){let r,e,t=new Promise((o,i)=>{r=o,e=i});function n(o){return o.then(r).catch(e),t}return{promise:t,resolve:r,reject:e,entangle:n}}var Er=Object.freeze({happy:r=>r!=null,sad:r=>r==null,boolean:r=>typeof r=="boolean",number:r=>typeof r=="number",string:r=>typeof r=="string",bigint:r=>typeof r=="bigint",object:r=>typeof r=="object"&&r!==null,array:r=>Array.isArray(r),fn:r=>typeof r=="function",symbol:r=>typeof r=="symbol"});var Fr=class r extends Map{static require(e,t){if(e.has(t))return e.get(t);throw new Error(`required key not found: "${t}"`)}static guarantee(e,t,n){if(e.has(t))return e.get(t);{let o=n();return e.set(t,o),o}}array(){return[...this]}require(e){return r.require(this,e)}guarantee(e,t){return r.guarantee(this,e,t)}};var Xt=class extends Error{milliseconds;name=this.constructor.name;constructor(e){super(`deadline exceeded (${(e/1e3).toFixed(1)} seconds)`),this.milliseconds=e}};function Mi(r,e){return r<=0||r===1/0?e():new Promise((t,n)=>{let o=setTimeout(()=>n(new Xt(r)),r);e().then(t).catch(n).finally(()=>clearTimeout(o))})}function Dr(){let r=[];function e(){for(let t of r)t();r=[]}return e.schedule=(...t)=>(r.push(...t),e),e}function Bi(r,e){let t=r;for(let n of e)if(t=t[n],Er.sad(t))break;return t}function sc(){let r=new Set;async function e(...c){await Promise.all([...r].map(l=>l(...c)))}function t(c){return r.add(c),()=>{r.delete(c)}}async function n(...c){return e(...c)}function o(c){return t(c)}async function i(c){let{promise:l,resolve:d}=xe(),u=o(async(...f)=>{c&&await c(...f),d(f),u()});return l}function s(){r.clear()}let a={pub:n,sub:o,publish:e,subscribe:t,on:t,next:i,clear:s};return Object.assign(o,a),Object.assign(n,a),a}function xt(r){let e=sc();return r&&e.sub(r),e.pub}function To(r,e){return{error:t=>r.error({...e,...t}),rpcRequest:t=>r.rpcRequest({...e,...t}),rpcError:t=>r.rpcError({...e,...t})}}var Rr=()=>r=>({plain:r.none,errMessage:r.mix(r.brightRed,r.bold),errName:r.red,errStack:r.mix(r.red,r.dim),timestamp:r.blue,timestampErr:r.red});function Oi(){return Rr()}var Me=Object.freeze({black:"\x1B[30m",red:"\x1B[31m",green:"\x1B[32m",yellow:"\x1B[33m",blue:"\x1B[34m",magenta:"\x1B[35m",cyan:"\x1B[36m",white:"\x1B[37m",brightBlack:"\x1B[90m",brightRed:"\x1B[91m",brightGreen:"\x1B[92m",brightYellow:"\x1B[93m",brightBlue:"\x1B[94m",brightMagenta:"\x1B[95m",brightCyan:"\x1B[96m",brightWhite:"\x1B[97m",bgBlack:"\x1B[40m",bgRed:"\x1B[41m",bgGreen:"\x1B[42m",bgYellow:"\x1B[43m",bgBlue:"\x1B[44m",bgMagenta:"\x1B[45m",bgCyan:"\x1B[46m",bgWhite:"\x1B[47m",bgBrightBlack:"\x1B[100m",bgBrightRed:"\x1B[101m",bgBrightGreen:"\x1B[102m",bgBrightYellow:"\x1B[103m",bgBrightBlue:"\x1B[104m",bgBrightMagenta:"\x1B[105m",bgBrightCyan:"\x1B[106m",bgBrightWhite:"\x1B[107m",bold:"\x1B[1m",dim:"\x1B[2m",italic:"\x1B[3m",underline:"\x1B[4m",inverse:"\x1B[7m",hidden:"\x1B[8m",strikethrough:"\x1B[9m",reset:"\x1B[0m"});var Mr=()=>({none:r=>r,uncolor:cc,mix:lc,hex:uc,rgb:zi,bgRgb:dc});function cc(r){return r.replace(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g,"")}function lc(...r){return e=>{for(let t of r)e=t(e);return e}}function uc(r){r=r.replace(/^#/,"");let e,t,n,o;if(r.length===3)e=parseInt(r.split("").map(i=>i+i).join(""),16);else if(r.length===6)e=parseInt(r,16);else throw new Error("Invalid hex color");return t=e>>16&255,n=e>>8&255,o=e&255,zi(t,n,o)}function zi(r,e,t){let n=`\x1B[38;2;${r};${e};${t}m`;return o=>`${n}${o}${Me.reset}`}function dc(r,e,t){let n=`\x1B[48;2;${r};${e};${t}m`;return o=>`${n}${o}${Me.reset}`}var Qt={...Object.fromEntries(Object.entries(Me).map(([r])=>[r,e=>e])),...Mr()};var Yt={...Object.fromEntries(Object.entries(Me).map(([r,e])=>[r,t=>`${e}${t}${Me.reset}`])),...Mr()};function wo(){return typeof Deno<"u"&&typeof Deno.version<"u"}function ko(){return typeof process<"u"&&process.versions&&process.versions.node}function Ui(){return ko()?process.env.FORCE_COLOR||process.stdout.isTTY&&process.env.TERM!=="dumb":wo()?Deno.env.get("FORCE_COLOR")||Deno.isatty(Deno.stdout.rid)&&Deno.env.get("TERM")!=="dumb":!1}var So=()=>Ui()?Yt:Qt;var Br=()=>({colors:r,theme:e})=>{let t=e(r);function n(s){let a=s.stack?`
|
|
2335
|
+
`+s.stack+`
|
|
2336
|
+
`:"";return[t.errName(s.name+":"),t.errMessage(s.message)].join(" ")+t.errStack(a)}function o(s){return s&&s instanceof Error?n(s):s}function i(s){return s&&s instanceof Error?n(s):t.errMessage(s)}return{stdout:s=>s.map(o),stderr:s=>s.map(i)}};function Zt(...r){return e=>({stdout:t=>{for(let n of r)t=n(e).stdout(t);return t},stderr:t=>{for(let n of r)t=n(e).stderr(t);return t}})}function fc(){return{icon:"\u{1F6A8}",now:()=>Date.now()}}var Or=r=>({colors:e,theme:t})=>{let n={...fc(),...r},o=t(e),i=new Date(n.now()),s=i.getUTCFullYear().toString().padStart(4,"0"),a=(i.getUTCMonth()+1).toString().padStart(2,"0"),c=i.getUTCDate().toString().padStart(2,"0"),l=`${s}-${a}-${c}`,d=i.getUTCHours().toString().padStart(2,"0"),u=i.getUTCMinutes().toString().padStart(2,"0"),f=i.getUTCSeconds().toString().padStart(2,"0"),m=i.getUTCMilliseconds().toString().padStart(3,"0"),p=`${d}:${u}:${f}.${m}`,g=`${l}::${p}`;return{stdout:x=>[o.timestamp(g),...x],stderr:x=>[o.timestampErr(g),...[n.icon].filter(Boolean),...x]}};function Ni(){return Zt(Br(),Or())}var zr=()=>({stdout:async r=>{await Deno.stdout.write(new TextEncoder().encode(r+`
|
|
2337
|
+
`))},stderr:async r=>{await Deno.stderr.write(new TextEncoder().encode(r+`
|
|
2338
|
+
`))}});var Ur=()=>({stdout:async r=>{process.stdout.write(r+`
|
|
2339
|
+
`)},stderr:async r=>{process.stderr.write(r+`
|
|
2340
|
+
`)}});var Nr=()=>({stdout:async r=>console.log(r),stderr:async r=>console.error(r)});var Vi=()=>wo()?zr():ko()?Ur():Nr();var Li=()=>({stdout:async()=>{},stderr:async()=>{}});function Hi(){return()=>({stdout:r=>r,stderr:r=>r})}var bt=class r{static writers={auto:Vi,void:Li,deno:zr,node:Ur,console:Nr};static colors={auto:So,colorful:()=>Yt,colorless:()=>Qt};static themes={auto:Oi,basic:Rr};static shapers={auto:Ni,none:Hi,errors:Br,timestamp:Or};writer=r.writers.auto();colors=r.colors.auto();theme=r.themes.auto();shaper=r.shapers.auto();async log(...e){await this.writer.stdout(this.shaper(this).stdout(e).join(" "))}async error(...e){await this.writer.stderr(this.shaper(this).stderr(e).join(" "))}setWriter(e){return this.writer=e,this}setColors(e){return this.colors=e,this}setTheme(e){return this.theme=e,this}setShaper(...e){return this.shaper=Zt(...e),this}};var Jt=class extends bt{static dummy(){return new this().setWriter(bt.writers.void())}rpcRequest=async({request:e,...t})=>{let n=this.colors.none;this.log(...this.#e(t),n(`${e.method}()`))};rpcError=async({request:e,error:t,...n})=>{this.error(...this.#e(n),`${e.method}()`,t)};#e({meta:e,label:t,remote:n}){let o=this.colors.mix(this.colors.blue,this.colors.dim),i=this.colors.mix(this.colors.cyan,this.colors.dim);return[e?this.#t(e):void 0,t||void 0,n===void 0?void 0:n?o("<-"):i("->")].filter(Boolean)}#t(e){let{headers:t}=e.request;return[this.colors.yellow(`[${e.ip}]`),this.colors.green(t.origin?t.origin:"(no-origin)")].join(" ")}};var be=class extends Jt{rpcRequest=async()=>{}};var ve;(function(r){r.version="2.0";function e(t){return"id"in t?t.id:null}r.getId=e,r.errorCodes={serverError:-32e3,unexposedError:-32001}})(ve||(ve={}));var Vr=class extends Error{name=this.constructor.name},We=class extends Error{name=this.constructor.name};async function qi({tap:r,request:e,action:t}){let n=ve.getId(e);try{let o=await t();return n===null?null:{id:n,result:o,jsonrpc:ve.version}}catch(o){return r.rpcError({request:e,error:o}),n===null?null:{id:n,jsonrpc:ve.version,error:o instanceof Vr?{code:ve.errorCodes.serverError,message:o.message}:{code:ve.errorCodes.unexposedError,message:"unexposed error"}}}}function Lr(r){let e=r.tap??new be;return async t=>{let n=t.method.split("."),o=Bi(r.fns,n),i=async()=>await o(...t.params);return e.rpcRequest({request:t}),await qi({tap:e,request:t,action:i})}}var yt=Symbol("tune"),mc=Symbol("query"),pc=Symbol("notify"),hc=Symbol("settings");function Gi(r){function e(t){let n={notify:void 0};return new Proxy((()=>{}),{apply:(o,i,s)=>r(t,s,n),get:(o,i)=>{if(i!=="then")return i===yt?s=>(...a)=>r(t,a,{...n,...s}):i===pc?(...s)=>r(t,s,{...n,notify:!0}):i===mc?(...s)=>r(t,s,{...n,notify:!1}):i===hc?n:(o[i]||(o[i]=e([...t,i])),o[i])},set:(o,i,s)=>(o[i]=s,!0)})}return e([])}function je(r){let{endpoint:e,tap:t=new be}=r,n=1;return Gi(async(o,i,s)=>{let a=s.notify??r.notify??!1,c=s.transfer,l={jsonrpc:"2.0",method:o.join("."),params:i},d=a?l:{...l,id:n++};t.rpcRequest({request:d});let u=await e(d,{transfer:c});if(a&&!u)return null;if(!u)throw new We("response was null, but shouldn't be, because the request was not a notification");if("error"in u)throw new We(r.label?`${r.label}: ${u.error.message}`:u.error.message);return u.result})}function er(r){return je({endpoint:Lr(r),tap:r.tap})}var $e=class{recv=xt();sendRequest=xt();sendResponse=xt();static makeEntangledPair({origin:e="example.e280.org"}={}){let t=new this,n=new this,o=[t.sendRequest.sub(s=>n.recv(s,{origin:e})),t.sendResponse.sub(s=>n.recv(s,{origin:e})),n.sendRequest.sub(s=>t.recv(s,{origin:e})),n.sendResponse.sub(s=>t.recv(s,{origin:e}))];return[t,n,()=>o.forEach(s=>s())]}};function Hr(r,e){return r.addEventListener("message",e),()=>r.removeEventListener("message",e)}function Wi(r,e){return async(t,{transfer:n}={})=>{if("id"in t){let o=xe();return e(t,n,o.promise),r.wait(t.id,t.method).then(i=>(o.resolve(i),i))}else{let o=Promise.resolve(null);return e(t,n,o),o}}}function ji(r){let e=[],t=[];for(let n of Array.isArray(r)?r:[r])"method"in n?e.push(n):t.push(n);return{requests:e,responses:t}}async function $i(r,e){let t=(await Promise.all(e.map(async n=>r(n)))).filter(n=>n!==null);return t.length===0?null:t.length===1?t[0]:t}var Tt=class extends $e{dispose=Dr();constructor(e){super(),this.dispose.schedule(this.sendRequest.sub((t,n)=>e.postMessage(t,n)),this.sendResponse.sub((t,n)=>e.postMessage(t,n)),Hr(e,t=>this.recv(t.data,t)))}};var qr=class{remote;transfer;constructor(e){this.remote=e}};var vo=Object.freeze({timeout:6e4,maxRequestBytes:1e7});var Gr=class{timeout;pending=new Map;constructor(e){this.timeout=e}async wait(e,t){let n=xe();return this.pending.set(e,{method:t,deferred:n}),await Mi(this.timeout,()=>n.promise).catch(o=>{throw o instanceof Xt&&(o.message=`request #${e} ${t}(), ${o.message}`),o})}deliverResponse(e){let t=this.pending.get(e.id);t&&("error"in e?t.deferred.reject(new We(e.error.message)):t.deferred.resolve(e))}};var Ke=class{options;remote;remoteEndpoint;dispose=Dr();#e;constructor(e){this.options=e;let{conduit:t,tap:n}=e;this.#e=new Gr(e.timeout??vo.timeout),this.remoteEndpoint=Wi(this.#e,t.sendRequest.pub.bind(t.sendRequest)),this.remote=je({endpoint:this.remoteEndpoint,tap:n&&To(n,{remote:!0})}),this.dispose.schedule(t.recv.sub(o=>this.recv(o)))}async recv(e){let t=new qr(this.remote),{conduit:n,rpc:o,tap:i}=this.options,{requests:s,responses:a}=ji(e);for(let u of a)this.#e.deliverResponse(u);if(!o)return;let c=await o(t),l=Lr({fns:c,tap:i&&To(i,{remote:!1})}),d=await $i(l,s);d&&await n.sendResponse(d,t.transfer)}};var Pe={derive:{host:r=>({host:r.remote.host,get transfer(){return r.transfer},set transfer(e){r.transfer=e}}),work:r=>({work:r.remote,get transfer(){return r.transfer},set transfer(e){r.transfer=e}})},mock:{host:()=>({host:void 0,transfer:void 0}),work:()=>({work:void 0,transfer:void 0})}};var Ce=new be;async function Ki(r,e,t={}){let n=t.tap??Ce,o=new Ke({tap:n,timeout:t.timeout??1/0,conduit:new Tt(r.getSelf()),rpc:async i=>e(Pe.derive.host(i))});return await o.remote.infra.ready(),o.remote.host}var wt=class{worker;messenger;constructor(e,t){this.worker=e,this.messenger=t}static async make(e,t){let n=t.tap??Ce,o=t.label??"comrade",i=e.loadWorker(t.workerUrl,o),s=xe(),a={async ready(){s.resolve()}},c=new Ke({tap:n,timeout:t.timeout??1/0,conduit:new Tt(i),rpc:async l=>({infra:a,host:t.setupHost(Pe.derive.work(l))})});return await s.promise,new this(i,c)}get work(){return this.messenger.remote}terminate(){this.worker.terminate()}};var Wr=class{threads;static async make(e,t){let n=t.workerCount??e.guessOptimalThreadCount(),o=await Promise.all([...Array(n)].map(async(i,s)=>wt.make(e,{...t,label:t.label??`${t.label??"comrade"}_${s+1}`})));return new this(o,{tap:t.tap})}work;#e=new Set;#t=[];constructor(e,t={}){this.threads=e;let n=t.tap??Ce,o=async(i,s)=>this.#r({request:i,prom:xe(),transfer:s?.transfer});this.work=je({tap:n,endpoint:o}),e.forEach(i=>this.#e.add(i))}get threadCount(){return this.threads.length}terminate(){for(let e of this.threads)e.terminate()}#r(e){return this.#t.push(e),this.#n(),e.prom.promise}#n(){for(;this.#e.size>0&&this.#t.length>0;){let e=[...this.#e].pop();this.#e.delete(e);let t=this.#t.shift();this.#e.delete(e);let n=e.messenger.remoteEndpoint(t.request,{transfer:t.transfer});t.prom.entangle(n).finally(()=>{this.#e.add(e),this.#n()})}}};var Xi=r=>({thread:e=>wt.make(r,e),cluster:e=>Wr.make(r,e),worker:(e,t={})=>Ki(r,e,t),work:e=>e,host:e=>e,mocks(e){let{setupWork:t,setupHost:n,tap:o=Ce}=e,i=Pe.mock.host(),s=Pe.mock.work();return s.work=er({tap:o,fns:t(i)}),i.host=er({tap:o,fns:n(s)}),{workShell:s,hostShell:i,work:s.work,host:i.host}},mockWork(e,t=Ce){let n=Pe.mock.host(),o=Pe.mock.work();return o.work=er({tap:t,fns:e(n)}),{workShell:o,hostShell:n,work:o.work,mockHost:i=>(n.host=er({tap:t,fns:i(o)}),{workShell:o,hostShell:n,work:o.work,host:n.host})}}});var Qi=()=>({getSelf(){return self},guessOptimalThreadCount(){let r=navigator.hardwareConcurrency??1;return Math.max(1,r-1)},loadWorker(r,e){return new window.Worker(r,{name:e,type:"module"})},async loadWasm(r){return WebAssembly.instantiateStreaming(fetch(r))}});var bc=Qi(),jr=Xi(bc);function h(r){if(!r)throw new Error("Assertion failed.")}var $r=r=>{let e=(r%360+360)%360;if(e===0||e===90||e===180||e===270)return e;throw new Error(`Invalid rotation ${r}.`)},Y=r=>r&&r[r.length-1];var N=class r{constructor(e){this.bytes=e,this.pos=0}seekToByte(e){this.pos=8*e}readBit(){let e=Math.floor(this.pos/8),t=this.bytes[e]??0,n=7-(this.pos&7),o=(t&1<<n)>>n;return this.pos++,o}readBits(e){if(e===1)return this.readBit();let t=0;for(let n=0;n<e;n++)t<<=1,t|=this.readBit();return t}writeBits(e,t){let n=this.pos+e;for(let o=this.pos;o<n;o++){let i=Math.floor(o/8),s=this.bytes[i],a=7-(o&7);s&=~(1<<a),s|=(t&1<<n-o-1)>>n-o-1<<a,this.bytes[i]=s}this.pos=n}readAlignedByte(){if(this.pos%8!==0)throw new Error("Bitstream is not byte-aligned.");let e=this.pos/8,t=this.bytes[e]??0;return this.pos+=8,t}skipBits(e){this.pos+=e}getBitsLeft(){return this.bytes.length*8-this.pos}clone(){let e=new r(this.bytes);return e.pos=this.pos,e}},I=r=>{let e=0;for(;r.readBits(1)===0&&e<32;)e++;if(e>=32)throw new Error("Invalid exponential-Golomb code.");return(1<<e)-1+r.readBits(e)},Te=r=>{let e=I(r);return(e&1)===0?-(e>>1):e+1>>1};var le=r=>r.constructor===Uint8Array?r:ArrayBuffer.isView(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):new Uint8Array(r),z=r=>r.constructor===DataView?r:ArrayBuffer.isView(r)?new DataView(r.buffer,r.byteOffset,r.byteLength):new DataView(r),$=new TextDecoder;var _o=r=>Object.fromEntries(Object.entries(r).map(([e,t])=>[t,e])),Eo={bt709:1,bt470bg:5,smpte170m:6,bt2020:9,smpte432:12},Kr=_o(Eo),Fo={bt709:1,smpte170m:6,linear:8,"iec61966-2-1":13,pq:16,hlg:18},Xr=_o(Fo),Do={rgb:0,bt709:1,bt470bg:5,smpte170m:6,"bt2020-ncl":9},Qr=_o(Do);var Yr=r=>r instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&r instanceof SharedArrayBuffer||ArrayBuffer.isView(r),ye=class{constructor(){this.currentPromise=Promise.resolve()}async acquire(){let e,t=new Promise(o=>{e=o}),n=this.currentPromise;return this.currentPromise=t,await n,e}},Ro=r=>[...r].map(e=>e.toString(16).padStart(2,"0")).join(""),Mo=r=>(r=r>>1&1431655765|(r&1431655765)<<1,r=r>>2&858993459|(r&858993459)<<2,r=r>>4&252645135|(r&252645135)<<4,r=r>>8&16711935|(r&16711935)<<8,r=r>>16&65535|(r&65535)<<16,r>>>0),Xe=(r,e,t)=>{let n=0,o=r.length-1,i=-1;for(;n<=o;){let s=n+o>>1,a=t(r[s]);a===e?(i=s,o=s-1):a<e?n=s+1:o=s-1}return i},B=(r,e,t)=>{let n=0,o=r.length-1,i=-1;for(;n<=o;){let s=n+(o-n+1)/2|0;t(r[s])<=e?(i=s,n=s+1):o=s-1}return i},Bo=(r,e,t)=>{let n=B(r,t(e),t);r.splice(n+1,0,e)},Z=()=>{let r,e;return{promise:new Promise((n,o)=>{r=n,e=o}),resolve:r,reject:e}};var Oo=(r,e)=>{for(let t=r.length-1;t>=0;t--)if(e(r[t]))return r[t]},Zr=(r,e)=>{for(let t=r.length-1;t>=0;t--)if(e(r[t]))return t;return-1},Zi=async function*(r){Symbol.iterator in r?yield*r[Symbol.iterator]():yield*r[Symbol.asyncIterator]()},Ji=r=>{if(!(Symbol.iterator in r)&&!(Symbol.asyncIterator in r))throw new TypeError("Argument must be an iterable or async iterable.")},se=r=>{throw new Error(`Unexpected value: ${r}`)},Qe=(r,e,t)=>{let n=r.getUint8(e),o=r.getUint8(e+1),i=r.getUint8(e+2);return t?n|o<<8|i<<16:n<<16|o<<8|i},es=(r,e,t)=>Qe(r,e,t)<<8>>8,ts=(r,e,t,n)=>{t=t>>>0,t=t&16777215,n?(r.setUint8(e,t&255),r.setUint8(e+1,t>>>8&255),r.setUint8(e+2,t>>>16&255)):(r.setUint8(e,t>>>16&255),r.setUint8(e+1,t>>>8&255),r.setUint8(e+2,t&255))};var zo=(r,e)=>({async next(){let t=await r.next();return t.done?{value:void 0,done:!0}:{value:e(t.value),done:!1}},return(){return r.return()},throw(t){return r.throw(t)},[Symbol.asyncIterator](){return this}}),Ye=(r,e,t)=>Math.max(e,Math.min(t,r)),K="und",Ze=r=>{let e=Math.round(r);return Math.abs(r/e-1)<10*Number.EPSILON?e:r},rs=(r,e)=>Math.round(r/e)*e,ns=r=>{let e=0;for(;r;)e++,r>>=1;return e},yc=/^[a-z]{3}$/,Jr=r=>yc.test(r),we=1e6*(1+Number.EPSILON),Uo=(r,e)=>{let t={...r,...e};if(r.headers||e.headers){let n=r.headers?Yi(r.headers):{},o=e.headers?Yi(e.headers):{},i={...n};Object.entries(o).forEach(([s,a])=>{let c=Object.keys(i).find(l=>l.toLowerCase()===s.toLowerCase());c&&delete i[c],i[s]=a}),t.headers=i}return t},Yi=r=>{if(r instanceof Headers){let e={};return r.forEach((t,n)=>{e[n]=t}),e}if(Array.isArray(r)){let e={};return r.forEach(([t,n])=>{e[t]=n}),e}return r},No=async(r,e,t,n,o)=>{let i=0;for(;;)try{return await r(e,t)}catch(s){if(o())throw s;i++;let a=n(i,s,e);if(a===null)throw s;if(console.error("Retrying failed fetch. Error:",s),!Number.isFinite(a)||a<0)throw new TypeError("Retry delay must be a non-negative finite number.");if(a>0&&await new Promise(c=>setTimeout(c,1e3*a)),o())throw s}};var tr=class{constructor(){this.currentPromise=Promise.resolve()}call(e){return this.currentPromise=this.currentPromise.then(e)}},Po=null,Be=()=>Po!==null?Po:Po=!!(typeof navigator<"u"&&(navigator.vendor?.match(/apple/i)||/AppleWebKit/.test(navigator.userAgent)&&!/Chrome/.test(navigator.userAgent)||/\b(iPad|iPhone|iPod)\b/.test(navigator.userAgent))),Co=null,rr=()=>Co!==null?Co:Co=typeof navigator<"u"&&navigator.userAgent?.includes("Firefox"),Io=null,nr=()=>Io!==null?Io:Io=!!(typeof navigator<"u"&&(navigator.vendor?.includes("Google Inc")||/Chrome/.test(navigator.userAgent))),Ao=null,os=()=>{if(Ao!==null)return Ao;if(typeof navigator>"u")return null;let r=/\bChrome\/(\d+)/.exec(navigator.userAgent);return r?Ao=Number(r[1]):null},Je=(r,e)=>r!==-1?r:e,en=(r,e,t,n)=>r<=n&&t<=e;var is=r=>{let e=atob(r),t=new Uint8Array(e.length);for(let n=0;n<e.length;n++)t[n]=e.charCodeAt(n);return t};var tn=()=>{Symbol.dispose??=Symbol("Symbol.dispose")},or=r=>typeof r=="number"&&!Number.isNaN(r);var Oe=class{constructor(e,t){if(this.data=e,this.mimeType=t,!(e instanceof Uint8Array))throw new TypeError("data must be a Uint8Array.");if(typeof t!="string")throw new TypeError("mimeType must be a string.")}},rn=class{constructor(e,t,n,o){if(this.data=e,this.mimeType=t,this.name=n,this.description=o,!(e instanceof Uint8Array))throw new TypeError("data must be a Uint8Array.");if(t!==void 0&&typeof t!="string")throw new TypeError("mimeType, when provided, must be a string.");if(n!==void 0&&typeof n!="string")throw new TypeError("name, when provided, must be a string.");if(o!==void 0&&typeof o!="string")throw new TypeError("description, when provided, must be a string.")}};var te={default:!0,forced:!1,original:!1,commentary:!1,hearingImpaired:!1,visuallyImpaired:!1};var ze=["pcm-s16","pcm-s16be","pcm-s24","pcm-s24be","pcm-s32","pcm-s32be","pcm-f32","pcm-f32be","pcm-f64","pcm-f64be","pcm-u8","pcm-s8","ulaw","alaw"],Tc=["aac","opus","mp3","vorbis","flac"],jm=[...Tc,...ze];var et=[{maxPictureSize:36864,maxBitrate:2e5,level:10},{maxPictureSize:73728,maxBitrate:8e5,level:11},{maxPictureSize:122880,maxBitrate:18e5,level:20},{maxPictureSize:245760,maxBitrate:36e5,level:21},{maxPictureSize:552960,maxBitrate:72e5,level:30},{maxPictureSize:983040,maxBitrate:12e6,level:31},{maxPictureSize:2228224,maxBitrate:18e6,level:40},{maxPictureSize:2228224,maxBitrate:3e7,level:41},{maxPictureSize:8912896,maxBitrate:6e7,level:50},{maxPictureSize:8912896,maxBitrate:12e7,level:51},{maxPictureSize:8912896,maxBitrate:18e7,level:52},{maxPictureSize:35651584,maxBitrate:18e7,level:60},{maxPictureSize:35651584,maxBitrate:24e7,level:61},{maxPictureSize:35651584,maxBitrate:48e7,level:62}];var ss=".01.01.01.01.00",as=".0.110.01.01.01.0";var nn=r=>{let{codec:e,codecDescription:t,colorSpace:n,avcCodecInfo:o,hevcCodecInfo:i,vp9CodecInfo:s,av1CodecInfo:a}=r;if(e==="avc"){if(h(r.avcType!==null),o){let c=new Uint8Array([o.avcProfileIndication,o.profileCompatibility,o.avcLevelIndication]);return`avc${r.avcType}.${Ro(c)}`}if(!t||t.byteLength<4)throw new TypeError("AVC decoder description is not provided or is not at least 4 bytes long.");return`avc${r.avcType}.${Ro(t.subarray(1,4))}`}else if(e==="hevc"){let c,l,d,u,f,m;if(i)c=i.generalProfileSpace,l=i.generalProfileIdc,d=Mo(i.generalProfileCompatibilityFlags),u=i.generalTierFlag,f=i.generalLevelIdc,m=[...i.generalConstraintIndicatorFlags];else{if(!t||t.byteLength<23)throw new TypeError("HEVC decoder description is not provided or is not at least 23 bytes long.");let g=z(t),x=g.getUint8(1);c=x>>6&3,l=x&31,d=Mo(g.getUint32(2)),u=x>>5&1,f=g.getUint8(12),m=[];for(let y=0;y<6;y++)m.push(g.getUint8(6+y))}let p="hev1.";for(p+=["","A","B","C"][c]+l,p+=".",p+=d.toString(16).toUpperCase(),p+=".",p+=u===0?"L":"H",p+=f;m.length>0&&m[m.length-1]===0;)m.pop();return m.length>0&&(p+=".",p+=m.map(g=>g.toString(16).toUpperCase()).join(".")),p}else{if(e==="vp8")return"vp8";if(e==="vp9"){if(!s){let y=r.width*r.height,b=Y(et).level;for(let w of et)if(y<=w.maxPictureSize){b=w.level;break}return`vp09.00.${b.toString().padStart(2,"0")}.08`}let c=s.profile.toString().padStart(2,"0"),l=s.level.toString().padStart(2,"0"),d=s.bitDepth.toString().padStart(2,"0"),u=s.chromaSubsampling.toString().padStart(2,"0"),f=s.colourPrimaries.toString().padStart(2,"0"),m=s.transferCharacteristics.toString().padStart(2,"0"),p=s.matrixCoefficients.toString().padStart(2,"0"),g=s.videoFullRangeFlag.toString().padStart(2,"0"),x=`vp09.${c}.${l}.${d}.${u}`;return x+=`.${f}.${m}.${p}.${g}`,x.endsWith(ss)&&(x=x.slice(0,-ss.length)),x}else if(e==="av1"){if(!a){let w=r.width*r.height,k=Y(et).level;for(let P of et)if(w<=P.maxPictureSize){k=P.level;break}return`av01.0.${k.toString().padStart(2,"0")}M.08`}let c=a.profile,l=a.level.toString().padStart(2,"0"),d=a.tier?"H":"M",u=a.bitDepth.toString().padStart(2,"0"),f=a.monochrome?"1":"0",m=100*a.chromaSubsamplingX+10*a.chromaSubsamplingY+1*(a.chromaSubsamplingX&&a.chromaSubsamplingY?a.chromaSamplePosition:0),p=n?.primaries?Eo[n.primaries]:1,g=n?.transfer?Fo[n.transfer]:1,x=n?.matrix?Do[n.matrix]:1,y=n?.fullRange?1:0,b=`av01.${c}.${l}${d}.${u}`;return b+=`.${f}.${m.toString().padStart(3,"0")}`,b+=`.${p.toString().padStart(2,"0")}`,b+=`.${g.toString().padStart(2,"0")}`,b+=`.${x.toString().padStart(2,"0")}`,b+=`.${y}`,b.endsWith(as)&&(b=b.slice(0,-as.length)),b}}throw new TypeError(`Unhandled codec '${e}'.`)};var on=r=>{let{codec:e,codecDescription:t,aacCodecInfo:n}=r;if(e==="aac"){if(!n)throw new TypeError("AAC codec info must be provided.");return n.isMpeg2?"mp4a.67":`mp4a.40.${Lo(t).objectType}`}else{if(e==="mp3")return"mp3";if(e==="opus")return"opus";if(e==="vorbis")return"vorbis";if(e==="flac")return"flac";if(e&&ze.includes(e))return e}throw new TypeError(`Unhandled codec '${e}'.`)},ir=[96e3,88200,64e3,48e3,44100,32e3,24e3,22050,16e3,12e3,11025,8e3,7350],Vo=[-1,1,2,3,4,5,6,8],Lo=r=>{if(!r||r.byteLength<2)throw new TypeError("AAC description must be at least 2 bytes long.");let e=new N(r),t=e.readBits(5);t===31&&(t=32+e.readBits(6));let n=e.readBits(4),o=null;n===15?o=e.readBits(24):n<ir.length&&(o=ir[n]);let i=e.readBits(4),s=null;return i>=1&&i<=7&&(s=Vo[i]),{objectType:t,frequencyIndex:n,sampleRate:o,channelConfiguration:i,numberOfChannels:s}};var tt=48e3,wc=/^pcm-([usf])(\d+)+(be)?$/,sn=r=>{if(h(ze.includes(r)),r==="ulaw")return{dataType:"ulaw",sampleSize:1,littleEndian:!0,silentValue:255};if(r==="alaw")return{dataType:"alaw",sampleSize:1,littleEndian:!0,silentValue:213};let e=wc.exec(r);h(e);let t;e[1]==="u"?t="unsigned":e[1]==="s"?t="signed":t="float";let n=Number(e[2])/8,o=e[3]!=="be",i=r==="pcm-u8"?2**7:0;return{dataType:t,sampleSize:n,littleEndian:o,silentValue:i}};var rt;(function(r){r[r.IDR=5]="IDR",r[r.SEI=6]="SEI",r[r.SPS=7]="SPS",r[r.PPS=8]="PPS",r[r.SPS_EXT=13]="SPS_EXT"})(rt||(rt={}));var J;(function(r){r[r.RASL_N=8]="RASL_N",r[r.RASL_R=9]="RASL_R",r[r.BLA_W_LP=16]="BLA_W_LP",r[r.RSV_IRAP_VCL23=23]="RSV_IRAP_VCL23",r[r.VPS_NUT=32]="VPS_NUT",r[r.SPS_NUT=33]="SPS_NUT",r[r.PPS_NUT=34]="PPS_NUT",r[r.PREFIX_SEI_NUT=39]="PREFIX_SEI_NUT",r[r.SUFFIX_SEI_NUT=40]="SUFFIX_SEI_NUT"})(J||(J={}));var cn=r=>{let e=[],t=0;for(;t<r.length;){let n=-1,o=0;for(let i=t;i<r.length-3;i++){if(r[i]===0&&r[i+1]===0&&r[i+2]===1){n=i,o=3;break}if(i<r.length-4&&r[i]===0&&r[i+1]===0&&r[i+2]===0&&r[i+3]===1){n=i,o=4;break}}if(n===-1)break;if(t>0&&n>t){let i=r.subarray(t,n);i.length>0&&e.push(i)}t=n+o}if(t<r.length){let n=r.subarray(t);n.length>0&&e.push(n)}return e},us=(r,e)=>{let t=[],n=0,o=new DataView(r.buffer,r.byteOffset,r.byteLength);for(;n+e<=r.length;){let i;e===1?i=o.getUint8(n):e===2?i=o.getUint16(n,!1):e===3?i=Qe(o,n,!1):e===4?i=o.getUint32(n,!1):(se(e),h(!1)),n+=e;let s=r.subarray(n,n+i);t.push(s),n+=i}return t},an=r=>{let e=[],t=r.length;for(let n=0;n<t;n++)n+2<t&&r[n]===0&&r[n+1]===0&&r[n+2]===3?(e.push(0,0),n+=2):e.push(r[n]);return new Uint8Array(e)},Ho=new Uint8Array([0,0,0,1]),Sc=r=>{let e=r.reduce((o,i)=>o+Ho.byteLength+i.byteLength,0),t=new Uint8Array(e),n=0;for(let o of r)t.set(Ho,n),n+=Ho.byteLength,t.set(o,n),n+=o.byteLength;return t},vc=(r,e)=>{let t=r.reduce((i,s)=>i+e+s.byteLength,0),n=new Uint8Array(t),o=0;for(let i of r){let s=new DataView(n.buffer,n.byteOffset,n.byteLength);switch(e){case 1:s.setUint8(o,i.byteLength);break;case 2:s.setUint16(o,i.byteLength,!1);break;case 3:ts(s,o,i.byteLength,!1);break;case 4:s.setUint32(o,i.byteLength,!1);break}o+=e,n.set(i,o),o+=i.byteLength}return n},qo=(r,e)=>{if(e.description){let o=(le(e.description)[4]&3)+1;return us(r,o)}else return cn(r)},ds=(r,e)=>{if(e.description){let o=(le(e.description)[4]&3)+1;return vc(r,o)}else return Sc(r)},nt=r=>r[0]&31,fs=r=>{try{let e=cn(r),t=e.filter(c=>nt(c)===rt.SPS),n=e.filter(c=>nt(c)===rt.PPS),o=e.filter(c=>nt(c)===rt.SPS_EXT);if(t.length===0||n.length===0)return null;let i=t[0],s=Go(i);h(s!==null);let a=s.profileIdc===100||s.profileIdc===110||s.profileIdc===122||s.profileIdc===144;return{configurationVersion:1,avcProfileIndication:s.profileIdc,profileCompatibility:s.constraintFlags,avcLevelIndication:s.levelIdc,lengthSizeMinusOne:3,sequenceParameterSets:t,pictureParameterSets:n,chromaFormat:a?s.chromaFormatIdc:null,bitDepthLumaMinus8:a?s.bitDepthLumaMinus8:null,bitDepthChromaMinus8:a?s.bitDepthChromaMinus8:null,sequenceParameterSetExt:a?o:null}}catch(e){return console.error("Error building AVC Decoder Configuration Record:",e),null}};var ms=r=>{try{let e=z(r),t=0,n=e.getUint8(t++),o=e.getUint8(t++),i=e.getUint8(t++),s=e.getUint8(t++),a=e.getUint8(t++)&3,c=e.getUint8(t++)&31,l=[];for(let m=0;m<c;m++){let p=e.getUint16(t,!1);t+=2,l.push(r.subarray(t,t+p)),t+=p}let d=e.getUint8(t++),u=[];for(let m=0;m<d;m++){let p=e.getUint16(t,!1);t+=2,u.push(r.subarray(t,t+p)),t+=p}let f={configurationVersion:n,avcProfileIndication:o,profileCompatibility:i,avcLevelIndication:s,lengthSizeMinusOne:a,sequenceParameterSets:l,pictureParameterSets:u,chromaFormat:null,bitDepthLumaMinus8:null,bitDepthChromaMinus8:null,sequenceParameterSetExt:null};if((o===100||o===110||o===122||o===144)&&t+4<=r.length){let m=e.getUint8(t++)&3,p=e.getUint8(t++)&7,g=e.getUint8(t++)&7,x=e.getUint8(t++);f.chromaFormat=m,f.bitDepthLumaMinus8=p,f.bitDepthChromaMinus8=g;let y=[];for(let b=0;b<x;b++){let w=e.getUint16(t,!1);t+=2,y.push(r.subarray(t,t+w)),t+=w}f.sequenceParameterSetExt=y}return f}catch(e){return console.error("Error deserializing AVC Decoder Configuration Record:",e),null}},Go=r=>{try{let e=new N(an(r));if(e.skipBits(1),e.skipBits(2),e.readBits(5)!==7)return null;let n=e.readAlignedByte(),o=e.readAlignedByte(),i=e.readAlignedByte();I(e);let s=null,a=null,c=null;if((n===100||n===110||n===122||n===244||n===44||n===83||n===86||n===118||n===128)&&(s=I(e),s===3&&e.skipBits(1),a=I(e),c=I(e),e.skipBits(1),e.readBits(1))){for(let f=0;f<(s!==3?8:12);f++)if(e.readBits(1)){let p=f<6?16:64,g=8,x=8;for(let y=0;y<p;y++){if(x!==0){let b=Te(e);x=(g+b+256)%256}g=x===0?g:x}}}I(e);let l=I(e);if(l===0)I(e);else if(l===1){e.skipBits(1),Te(e),Te(e);let u=I(e);for(let f=0;f<u;f++)Te(e)}I(e),e.skipBits(1),I(e),I(e);let d=e.readBits(1);return{profileIdc:n,constraintFlags:o,levelIdc:i,frameMbsOnlyFlag:d,chromaFormatIdc:s,bitDepthLumaMinus8:a,bitDepthChromaMinus8:c}}catch(e){return console.error("Error parsing AVC SPS:",e),null}},Wo=(r,e)=>{if(e.description){let o=(le(e.description)[21]&3)+1;return us(r,o)}else return cn(r)},Ie=r=>r[0]>>1&63,ps=r=>{try{let e=cn(r),t=e.filter(O=>Ie(O)===J.VPS_NUT),n=e.filter(O=>Ie(O)===J.SPS_NUT),o=e.filter(O=>Ie(O)===J.PPS_NUT),i=e.filter(O=>Ie(O)===J.PREFIX_SEI_NUT||Ie(O)===J.SUFFIX_SEI_NUT);if(n.length===0||o.length===0)return null;let s=n[0],a=new N(an(s));a.skipBits(16),a.readBits(4);let c=a.readBits(3),l=a.readBits(1),{general_profile_space:d,general_tier_flag:u,general_profile_idc:f,general_profile_compatibility_flags:m,general_constraint_indicator_flags:p,general_level_idc:g}=Pc(a,c);I(a);let x=I(a);x===3&&a.skipBits(1),I(a),I(a),a.readBits(1)&&(I(a),I(a),I(a),I(a));let y=I(a),b=I(a);I(a);let k=a.readBits(1)?0:c;for(let O=k;O<=c;O++)I(a),I(a),I(a);I(a),I(a),I(a),I(a),I(a),I(a),a.readBits(1)&&a.readBits(1)&&Cc(a),a.skipBits(1),a.skipBits(1),a.readBits(1)&&(a.skipBits(4),a.skipBits(4),I(a),I(a),a.skipBits(1));let P=I(a);if(Ic(a,P),a.readBits(1)){let O=I(a);for(let R=0;R<O;R++)I(a),a.skipBits(1)}a.skipBits(1),a.skipBits(1);let S=0;a.readBits(1)&&(S=_c(a,c));let _=0;if(o.length>0){let O=o[0],R=new N(an(O));R.skipBits(16),I(R),I(R),R.skipBits(1),R.skipBits(1),R.skipBits(3),R.skipBits(1),R.skipBits(1),I(R),I(R),Te(R),R.skipBits(1),R.skipBits(1),R.readBits(1)&&I(R),Te(R),Te(R),R.skipBits(1),R.skipBits(1),R.skipBits(1),R.skipBits(1);let j=R.readBits(1),Ge=R.readBits(1);!j&&!Ge?_=0:j&&!Ge?_=2:!j&&Ge?_=3:_=0}let C=[...t.length?[{arrayCompleteness:1,nalUnitType:J.VPS_NUT,nalUnits:t}]:[],...n.length?[{arrayCompleteness:1,nalUnitType:J.SPS_NUT,nalUnits:n}]:[],...o.length?[{arrayCompleteness:1,nalUnitType:J.PPS_NUT,nalUnits:o}]:[],...i.length?[{arrayCompleteness:1,nalUnitType:Ie(i[0]),nalUnits:i}]:[]];return{configurationVersion:1,generalProfileSpace:d,generalTierFlag:u,generalProfileIdc:f,generalProfileCompatibilityFlags:m,generalConstraintIndicatorFlags:p,generalLevelIdc:g,minSpatialSegmentationIdc:S,parallelismType:_,chromaFormatIdc:x,bitDepthLumaMinus8:y,bitDepthChromaMinus8:b,avgFrameRate:0,constantFrameRate:0,numTemporalLayers:c+1,temporalIdNested:l,lengthSizeMinusOne:3,arrays:C}}catch(e){return console.error("Error building HEVC Decoder Configuration Record:",e),null}},Pc=(r,e)=>{let t=r.readBits(2),n=r.readBits(1),o=r.readBits(5),i=0;for(let d=0;d<32;d++)i=i<<1|r.readBits(1);let s=new Uint8Array(6);for(let d=0;d<6;d++)s[d]=r.readBits(8);let a=r.readBits(8),c=[],l=[];for(let d=0;d<e;d++)c.push(r.readBits(1)),l.push(r.readBits(1));if(e>0)for(let d=e;d<8;d++)r.skipBits(2);for(let d=0;d<e;d++)c[d]&&r.skipBits(88),l[d]&&r.skipBits(8);return{general_profile_space:t,general_tier_flag:n,general_profile_idc:o,general_profile_compatibility_flags:i,general_constraint_indicator_flags:s,general_level_idc:a}},Cc=r=>{for(let e=0;e<4;e++)for(let t=0;t<(e===3?2:6);t++)if(!r.readBits(1))I(r);else{let o=Math.min(64,1<<4+(e<<1));e>1&&Te(r);for(let i=0;i<o;i++)Te(r)}},Ic=(r,e)=>{let t=[];for(let n=0;n<e;n++)t[n]=Ac(r,n,e,t)},Ac=(r,e,t,n)=>{let o=0,i=0,s=0;if(e!==0&&(i=r.readBits(1)),i){if(e===t){let c=I(r);s=e-(c+1)}else s=e-1;r.readBits(1),I(r);let a=n[s]??0;for(let c=0;c<=a;c++)r.readBits(1)||r.readBits(1);o=n[s]}else{let a=I(r),c=I(r);for(let l=0;l<a;l++)I(r),r.readBits(1);for(let l=0;l<c;l++)I(r),r.readBits(1);o=a+c}return o},_c=(r,e)=>{if(r.readBits(1)&&r.readBits(8)===255&&(r.readBits(16),r.readBits(16)),r.readBits(1)&&r.readBits(1),r.readBits(1)&&(r.readBits(3),r.readBits(1),r.readBits(1)&&(r.readBits(8),r.readBits(8),r.readBits(8))),r.readBits(1)&&(I(r),I(r)),r.readBits(1),r.readBits(1),r.readBits(1),r.readBits(1)&&(I(r),I(r),I(r),I(r)),r.readBits(1)&&(r.readBits(32),r.readBits(32),r.readBits(1)&&I(r),r.readBits(1)&&Ec(r,!0,e)),r.readBits(1)){r.readBits(1),r.readBits(1),r.readBits(1);let t=I(r);return I(r),I(r),I(r),I(r),t}return 0},Ec=(r,e,t)=>{let n=!1,o=!1,i=!1;e&&(n=r.readBits(1)===1,o=r.readBits(1)===1,(n||o)&&(i=r.readBits(1)===1,i&&(r.readBits(8),r.readBits(5),r.readBits(1),r.readBits(5)),r.readBits(4),r.readBits(4),i&&r.readBits(4),r.readBits(5),r.readBits(5),r.readBits(5)));for(let s=0;s<=t;s++){let a=r.readBits(1)===1,c=!0;a||(c=r.readBits(1)===1);let l=!1;c?I(r):l=r.readBits(1)===1;let d=1;l||(d=I(r)+1),n&&cs(r,d,i),o&&cs(r,d,i)}},cs=(r,e,t)=>{for(let n=0;n<e;n++)I(r),I(r),t&&(I(r),I(r)),r.readBits(1)};var ln=r=>{let e=new N(r);if(e.readBits(2)!==2)return null;let n=e.readBits(1),i=(e.readBits(1)<<1)+n;if(i===3&&e.skipBits(1),e.readBits(1)===1||e.readBits(1)!==0||(e.skipBits(2),e.readBits(24)!==4817730))return null;let l=8;i>=2&&(l=e.readBits(1)?12:10);let d=e.readBits(3),u=0,f=0;if(d!==7)if(f=e.readBits(1),i===1||i===3){let _=e.readBits(1),C=e.readBits(1);u=!_&&!C?3:_&&!C?2:1,e.skipBits(1)}else u=1;else u=3,f=1;let m=e.readBits(16),p=e.readBits(16),g=m+1,x=p+1,y=g*x,b=Y(et).level;for(let S of et)if(y<=S.maxPictureSize){b=S.level;break}return{profile:i,level:b,bitDepth:l,chromaSubsampling:u,videoFullRangeFlag:f,colourPrimaries:d===2?1:d===1?6:2,transferCharacteristics:d===2?1:d===1?6:2,matrixCoefficients:d===7?0:d===2?1:d===1?6:2}},hs=function*(r){let e=new N(r),t=()=>{let n=0;for(let o=0;o<8;o++){let i=e.readAlignedByte();if(n|=(i&127)<<o*7,!(i&128))break;if(o===7&&i&128)return null}return n>=2**32-1?null:n};for(;e.getBitsLeft()>=8;){e.skipBits(1);let n=e.readBits(4),o=e.readBits(1),i=e.readBits(1);e.skipBits(1),o&&e.skipBits(8);let s;if(i){let a=t();if(a===null)return;s=a}else s=Math.floor(e.getBitsLeft()/8);h(e.pos%8===0),yield{type:n,data:r.subarray(e.pos/8,e.pos/8+s)},e.skipBits(s*8)}},un=r=>{for(let{type:e,data:t}of hs(r)){if(e!==1)continue;let n=new N(t),o=n.readBits(3),i=n.readBits(1),s=n.readBits(1),a=0,c=0,l=0;if(s)a=n.readBits(5);else{if(n.readBits(1)&&(n.skipBits(32),n.skipBits(32),n.readBits(1)))return null;let S=n.readBits(1);S&&(l=n.readBits(5),n.skipBits(32),n.skipBits(5),n.skipBits(5));let _=n.readBits(5);for(let C=0;C<=_;C++){n.skipBits(12);let F=n.readBits(5);if(C===0&&(a=F),F>7){let R=n.readBits(1);C===0&&(c=R)}if(S&&n.readBits(1)){let j=l+1;n.skipBits(j),n.skipBits(j),n.skipBits(1)}n.readBits(1)&&n.skipBits(4)}}let d=n.readBits(4),u=n.readBits(4),f=d+1;n.skipBits(f);let m=u+1;n.skipBits(m);let p=0;if(s?p=0:p=n.readBits(1),p&&(n.skipBits(4),n.skipBits(3)),n.skipBits(1),n.skipBits(1),n.skipBits(1),!s){n.skipBits(1),n.skipBits(1),n.skipBits(1),n.skipBits(1);let P=n.readBits(1);P&&(n.skipBits(1),n.skipBits(1));let S=n.readBits(1),_=0;S?_=2:_=n.readBits(1),_>0&&(n.readBits(1)||n.skipBits(1)),P&&n.skipBits(3)}n.skipBits(1),n.skipBits(1),n.skipBits(1);let g=n.readBits(1),x=8;o===2&&g?x=n.readBits(1)?12:10:o<=2&&(x=g?10:8);let y=0;o!==1&&(y=n.readBits(1));let b=1,w=1,k=0;return y||(o===0?(b=1,w=1):o===1?(b=0,w=0):x===12&&(b=n.readBits(1),b&&(w=n.readBits(1))),b&&w&&(k=n.readBits(2))),{profile:o,level:a,tier:c,bitDepth:x,monochrome:y,chromaSubsamplingX:b,chromaSubsamplingY:w,chromaSamplePosition:k}}return null},gs=r=>{let e=z(r),t=e.getUint8(9),n=e.getUint16(10,!0),o=e.getUint32(12,!0),i=e.getInt16(16,!0),s=e.getUint8(18),a=null;return s&&(a=r.subarray(19,21+t)),{outputChannelCount:t,preSkip:n,inputSampleRate:o,outputGain:i,channelMappingFamily:s,channelMappingTable:a}},Fc=[480,960,1920,2880,480,960,1920,2880,480,960,1920,2880,480,960,480,960,120,240,480,960,120,240,480,960,120,240,480,960,120,240,480,960],xs=r=>{let e=r[0]>>3;return{durationInSamples:Fc[e]}},bs=r=>{if(r.length<7)throw new Error("Setup header is too short.");if(r[0]!==5)throw new Error("Wrong packet type in Setup header.");if(String.fromCharCode(...r.slice(1,7))!=="vorbis")throw new Error("Invalid packet signature in Setup header.");let t=r.length,n=new Uint8Array(t);for(let u=0;u<t;u++)n[u]=r[t-1-u];let o=new N(n),i=0;for(;o.getBitsLeft()>97;)if(o.readBits(1)===1){i=o.pos;break}if(i===0)throw new Error("Invalid Setup header: framing bit not found.");let s=0,a=!1,c=0;for(;o.getBitsLeft()>=97;){let u=o.pos,f=o.readBits(8),m=o.readBits(16),p=o.readBits(16);if(f>63||m!==0||p!==0){o.pos=u;break}if(o.skipBits(1),s++,s>64)break;o.clone().readBits(6)+1===s&&(a=!0,c=s)}if(!a)throw new Error("Invalid Setup header: mode header not found.");if(c>63)throw new Error(`Unsupported mode count: ${c}.`);let l=c;o.pos=0,o.skipBits(i);let d=Array(l).fill(0);for(let u=l-1;u>=0;u--)o.skipBits(40),d[u]=o.readBits(1);return{modeBlockflags:d}},dn=(r,e,t)=>{switch(r){case"avc":{let n=qo(t,e),o=n.some(i=>nt(i)===rt.IDR);if(!o&&(!nr()||os()>=144))for(let i of n){if(nt(i)!==rt.SEI)continue;let a=an(i),c=1;do{let l=0;for(;;){let f=a[c++];if(f===void 0||(l+=f,f<255))break}let d=0;for(;;){let f=a[c++];if(f===void 0||(d+=f,f<255))break}if(l===6){let f=new N(a);f.pos=8*c;let m=I(f),p=f.readBits(1);if(m===0&&p===1){o=!0;break}}c+=d}while(c<a.length-1)}return o?"key":"delta"}case"hevc":return Wo(t,e).some(i=>{let s=Ie(i);return J.BLA_W_LP<=s&&s<=J.RSV_IRAP_VCL23})?"key":"delta";case"vp8":return(t[0]&1)===0?"key":"delta";case"vp9":{let n=new N(t);if(n.readBits(2)!==2)return null;let o=n.readBits(1);return(n.readBits(1)<<1)+o===3&&n.skipBits(1),n.readBits(1)?null:n.readBits(1)===0?"key":"delta"}case"av1":{let n=!1;for(let{type:o,data:i}of hs(t))if(o===1){let s=new N(i);s.skipBits(4),n=!!s.readBits(1)}else if(o===3||o===6||o===7){if(n)return"key";let s=new N(i);return s.readBits(1)?null:s.readBits(2)===0?"key":"delta"}return null}default:se(r),h(!1)}},Ue;(function(r){r[r.STREAMINFO=0]="STREAMINFO",r[r.VORBIS_COMMENT=4]="VORBIS_COMMENT",r[r.PICTURE=6]="PICTURE"})(Ue||(Ue={}));var sr=(r,e)=>{let t=z(r),n=0,o=t.getUint32(n,!0);n+=4;let i=$.decode(r.subarray(n,n+o));n+=o,o>0&&(e.raw??={},e.raw.vendor??=i);let s=t.getUint32(n,!0);n+=4;for(let a=0;a<s;a++){let c=t.getUint32(n,!0);n+=4;let l=$.decode(r.subarray(n,n+c));n+=c;let d=l.indexOf("=");if(d===-1)continue;let u=l.slice(0,d).toUpperCase(),f=l.slice(d+1);switch(e.raw??={},e.raw[u]??=f,u){case"TITLE":e.title??=f;break;case"DESCRIPTION":e.description??=f;break;case"ARTIST":e.artist??=f;break;case"ALBUM":e.album??=f;break;case"ALBUMARTIST":e.albumArtist??=f;break;case"COMMENT":e.comment??=f;break;case"LYRICS":e.lyrics??=f;break;case"TRACKNUMBER":{let m=f.split("/"),p=Number.parseInt(m[0],10),g=m[1]&&Number.parseInt(m[1],10);Number.isInteger(p)&&p>0&&(e.trackNumber??=p),g&&Number.isInteger(g)&&g>0&&(e.tracksTotal??=g)}break;case"TRACKTOTAL":{let m=Number.parseInt(f,10);Number.isInteger(m)&&m>0&&(e.tracksTotal??=m)}break;case"DISCNUMBER":{let m=f.split("/"),p=Number.parseInt(m[0],10),g=m[1]&&Number.parseInt(m[1],10);Number.isInteger(p)&&p>0&&(e.discNumber??=p),g&&Number.isInteger(g)&&g>0&&(e.discsTotal??=g)}break;case"DISCTOTAL":{let m=Number.parseInt(f,10);Number.isInteger(m)&&m>0&&(e.discsTotal??=m)}break;case"DATE":{let m=new Date(f);Number.isNaN(m.getTime())||(e.date??=m)}break;case"GENRE":e.genre??=f;break;case"METADATA_BLOCK_PICTURE":{let m=is(f),p=z(m),g=p.getUint32(0,!1),x=p.getUint32(4,!1),y=String.fromCharCode(...m.subarray(8,8+x)),b=p.getUint32(8+x,!1),w=$.decode(m.subarray(12+x,12+x+b)),k=p.getUint32(x+b+28),P=m.subarray(x+b+32,x+b+32+k);e.images??=[],e.images.push({data:P,mimeType:y,kind:g===3?"coverFront":g===4?"coverBack":"unknown",name:void 0,description:w||void 0})}break}}};var Q=class{constructor(e){this.input=e}};var fn=[],mn=[];var H=new Uint8Array(0),V=class r{constructor(e,t,n,o,i=-1,s,a){if(this.data=e,this.type=t,this.timestamp=n,this.duration=o,this.sequenceNumber=i,e===H&&s===void 0)throw new Error("Internal error: byteLength must be explicitly provided when constructing metadata-only packets.");if(s===void 0&&(s=e.byteLength),!(e instanceof Uint8Array))throw new TypeError("data must be a Uint8Array.");if(t!=="key"&&t!=="delta")throw new TypeError('type must be either "key" or "delta".');if(!Number.isFinite(n))throw new TypeError("timestamp must be a number.");if(!Number.isFinite(o)||o<0)throw new TypeError("duration must be a non-negative number.");if(!Number.isFinite(i))throw new TypeError("sequenceNumber must be a number.");if(!Number.isInteger(s)||s<0)throw new TypeError("byteLength must be a non-negative integer.");if(a!==void 0&&(typeof a!="object"||!a))throw new TypeError("sideData, when provided, must be an object.");if(a?.alpha!==void 0&&!(a.alpha instanceof Uint8Array))throw new TypeError("sideData.alpha, when provided, must be a Uint8Array.");if(a?.alphaByteLength!==void 0&&(!Number.isInteger(a.alphaByteLength)||a.alphaByteLength<0))throw new TypeError("sideData.alphaByteLength, when provided, must be a non-negative integer.");this.byteLength=s,this.sideData=a??{},this.sideData.alpha&&this.sideData.alphaByteLength===void 0&&(this.sideData.alphaByteLength=this.sideData.alpha.byteLength)}get isMetadataOnly(){return this.data===H}get microsecondTimestamp(){return Math.trunc(we*this.timestamp)}get microsecondDuration(){return Math.trunc(we*this.duration)}toEncodedVideoChunk(){if(this.isMetadataOnly)throw new TypeError("Metadata-only packets cannot be converted to a video chunk.");if(typeof EncodedVideoChunk>"u")throw new Error("Your browser does not support EncodedVideoChunk.");return new EncodedVideoChunk({data:this.data,type:this.type,timestamp:this.microsecondTimestamp,duration:this.microsecondDuration})}alphaToEncodedVideoChunk(e=this.type){if(!this.sideData.alpha)throw new TypeError("This packet does not contain alpha side data.");if(this.isMetadataOnly)throw new TypeError("Metadata-only packets cannot be converted to a video chunk.");if(typeof EncodedVideoChunk>"u")throw new Error("Your browser does not support EncodedVideoChunk.");return new EncodedVideoChunk({data:this.sideData.alpha,type:e,timestamp:this.microsecondTimestamp,duration:this.microsecondDuration})}toEncodedAudioChunk(){if(this.isMetadataOnly)throw new TypeError("Metadata-only packets cannot be converted to an audio chunk.");if(typeof EncodedAudioChunk>"u")throw new Error("Your browser does not support EncodedAudioChunk.");return new EncodedAudioChunk({data:this.data,type:this.type,timestamp:this.microsecondTimestamp,duration:this.microsecondDuration})}static fromEncodedChunk(e,t){if(!(e instanceof EncodedVideoChunk||e instanceof EncodedAudioChunk))throw new TypeError("chunk must be an EncodedVideoChunk or EncodedAudioChunk.");let n=new Uint8Array(e.byteLength);return e.copyTo(n),new r(n,e.type,e.timestamp/1e6,(e.duration??0)/1e6,void 0,void 0,t)}clone(e){if(e!==void 0&&(typeof e!="object"||e===null))throw new TypeError("options, when provided, must be an object.");if(e?.timestamp!==void 0&&!Number.isFinite(e.timestamp))throw new TypeError("options.timestamp, when provided, must be a number.");if(e?.duration!==void 0&&!Number.isFinite(e.duration))throw new TypeError("options.duration, when provided, must be a number.");return new r(this.data,this.type,e?.timestamp??this.timestamp,e?.duration??this.duration,this.sequenceNumber,this.byteLength)}};var ys=r=>{let t=0,n=0,o=~r;o&128&&(o&=-129,t=-1),n=((o&240)>>4)+5;let i=(1<<n|(o&15)<<n-4|1<<n-5)-33;return t===0?i:-i};var Ts=r=>{let e=0,t=0,n=r^85;n&128&&(n&=-129,e=-1),t=((n&240)>>4)+4;let o=0;return t!==4?o=1<<t|(n&15)<<t-4|1<<t-5:o=n<<1|1,e===0?o:-o};tn();var ws=-1/0,ks=-1/0,lr=null;typeof FinalizationRegistry<"u"&&(lr=new FinalizationRegistry(r=>{let e=Date.now();r.type==="video"?(e-ws>=1e3&&(console.error("A VideoSample was garbage collected without first being closed. For proper resource management, make sure to call close() on all your VideoSamples as soon as you're done using them."),ws=e),typeof VideoFrame<"u"&&r.data instanceof VideoFrame&&r.data.close()):(e-ks>=1e3&&(console.error("An AudioSample was garbage collected without first being closed. For proper resource management, make sure to call close() on all your AudioSamples as soon as you're done using them."),ks=e),typeof AudioData<"u"&&r.data instanceof AudioData&&r.data.close())}));var vs=["I420","I420P10","I420P12","I420A","I420AP10","I420AP12","I422","I422P10","I422P12","I422A","I422AP10","I422AP12","I444","I444P10","I444P12","I444A","I444AP10","I444AP12","NV12","RGBA","RGBX","BGRA","BGRX"],Dc=new Set(vs),St=class r{get displayWidth(){return this.rotation%180===0?this.codedWidth:this.codedHeight}get displayHeight(){return this.rotation%180===0?this.codedHeight:this.codedWidth}get microsecondTimestamp(){return Math.trunc(we*this.timestamp)}get microsecondDuration(){return Math.trunc(we*this.duration)}get hasAlpha(){return this.format&&this.format.includes("A")}constructor(e,t){if(this._closed=!1,e instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&e instanceof SharedArrayBuffer||ArrayBuffer.isView(e)){if(!t||typeof t!="object")throw new TypeError("init must be an object.");if(t.format===void 0||!Dc.has(t.format))throw new TypeError("init.format must be one of: "+vs.join(", "));if(!Number.isInteger(t.codedWidth)||t.codedWidth<=0)throw new TypeError("init.codedWidth must be a positive integer.");if(!Number.isInteger(t.codedHeight)||t.codedHeight<=0)throw new TypeError("init.codedHeight must be a positive integer.");if(t.rotation!==void 0&&![0,90,180,270].includes(t.rotation))throw new TypeError("init.rotation, when provided, must be 0, 90, 180, or 270.");if(!Number.isFinite(t.timestamp))throw new TypeError("init.timestamp must be a number.");if(t.duration!==void 0&&(!Number.isFinite(t.duration)||t.duration<0))throw new TypeError("init.duration, when provided, must be a non-negative number.");this._data=le(e).slice(),this._layout=t.layout??Rc(t.format,t.codedWidth,t.codedHeight),this.format=t.format,this.codedWidth=t.codedWidth,this.codedHeight=t.codedHeight,this.rotation=t.rotation??0,this.timestamp=t.timestamp,this.duration=t.duration??0,this.colorSpace=new cr(t.colorSpace)}else if(typeof VideoFrame<"u"&&e instanceof VideoFrame){if(t?.rotation!==void 0&&![0,90,180,270].includes(t.rotation))throw new TypeError("init.rotation, when provided, must be 0, 90, 180, or 270.");if(t?.timestamp!==void 0&&!Number.isFinite(t?.timestamp))throw new TypeError("init.timestamp, when provided, must be a number.");if(t?.duration!==void 0&&(!Number.isFinite(t.duration)||t.duration<0))throw new TypeError("init.duration, when provided, must be a non-negative number.");this._data=e,this._layout=null,this.format=e.format,this.codedWidth=e.displayWidth,this.codedHeight=e.displayHeight,this.rotation=t?.rotation??0,this.timestamp=t?.timestamp??e.timestamp/1e6,this.duration=t?.duration??(e.duration??0)/1e6,this.colorSpace=new cr(e.colorSpace)}else if(typeof HTMLImageElement<"u"&&e instanceof HTMLImageElement||typeof SVGImageElement<"u"&&e instanceof SVGImageElement||typeof ImageBitmap<"u"&&e instanceof ImageBitmap||typeof HTMLVideoElement<"u"&&e instanceof HTMLVideoElement||typeof HTMLCanvasElement<"u"&&e instanceof HTMLCanvasElement||typeof OffscreenCanvas<"u"&&e instanceof OffscreenCanvas){if(!t||typeof t!="object")throw new TypeError("init must be an object.");if(t.rotation!==void 0&&![0,90,180,270].includes(t.rotation))throw new TypeError("init.rotation, when provided, must be 0, 90, 180, or 270.");if(!Number.isFinite(t.timestamp))throw new TypeError("init.timestamp must be a number.");if(t.duration!==void 0&&(!Number.isFinite(t.duration)||t.duration<0))throw new TypeError("init.duration, when provided, must be a non-negative number.");if(typeof VideoFrame<"u")return new r(new VideoFrame(e,{timestamp:Math.trunc(t.timestamp*we),duration:Math.trunc((t.duration??0)*we)||void 0}),t);let n=0,o=0;if("naturalWidth"in e?(n=e.naturalWidth,o=e.naturalHeight):"videoWidth"in e?(n=e.videoWidth,o=e.videoHeight):"width"in e&&(n=Number(e.width),o=Number(e.height)),!n||!o)throw new TypeError("Could not determine dimensions.");let i=new OffscreenCanvas(n,o),s=i.getContext("2d",{alpha:rr(),willReadFrequently:!0});h(s),s.drawImage(e,0,0),this._data=i,this._layout=null,this.format="RGBX",this.codedWidth=n,this.codedHeight=o,this.rotation=t.rotation??0,this.timestamp=t.timestamp,this.duration=t.duration??0,this.colorSpace=new cr({matrix:"rgb",primaries:"bt709",transfer:"iec61966-2-1",fullRange:!0})}else throw new TypeError("Invalid data type: Must be a BufferSource or CanvasImageSource.");lr?.register(this,{type:"video",data:this._data},this)}clone(){if(this._closed)throw new Error("VideoSample is closed.");return h(this._data!==null),ot(this._data)?new r(this._data.clone(),{timestamp:this.timestamp,duration:this.duration,rotation:this.rotation}):this._data instanceof Uint8Array?(h(this._layout),new r(this._data,{format:this.format,layout:this._layout,codedWidth:this.codedWidth,codedHeight:this.codedHeight,timestamp:this.timestamp,duration:this.duration,colorSpace:this.colorSpace,rotation:this.rotation})):new r(this._data,{format:this.format,codedWidth:this.codedWidth,codedHeight:this.codedHeight,timestamp:this.timestamp,duration:this.duration,colorSpace:this.colorSpace,rotation:this.rotation})}close(){this._closed||(lr?.unregister(this),ot(this._data)?this._data.close():this._data=null,this._closed=!0)}allocationSize(e={}){if(Ss(e),this._closed)throw new Error("VideoSample is closed.");if((e.format??this.format)===null)throw new Error("Cannot get allocation size when format is null. Please manually provide an RGB pixel format in the options instead.");if(h(this._data!==null),!ot(this._data)&&(e.colorSpace||e.format&&e.format!==this.format||e.layout||e.rect)){let t=this.toVideoFrame(),n=t.allocationSize(e);return t.close(),n}return ot(this._data)?this._data.allocationSize(e):this._data instanceof Uint8Array?this._data.byteLength:this.codedWidth*this.codedHeight*4}async copyTo(e,t={}){if(!Yr(e))throw new TypeError("destination must be an ArrayBuffer or an ArrayBuffer view.");if(Ss(t),this._closed)throw new Error("VideoSample is closed.");if((t.format??this.format)===null)throw new Error("Cannot copy video sample data when format is null. Please manually provide an RGB pixel format in the options instead.");if(h(this._data!==null),!ot(this._data)&&(t.colorSpace||t.format&&t.format!==this.format||t.layout||t.rect)){let n=this.toVideoFrame(),o=await n.copyTo(e,t);return n.close(),o}if(ot(this._data))return this._data.copyTo(e,t);if(this._data instanceof Uint8Array)return h(this._layout),le(e).set(this._data),this._layout;{let o=this._data.getContext("2d");h(o);let i=o.getImageData(0,0,this.codedWidth,this.codedHeight);return le(e).set(i.data),[{offset:0,stride:4*this.codedWidth}]}}toVideoFrame(){if(this._closed)throw new Error("VideoSample is closed.");return h(this._data!==null),ot(this._data)?new VideoFrame(this._data,{timestamp:this.microsecondTimestamp,duration:this.microsecondDuration||void 0}):this._data instanceof Uint8Array?new VideoFrame(this._data,{format:this.format,codedWidth:this.codedWidth,codedHeight:this.codedHeight,timestamp:this.microsecondTimestamp,duration:this.microsecondDuration||void 0,colorSpace:this.colorSpace}):new VideoFrame(this._data,{timestamp:this.microsecondTimestamp,duration:this.microsecondDuration||void 0})}draw(e,t,n,o,i,s,a,c,l){let d=0,u=0,f=this.displayWidth,m=this.displayHeight,p=0,g=0,x=this.displayWidth,y=this.displayHeight;if(s!==void 0?(d=t,u=n,f=o,m=i,p=s,g=a,c!==void 0?(x=c,y=l):(x=f,y=m)):(p=t,g=n,o!==void 0&&(x=o,y=i)),!(typeof CanvasRenderingContext2D<"u"&&e instanceof CanvasRenderingContext2D||typeof OffscreenCanvasRenderingContext2D<"u"&&e instanceof OffscreenCanvasRenderingContext2D))throw new TypeError("context must be a CanvasRenderingContext2D or OffscreenCanvasRenderingContext2D.");if(!Number.isFinite(d))throw new TypeError("sx must be a number.");if(!Number.isFinite(u))throw new TypeError("sy must be a number.");if(!Number.isFinite(f)||f<0)throw new TypeError("sWidth must be a non-negative number.");if(!Number.isFinite(m)||m<0)throw new TypeError("sHeight must be a non-negative number.");if(!Number.isFinite(p))throw new TypeError("dx must be a number.");if(!Number.isFinite(g))throw new TypeError("dy must be a number.");if(!Number.isFinite(x)||x<0)throw new TypeError("dWidth must be a non-negative number.");if(!Number.isFinite(y)||y<0)throw new TypeError("dHeight must be a non-negative number.");if(this._closed)throw new Error("VideoSample is closed.");({sx:d,sy:u,sWidth:f,sHeight:m}=this._rotateSourceRegion(d,u,f,m,this.rotation));let b=this.toCanvasImageSource();e.save();let w=p+x/2,k=g+y/2;e.translate(w,k),e.rotate(this.rotation*Math.PI/180);let P=this.rotation%180===0?1:x/y;e.scale(1/P,P),e.drawImage(b,d,u,f,m,-x/2,-y/2,x,y),e.restore()}drawWithFit(e,t){if(!(typeof CanvasRenderingContext2D<"u"&&e instanceof CanvasRenderingContext2D||typeof OffscreenCanvasRenderingContext2D<"u"&&e instanceof OffscreenCanvasRenderingContext2D))throw new TypeError("context must be a CanvasRenderingContext2D or OffscreenCanvasRenderingContext2D.");if(!t||typeof t!="object")throw new TypeError("options must be an object.");if(!["fill","contain","cover"].includes(t.fit))throw new TypeError("options.fit must be 'fill', 'contain', or 'cover'.");if(t.rotation!==void 0&&![0,90,180,270].includes(t.rotation))throw new TypeError("options.rotation, when provided, must be 0, 90, 180, or 270.");t.crop!==void 0&&Ko(t.crop,"options.");let n=e.canvas.width,o=e.canvas.height,i=t.rotation??this.rotation,[s,a]=i%180===0?[this.codedWidth,this.codedHeight]:[this.codedHeight,this.codedWidth];t.crop&&$o(t.crop,s,a);let c,l,d,u,{sx:f,sy:m,sWidth:p,sHeight:g}=this._rotateSourceRegion(t.crop?.left??0,t.crop?.top??0,t.crop?.width??s,t.crop?.height??a,i);if(t.fit==="fill")c=0,l=0,d=n,u=o;else{let[y,b]=t.crop?[t.crop.width,t.crop.height]:[s,a],w=t.fit==="contain"?Math.min(n/y,o/b):Math.max(n/y,o/b);d=y*w,u=b*w,c=(n-d)/2,l=(o-u)/2}e.save();let x=i%180===0?1:d/u;e.translate(n/2,o/2),e.rotate(i*Math.PI/180),e.scale(1/x,x),e.translate(-n/2,-o/2),e.drawImage(this.toCanvasImageSource(),f,m,p,g,c,l,d,u),e.restore()}_rotateSourceRegion(e,t,n,o,i){return i===90?[e,t,n,o]=[t,this.codedHeight-e-n,o,n]:i===180?[e,t]=[this.codedWidth-e-n,this.codedHeight-t-o]:i===270&&([e,t,n,o]=[this.codedWidth-t-o,e,o,n]),{sx:e,sy:t,sWidth:n,sHeight:o}}toCanvasImageSource(){if(this._closed)throw new Error("VideoSample is closed.");if(h(this._data!==null),this._data instanceof Uint8Array){let e=this.toVideoFrame();return queueMicrotask(()=>e.close()),e}else return this._data}setRotation(e){if(![0,90,180,270].includes(e))throw new TypeError("newRotation must be 0, 90, 180, or 270.");this.rotation=e}setTimestamp(e){if(!Number.isFinite(e))throw new TypeError("newTimestamp must be a number.");this.timestamp=e}setDuration(e){if(!Number.isFinite(e)||e<0)throw new TypeError("newDuration must be a non-negative number.");this.duration=e}[Symbol.dispose](){this.close()}},cr=class{constructor(e){this.primaries=e?.primaries??null,this.transfer=e?.transfer??null,this.matrix=e?.matrix??null,this.fullRange=e?.fullRange??null}toJSON(){return{primaries:this.primaries,transfer:this.transfer,matrix:this.matrix,fullRange:this.fullRange}}},ot=r=>typeof VideoFrame<"u"&&r instanceof VideoFrame,$o=(r,e,t)=>{r.left=Math.min(r.left,e),r.top=Math.min(r.top,t),r.width=Math.min(r.width,e-r.left),r.height=Math.min(r.height,t-r.top),h(r.width>=0),h(r.height>=0)},Ko=(r,e)=>{if(!r||typeof r!="object")throw new TypeError(e+"crop, when provided, must be an object.");if(!Number.isInteger(r.left)||r.left<0)throw new TypeError(e+"crop.left must be a non-negative integer.");if(!Number.isInteger(r.top)||r.top<0)throw new TypeError(e+"crop.top must be a non-negative integer.");if(!Number.isInteger(r.width)||r.width<0)throw new TypeError(e+"crop.width must be a non-negative integer.");if(!Number.isInteger(r.height)||r.height<0)throw new TypeError(e+"crop.height must be a non-negative integer.")},Ss=r=>{if(!r||typeof r!="object")throw new TypeError("options must be an object.");if(r.colorSpace!==void 0&&!["display-p3","srgb"].includes(r.colorSpace))throw new TypeError("options.colorSpace, when provided, must be 'display-p3' or 'srgb'.");if(r.format!==void 0&&typeof r.format!="string")throw new TypeError("options.format, when provided, must be a string.");if(r.layout!==void 0){if(!Array.isArray(r.layout))throw new TypeError("options.layout, when provided, must be an array.");for(let e of r.layout){if(!e||typeof e!="object")throw new TypeError("Each entry in options.layout must be an object.");if(!Number.isInteger(e.offset)||e.offset<0)throw new TypeError("plane.offset must be a non-negative integer.");if(!Number.isInteger(e.stride)||e.stride<0)throw new TypeError("plane.stride must be a non-negative integer.")}}if(r.rect!==void 0){if(!r.rect||typeof r.rect!="object")throw new TypeError("options.rect, when provided, must be an object.");if(r.rect.x!==void 0&&(!Number.isInteger(r.rect.x)||r.rect.x<0))throw new TypeError("options.rect.x, when provided, must be a non-negative integer.");if(r.rect.y!==void 0&&(!Number.isInteger(r.rect.y)||r.rect.y<0))throw new TypeError("options.rect.y, when provided, must be a non-negative integer.");if(r.rect.width!==void 0&&(!Number.isInteger(r.rect.width)||r.rect.width<0))throw new TypeError("options.rect.width, when provided, must be a non-negative integer.");if(r.rect.height!==void 0&&(!Number.isInteger(r.rect.height)||r.rect.height<0))throw new TypeError("options.rect.height, when provided, must be a non-negative integer.")}},Rc=(r,e,t)=>{let n=Mc(r),o=[],i=0;for(let s of n){let a=Math.ceil(e/s.widthDivisor),c=Math.ceil(t/s.heightDivisor),l=a*s.sampleBytes,d=l*c;o.push({offset:i,stride:l}),i+=d}return o},Mc=r=>{let e=(t,n,o,i,s)=>{let a=[{sampleBytes:t,widthDivisor:1,heightDivisor:1},{sampleBytes:n,widthDivisor:o,heightDivisor:i},{sampleBytes:n,widthDivisor:o,heightDivisor:i}];return s&&a.push({sampleBytes:t,widthDivisor:1,heightDivisor:1}),a};switch(r){case"I420":return e(1,1,2,2,!1);case"I420P10":case"I420P12":return e(2,2,2,2,!1);case"I420A":return e(1,1,2,2,!0);case"I420AP10":case"I420AP12":return e(2,2,2,2,!0);case"I422":return e(1,1,2,1,!1);case"I422P10":case"I422P12":return e(2,2,2,1,!1);case"I422A":return e(1,1,2,1,!0);case"I422AP10":case"I422AP12":return e(2,2,2,1,!0);case"I444":return e(1,1,1,1,!1);case"I444P10":case"I444P12":return e(2,2,1,1,!1);case"I444A":return e(1,1,1,1,!0);case"I444AP10":case"I444AP12":return e(2,2,1,1,!0);case"NV12":return[{sampleBytes:1,widthDivisor:1,heightDivisor:1},{sampleBytes:2,widthDivisor:2,heightDivisor:2}];case"RGBA":case"RGBX":case"BGRA":case"BGRX":return[{sampleBytes:4,widthDivisor:1,heightDivisor:1}];default:se(r),h(!1)}},jo=new Set(["f32","f32-planar","s16","s16-planar","s32","s32-planar","u8","u8-planar"]),vt=class r{get microsecondTimestamp(){return Math.trunc(we*this.timestamp)}get microsecondDuration(){return Math.trunc(we*this.duration)}constructor(e){if(this._closed=!1,ar(e)){if(e.format===null)throw new TypeError("AudioData with null format is not supported.");this._data=e,this.format=e.format,this.sampleRate=e.sampleRate,this.numberOfFrames=e.numberOfFrames,this.numberOfChannels=e.numberOfChannels,this.timestamp=e.timestamp/1e6,this.duration=e.numberOfFrames/e.sampleRate}else{if(!e||typeof e!="object")throw new TypeError("Invalid AudioDataInit: must be an object.");if(!jo.has(e.format))throw new TypeError("Invalid AudioDataInit: invalid format.");if(!Number.isFinite(e.sampleRate)||e.sampleRate<=0)throw new TypeError("Invalid AudioDataInit: sampleRate must be > 0.");if(!Number.isInteger(e.numberOfChannels)||e.numberOfChannels===0)throw new TypeError("Invalid AudioDataInit: numberOfChannels must be an integer > 0.");if(!Number.isFinite(e?.timestamp))throw new TypeError("init.timestamp must be a number.");let t=e.data.byteLength/(it(e.format)*e.numberOfChannels);if(!Number.isInteger(t))throw new TypeError("Invalid AudioDataInit: data size is not a multiple of frame size.");this.format=e.format,this.sampleRate=e.sampleRate,this.numberOfFrames=t,this.numberOfChannels=e.numberOfChannels,this.timestamp=e.timestamp,this.duration=t/e.sampleRate;let n;if(e.data instanceof ArrayBuffer)n=new Uint8Array(e.data);else if(ArrayBuffer.isView(e.data))n=new Uint8Array(e.data.buffer,e.data.byteOffset,e.data.byteLength);else throw new TypeError("Invalid AudioDataInit: data is not a BufferSource.");let o=this.numberOfFrames*this.numberOfChannels*it(this.format);if(n.byteLength<o)throw new TypeError("Invalid AudioDataInit: insufficient data size.");this._data=n}lr?.register(this,{type:"audio",data:this._data},this)}allocationSize(e){if(!e||typeof e!="object")throw new TypeError("options must be an object.");if(!Number.isInteger(e.planeIndex)||e.planeIndex<0)throw new TypeError("planeIndex must be a non-negative integer.");if(e.format!==void 0&&!jo.has(e.format))throw new TypeError("Invalid format.");if(e.frameOffset!==void 0&&(!Number.isInteger(e.frameOffset)||e.frameOffset<0))throw new TypeError("frameOffset must be a non-negative integer.");if(e.frameCount!==void 0&&(!Number.isInteger(e.frameCount)||e.frameCount<0))throw new TypeError("frameCount must be a non-negative integer.");if(this._closed)throw new Error("AudioSample is closed.");let t=e.format??this.format,n=e.frameOffset??0;if(n>=this.numberOfFrames)throw new RangeError("frameOffset out of range");let o=e.frameCount!==void 0?e.frameCount:this.numberOfFrames-n;if(o>this.numberOfFrames-n)throw new RangeError("frameCount out of range");let i=it(t),s=kt(t);if(s&&e.planeIndex>=this.numberOfChannels)throw new RangeError("planeIndex out of range");if(!s&&e.planeIndex!==0)throw new RangeError("planeIndex out of range");return(s?o:o*this.numberOfChannels)*i}copyTo(e,t){if(!Yr(e))throw new TypeError("destination must be an ArrayBuffer or an ArrayBuffer view.");if(!t||typeof t!="object")throw new TypeError("options must be an object.");if(!Number.isInteger(t.planeIndex)||t.planeIndex<0)throw new TypeError("planeIndex must be a non-negative integer.");if(t.format!==void 0&&!jo.has(t.format))throw new TypeError("Invalid format.");if(t.frameOffset!==void 0&&(!Number.isInteger(t.frameOffset)||t.frameOffset<0))throw new TypeError("frameOffset must be a non-negative integer.");if(t.frameCount!==void 0&&(!Number.isInteger(t.frameCount)||t.frameCount<0))throw new TypeError("frameCount must be a non-negative integer.");if(this._closed)throw new Error("AudioSample is closed.");let{planeIndex:n,format:o,frameCount:i,frameOffset:s}=t,a=this.format,c=o??this.format;if(!c)throw new Error("Destination format not determined");let l=this.numberOfFrames,d=this.numberOfChannels,u=s??0;if(u>=l)throw new RangeError("frameOffset out of range");let f=i!==void 0?i:l-u;if(f>l-u)throw new RangeError("frameCount out of range");let m=it(c),p=kt(c);if(p&&n>=d)throw new RangeError("planeIndex out of range");if(!p&&n!==0)throw new RangeError("planeIndex out of range");let x=(p?f:f*d)*m;if(e.byteLength<x)throw new RangeError("Destination buffer is too small");let y=z(e),b=Cs(c);if(ar(this._data))Be()&&d>2&&c!==a?Bc(this._data,y,a,c,d,n,u,f):this._data.copyTo(e,{planeIndex:n,frameOffset:u,frameCount:f,format:c});else{let w=this._data,k=z(w),P=Ps(a),S=it(a),_=kt(a);for(let C=0;C<f;C++)if(p){let F=C*m,O;_?O=(n*l+(C+u))*S:O=((C+u)*d+n)*S;let R=P(k,O);b(y,F,R)}else for(let F=0;F<d;F++){let R=(C*d+F)*m,j;_?j=(F*l+(C+u))*S:j=((C+u)*d+F)*S;let Ge=P(k,j);b(y,R,Ge)}}}clone(){if(this._closed)throw new Error("AudioSample is closed.");if(ar(this._data)){let e=new r(this._data.clone());return e.setTimestamp(this.timestamp),e}else return new r({format:this.format,sampleRate:this.sampleRate,numberOfFrames:this.numberOfFrames,numberOfChannels:this.numberOfChannels,timestamp:this.timestamp,data:this._data})}close(){this._closed||(lr?.unregister(this),ar(this._data)?this._data.close():this._data=new Uint8Array(0),this._closed=!0)}toAudioData(){if(this._closed)throw new Error("AudioSample is closed.");if(ar(this._data)){if(this._data.timestamp===this.microsecondTimestamp)return this._data.clone();if(kt(this.format)){let e=this.allocationSize({planeIndex:0,format:this.format}),t=new ArrayBuffer(e*this.numberOfChannels);for(let n=0;n<this.numberOfChannels;n++)this.copyTo(new Uint8Array(t,n*e,e),{planeIndex:n,format:this.format});return new AudioData({format:this.format,sampleRate:this.sampleRate,numberOfFrames:this.numberOfFrames,numberOfChannels:this.numberOfChannels,timestamp:this.microsecondTimestamp,data:t})}else{let e=new ArrayBuffer(this.allocationSize({planeIndex:0,format:this.format}));return this.copyTo(e,{planeIndex:0,format:this.format}),new AudioData({format:this.format,sampleRate:this.sampleRate,numberOfFrames:this.numberOfFrames,numberOfChannels:this.numberOfChannels,timestamp:this.microsecondTimestamp,data:e})}}else return new AudioData({format:this.format,sampleRate:this.sampleRate,numberOfFrames:this.numberOfFrames,numberOfChannels:this.numberOfChannels,timestamp:this.microsecondTimestamp,data:this._data.buffer instanceof ArrayBuffer?this._data.buffer:this._data.slice()})}toAudioBuffer(){if(this._closed)throw new Error("AudioSample is closed.");let e=new AudioBuffer({numberOfChannels:this.numberOfChannels,length:this.numberOfFrames,sampleRate:this.sampleRate}),t=new Float32Array(this.allocationSize({planeIndex:0,format:"f32-planar"})/4);for(let n=0;n<this.numberOfChannels;n++)this.copyTo(t,{planeIndex:n,format:"f32-planar"}),e.copyToChannel(t,n);return e}setTimestamp(e){if(!Number.isFinite(e))throw new TypeError("newTimestamp must be a number.");this.timestamp=e}[Symbol.dispose](){this.close()}static*_fromAudioBuffer(e,t){if(!(e instanceof AudioBuffer))throw new TypeError("audioBuffer must be an AudioBuffer.");let n=48e3*5,o=e.numberOfChannels,i=e.sampleRate,s=e.length,a=Math.floor(n/o),c=0,l=s;for(;l>0;){let d=Math.min(a,l),u=new Float32Array(o*d);for(let f=0;f<o;f++)e.copyFromChannel(u.subarray(f*d,(f+1)*d),f,c);yield new r({format:"f32-planar",sampleRate:i,numberOfFrames:d,numberOfChannels:o,timestamp:t+c/i,data:u}),c+=d,l-=d}}static fromAudioBuffer(e,t){if(!(e instanceof AudioBuffer))throw new TypeError("audioBuffer must be an AudioBuffer.");let n=48e3*5,o=e.numberOfChannels,i=e.sampleRate,s=e.length,a=Math.floor(n/o),c=0,l=s,d=[];for(;l>0;){let u=Math.min(a,l),f=new Float32Array(o*u);for(let p=0;p<o;p++)e.copyFromChannel(f.subarray(p*u,(p+1)*u),p,c);let m=new r({format:"f32-planar",sampleRate:i,numberOfFrames:u,numberOfChannels:o,timestamp:t+c/i,data:f});d.push(m),c+=u,l-=u}return d}},it=r=>{switch(r){case"u8":case"u8-planar":return 1;case"s16":case"s16-planar":return 2;case"s32":case"s32-planar":return 4;case"f32":case"f32-planar":return 4;default:throw new Error("Unknown AudioSampleFormat")}},kt=r=>{switch(r){case"u8-planar":case"s16-planar":case"s32-planar":case"f32-planar":return!0;default:return!1}},Ps=r=>{switch(r){case"u8":case"u8-planar":return(e,t)=>(e.getUint8(t)-128)/128;case"s16":case"s16-planar":return(e,t)=>e.getInt16(t,!0)/32768;case"s32":case"s32-planar":return(e,t)=>e.getInt32(t,!0)/2147483648;case"f32":case"f32-planar":return(e,t)=>e.getFloat32(t,!0)}},Cs=r=>{switch(r){case"u8":case"u8-planar":return(e,t,n)=>e.setUint8(t,Ye((n+1)*127.5,0,255));case"s16":case"s16-planar":return(e,t,n)=>e.setInt16(t,Ye(Math.round(n*32767),-32768,32767),!0);case"s32":case"s32-planar":return(e,t,n)=>e.setInt32(t,Ye(Math.round(n*2147483647),-2147483648,2147483647),!0);case"f32":case"f32-planar":return(e,t,n)=>e.setFloat32(t,n,!0)}},ar=r=>typeof AudioData<"u"&&r instanceof AudioData,Bc=(r,e,t,n,o,i,s,a)=>{let c=Ps(t),l=Cs(n),d=it(t),u=it(n),f=kt(t);if(kt(n))if(f){let p=new ArrayBuffer(a*d),g=z(p);r.copyTo(p,{planeIndex:i,frameOffset:s,frameCount:a,format:t});for(let x=0;x<a;x++){let y=x*d,b=x*u,w=c(g,y);l(e,b,w)}}else{let p=new ArrayBuffer(a*o*d),g=z(p);r.copyTo(p,{planeIndex:0,frameOffset:s,frameCount:a,format:t});for(let x=0;x<a;x++){let y=(x*o+i)*d,b=x*u,w=c(g,y);l(e,b,w)}}else if(f){let p=a*d,g=new ArrayBuffer(p),x=z(g);for(let y=0;y<o;y++){r.copyTo(g,{planeIndex:y,frameOffset:s,frameCount:a,format:t});for(let b=0;b<a;b++){let w=b*d,k=(b*o+y)*u,P=c(x,w);l(e,k,P)}}}else{let p=new ArrayBuffer(a*o*d),g=z(p);r.copyTo(p,{planeIndex:0,frameOffset:s,frameCount:a,format:t});for(let x=0;x<a;x++)for(let y=0;y<o;y++){let b=x*o+y,w=b*d,k=b*u,P=c(g,w);l(e,k,P)}}};var Pt=r=>{if(!r||typeof r!="object")throw new TypeError("options must be an object.");if(r.metadataOnly!==void 0&&typeof r.metadataOnly!="boolean")throw new TypeError("options.metadataOnly, when defined, must be a boolean.");if(r.verifyKeyPackets!==void 0&&typeof r.verifyKeyPackets!="boolean")throw new TypeError("options.verifyKeyPackets, when defined, must be a boolean.");if(r.verifyKeyPackets&&r.metadataOnly)throw new TypeError("options.verifyKeyPackets and options.metadataOnly cannot be enabled together.")},Ne=r=>{if(!or(r))throw new TypeError("timestamp must be a number.")},Xo=(r,e,t)=>t.verifyKeyPackets?e.then(async n=>{if(!n||n.type==="delta")return n;let o=await r.determinePacketType(n);return o&&(n.type=o),n}):e,st=class{constructor(e){if(!(e instanceof It))throw new TypeError("track must be an InputTrack.");this._track=e}getFirstPacket(e={}){if(Pt(e),this._track.input._disposed)throw new q;return Xo(this._track,this._track._backing.getFirstPacket(e),e)}getPacket(e,t={}){if(Ne(e),Pt(t),this._track.input._disposed)throw new q;return Xo(this._track,this._track._backing.getPacket(e,t),t)}getNextPacket(e,t={}){if(!(e instanceof V))throw new TypeError("packet must be an EncodedPacket.");if(Pt(t),this._track.input._disposed)throw new q;return Xo(this._track,this._track._backing.getNextPacket(e,t),t)}async getKeyPacket(e,t={}){if(Ne(e),Pt(t),this._track.input._disposed)throw new q;if(!t.verifyKeyPackets)return this._track._backing.getKeyPacket(e,t);let n=await this._track._backing.getKeyPacket(e,t);return n&&(h(n.type==="key"),await this._track.determinePacketType(n)==="delta"?this.getKeyPacket(n.timestamp-1/this._track.timeResolution,t):n)}async getNextKeyPacket(e,t={}){if(!(e instanceof V))throw new TypeError("packet must be an EncodedPacket.");if(Pt(t),this._track.input._disposed)throw new q;if(!t.verifyKeyPackets)return this._track._backing.getNextKeyPacket(e,t);let n=await this._track._backing.getNextKeyPacket(e,t);return n&&(h(n.type==="key"),await this._track.determinePacketType(n)==="delta"?this.getNextKeyPacket(n,t):n)}packets(e,t,n={}){if(e!==void 0&&!(e instanceof V))throw new TypeError("startPacket must be an EncodedPacket.");if(e!==void 0&&e.isMetadataOnly&&!n?.metadataOnly)throw new TypeError("startPacket can only be metadata-only if options.metadataOnly is enabled.");if(t!==void 0&&!(t instanceof V))throw new TypeError("endPacket must be an EncodedPacket.");if(Pt(n),this._track.input._disposed)throw new q;let o=[],{promise:i,resolve:s}=Z(),{promise:a,resolve:c}=Z(),l=!1,d=!1,u=null,f=[],m=()=>Math.max(2,f.length);(async()=>{let g=e??await this.getFirstPacket(n);for(;g&&!d&&!this._track.input._disposed&&!(t&&g.sequenceNumber>=t?.sequenceNumber);){if(o.length>m()){({promise:a,resolve:c}=Z()),await a;continue}o.push(g),s(),{promise:i,resolve:s}=Z(),g=await this.getNextPacket(g,n)}l=!0,s()})().catch(g=>{u||(u=g,s())});let p=this._track;return{async next(){for(;;){if(p.input._disposed)throw new q;if(d)return{value:void 0,done:!0};if(u)throw u;if(o.length>0){let g=o.shift(),x=performance.now();for(f.push(x);f.length>0&&x-f[0]>=1e3;)f.shift();return c(),{value:g,done:!1}}else{if(l)return{value:void 0,done:!0};await i}}},async return(){return d=!0,c(),s(),{value:void 0,done:!0}},async throw(g){throw g},[Symbol.asyncIterator](){return this}}}},ur=class{constructor(e,t){this.onSample=e,this.onError=t}},dr=class{mediaSamplesInRange(e=0,t=1/0){Ne(e),Ne(t);let n=[],o=!1,i=null,{promise:s,resolve:a}=Z(),{promise:c,resolve:l}=Z(),d=!1,u=!1,f=!1,m=null;(async()=>{let x=await this._createDecoder(S=>{if(l(),S.timestamp>=t&&(u=!0),u){S.close();return}i&&(S.timestamp>e?(n.push(i),o=!0):i.close()),S.timestamp>=e&&(n.push(S),o=!0),i=o?null:S,n.length>0&&(a(),{promise:s,resolve:a}=Z())},S=>{m||(m=S,a())}),y=this._createPacketSink(),b=await y.getKeyPacket(e,{verifyKeyPackets:!0})??await y.getFirstPacket(),w=b,k;if(t<1/0){let S=await y.getPacket(t),_=S?S.type==="key"&&S.timestamp===t?S:await y.getNextKeyPacket(S,{verifyKeyPackets:!0}):null;_&&(k=_)}let P=y.packets(b??void 0,k);for(await P.next();w&&!u&&!this._track.input._disposed;){let S=Is(n.length);if(n.length+x.getDecodeQueueSize()>S){({promise:c,resolve:l}=Z()),await c;continue}x.decode(w);let _=await P.next();if(_.done)break;w=_.value}await P.return(),!f&&!this._track.input._disposed&&await x.flush(),x.close(),!o&&i&&n.push(i),d=!0,a()})().catch(x=>{m||(m=x,a())});let p=this._track,g=()=>{i?.close();for(let x of n)x.close()};return{async next(){for(;;){if(p.input._disposed)throw g(),new q;if(f)return{value:void 0,done:!0};if(m)throw g(),m;if(n.length>0){let x=n.shift();return l(),{value:x,done:!1}}else if(!d)await s;else return{value:void 0,done:!0}}},async return(){return f=!0,u=!0,l(),a(),g(),{value:void 0,done:!0}},async throw(x){throw x},[Symbol.asyncIterator](){return this}}}mediaSamplesAtTimestamps(e){Ji(e);let t=Zi(e),n=[],o=[],{promise:i,resolve:s}=Z(),{promise:a,resolve:c}=Z(),l=!1,d=!1,u=null,f=g=>{o.push(g),s(),{promise:i,resolve:s}=Z()};(async()=>{let g=await this._createDecoder(S=>{if(c(),d){S.close();return}let _=0;for(;n.length>0&&S.timestamp-n[0]>-1e-10;)_++,n.shift();if(_>0)for(let C=0;C<_;C++)f(C<_-1?S.clone():S);else S.close()},S=>{u||(u=S,s())}),x=this._createPacketSink(),y=null,b=null,w=-1,k=async()=>{h(b);let S=b;for(g.decode(S);S.sequenceNumber<w;){let _=Is(o.length);for(;o.length+g.getDecodeQueueSize()>_&&!d;)({promise:a,resolve:c}=Z()),await a;if(d)break;let C=await x.getNextPacket(S);h(C),g.decode(C),S=C}w=-1},P=async()=>{await g.flush();for(let S=0;S<n.length;S++)f(null);n.length=0};for await(let S of t){if(Ne(S),d||this._track.input._disposed)break;let _=await x.getPacket(S),C=_&&await x.getKeyPacket(S,{verifyKeyPackets:!0});if(!C){w!==-1&&(await k(),await P()),f(null),y=null;continue}y&&(C.sequenceNumber!==b.sequenceNumber||_.timestamp<y.timestamp)&&(await k(),await P()),n.push(_.timestamp),w=Math.max(_.sequenceNumber,w),y=_,b=C}!d&&!this._track.input._disposed&&(w!==-1&&await k(),await P()),g.close(),l=!0,s()})().catch(g=>{u||(u=g,s())});let m=this._track,p=()=>{for(let g of o)g?.close()};return{async next(){for(;;){if(m.input._disposed)throw p(),new q;if(d)return{value:void 0,done:!0};if(u)throw p(),u;if(o.length>0){let g=o.shift();return h(g!==void 0),c(),{value:g,done:!1}}else if(!l)await i;else return{value:void 0,done:!0}}},async return(){return d=!0,c(),s(),p(),{value:void 0,done:!0}},async throw(g){throw g},[Symbol.asyncIterator](){return this}}}},Is=r=>r===0?40:8,Qo=class extends ur{constructor(e,t,n,o,i,s){super(e,t),this.codec=n,this.decoderConfig=o,this.rotation=i,this.timeResolution=s,this.decoder=null,this.customDecoder=null,this.customDecoderCallSerializer=new tr,this.customDecoderQueueSize=0,this.inputTimestamps=[],this.sampleQueue=[],this.currentPacketIndex=0,this.raslSkipped=!1,this.alphaDecoder=null,this.alphaHadKeyframe=!1,this.colorQueue=[],this.alphaQueue=[],this.merger=null,this.mergerCreationFailed=!1,this.decodedAlphaChunkCount=0,this.alphaDecoderQueueSize=0,this.nullAlphaFrameQueue=[],this.currentAlphaPacketIndex=0,this.alphaRaslSkipped=!1;let a=fn.find(c=>c.supports(n,o));if(a)this.customDecoder=new a,this.customDecoder.codec=n,this.customDecoder.config=o,this.customDecoder.onSample=c=>{if(!(c instanceof St))throw new TypeError("The argument passed to onSample must be a VideoSample.");this.finalizeAndEmitSample(c)},this.customDecoderCallSerializer.call(()=>this.customDecoder.init());else{let c=d=>{if(this.alphaQueue.length>0){let u=this.alphaQueue.shift();h(u!==void 0),this.mergeAlpha(d,u)}else this.colorQueue.push(d)};if(n==="avc"&&this.decoderConfig.description&&nr()){let d=ms(le(this.decoderConfig.description));if(d&&d.sequenceParameterSets.length>0){let u=Go(d.sequenceParameterSets[0]);u&&u.frameMbsOnlyFlag===0&&(this.decoderConfig={...this.decoderConfig,hardwareAcceleration:"prefer-software"})}}let l=new Error("Decoding error").stack;this.decoder=new VideoDecoder({output:d=>{try{c(d)}catch(u){this.onError(u)}},error:d=>{d.stack=l,this.onError(d)}}),this.decoder.configure(this.decoderConfig)}}getDecodeQueueSize(){return this.customDecoder?this.customDecoderQueueSize:(h(this.decoder),Math.max(this.decoder.decodeQueueSize,this.alphaDecoder?.decodeQueueSize??0))}decode(e){if(this.codec==="hevc"&&this.currentPacketIndex>0&&!this.raslSkipped){if(this.hasHevcRaslPicture(e.data))return;this.raslSkipped=!0}if(this.customDecoder)this.customDecoderQueueSize++,this.customDecoderCallSerializer.call(()=>this.customDecoder.decode(e)).then(()=>this.customDecoderQueueSize--);else{if(h(this.decoder),Be()||Bo(this.inputTimestamps,e.timestamp,t=>t),nr()&&this.currentPacketIndex===0&&this.codec==="avc"){let n=qo(e.data,this.decoderConfig).filter(i=>{let s=nt(i);return!(s>=20&&s<=31)}),o=ds(n,this.decoderConfig);e=new V(o,e.type,e.timestamp,e.duration)}this.decoder.decode(e.toEncodedVideoChunk()),this.decodeAlphaData(e)}this.currentPacketIndex++}decodeAlphaData(e){if(!e.sideData.alpha||this.mergerCreationFailed){this.pushNullAlphaFrame();return}if(!this.merger)try{this.merger=new Yo}catch(n){console.error("Due to an error, only color data will be decoded.",n),this.mergerCreationFailed=!0,this.decodeAlphaData(e);return}if(!this.alphaDecoder){let n=i=>{if(this.alphaDecoderQueueSize--,this.colorQueue.length>0){let s=this.colorQueue.shift();h(s!==void 0),this.mergeAlpha(s,i)}else this.alphaQueue.push(i);for(this.decodedAlphaChunkCount++;this.nullAlphaFrameQueue.length>0&&this.nullAlphaFrameQueue[0]===this.decodedAlphaChunkCount;)if(this.nullAlphaFrameQueue.shift(),this.colorQueue.length>0){let s=this.colorQueue.shift();h(s!==void 0),this.mergeAlpha(s,null)}else this.alphaQueue.push(null)},o=new Error("Decoding error").stack;this.alphaDecoder=new VideoDecoder({output:i=>{try{n(i)}catch(s){this.onError(s)}},error:i=>{i.stack=o,this.onError(i)}}),this.alphaDecoder.configure(this.decoderConfig)}let t=dn(this.codec,this.decoderConfig,e.sideData.alpha);if(this.alphaHadKeyframe||(this.alphaHadKeyframe=t==="key"),this.alphaHadKeyframe){if(this.codec==="hevc"&&this.currentAlphaPacketIndex>0&&!this.alphaRaslSkipped){if(this.hasHevcRaslPicture(e.sideData.alpha)){this.pushNullAlphaFrame();return}this.alphaRaslSkipped=!0}this.currentAlphaPacketIndex++,this.alphaDecoder.decode(e.alphaToEncodedVideoChunk(t??e.type)),this.alphaDecoderQueueSize++}else this.pushNullAlphaFrame()}pushNullAlphaFrame(){this.alphaDecoderQueueSize===0?this.alphaQueue.push(null):this.nullAlphaFrameQueue.push(this.decodedAlphaChunkCount+this.alphaDecoderQueueSize)}hasHevcRaslPicture(e){return Wo(e,this.decoderConfig).some(n=>{let o=Ie(n);return o===J.RASL_N||o===J.RASL_R})}sampleHandler(e){if(Be()){if(this.sampleQueue.length>0&&e.timestamp>=Y(this.sampleQueue).timestamp){for(let t of this.sampleQueue)this.finalizeAndEmitSample(t);this.sampleQueue.length=0}Bo(this.sampleQueue,e,t=>t.timestamp)}else{let t=this.inputTimestamps.shift();h(t!==void 0),e.setTimestamp(t),this.finalizeAndEmitSample(e)}}finalizeAndEmitSample(e){e.setTimestamp(Math.round(e.timestamp*this.timeResolution)/this.timeResolution),e.setDuration(Math.round(e.duration*this.timeResolution)/this.timeResolution),e.setRotation(this.rotation),this.onSample(e)}mergeAlpha(e,t){if(!t){let i=new St(e);this.sampleHandler(i);return}h(this.merger),this.merger.update(e,t),e.close(),t.close();let n=new VideoFrame(this.merger.canvas,{timestamp:e.timestamp,duration:e.duration??void 0}),o=new St(n);this.sampleHandler(o)}async flush(){if(this.customDecoder?await this.customDecoderCallSerializer.call(()=>this.customDecoder.flush()):(h(this.decoder),await Promise.all([this.decoder.flush(),this.alphaDecoder?.flush()]),this.colorQueue.forEach(e=>e.close()),this.colorQueue.length=0,this.alphaQueue.forEach(e=>e?.close()),this.alphaQueue.length=0,this.alphaHadKeyframe=!1,this.decodedAlphaChunkCount=0,this.alphaDecoderQueueSize=0,this.nullAlphaFrameQueue.length=0,this.currentAlphaPacketIndex=0,this.alphaRaslSkipped=!1),Be()){for(let e of this.sampleQueue)this.finalizeAndEmitSample(e);this.sampleQueue.length=0}this.currentPacketIndex=0,this.raslSkipped=!1}close(){this.customDecoder?this.customDecoderCallSerializer.call(()=>this.customDecoder.close()):(h(this.decoder),this.decoder.close(),this.alphaDecoder?.close(),this.colorQueue.forEach(e=>e.close()),this.colorQueue.length=0,this.alphaQueue.forEach(e=>e?.close()),this.alphaQueue.length=0,this.merger?.close());for(let e of this.sampleQueue)e.close();this.sampleQueue.length=0}},Yo=class{constructor(){typeof OffscreenCanvas<"u"?this.canvas=new OffscreenCanvas(300,150):this.canvas=document.createElement("canvas");let e=this.canvas.getContext("webgl2",{premultipliedAlpha:!1});if(!e)throw new Error("Couldn't acquire WebGL 2 context.");this.gl=e,this.program=this.createProgram(),this.vao=this.createVAO(),this.colorTexture=this.createTexture(),this.alphaTexture=this.createTexture(),this.gl.useProgram(this.program),this.gl.uniform1i(this.gl.getUniformLocation(this.program,"u_colorTexture"),0),this.gl.uniform1i(this.gl.getUniformLocation(this.program,"u_alphaTexture"),1)}createProgram(){let e=this.createShader(this.gl.VERTEX_SHADER,`#version 300 es
|
|
2341
|
+
in vec2 a_position;
|
|
2342
|
+
in vec2 a_texCoord;
|
|
2343
|
+
out vec2 v_texCoord;
|
|
2344
|
+
|
|
2345
|
+
void main() {
|
|
2346
|
+
gl_Position = vec4(a_position, 0.0, 1.0);
|
|
2347
|
+
v_texCoord = a_texCoord;
|
|
2348
|
+
}
|
|
2349
|
+
`),t=this.createShader(this.gl.FRAGMENT_SHADER,`#version 300 es
|
|
2350
|
+
precision highp float;
|
|
2351
|
+
|
|
2352
|
+
uniform sampler2D u_colorTexture;
|
|
2353
|
+
uniform sampler2D u_alphaTexture;
|
|
2354
|
+
in vec2 v_texCoord;
|
|
2355
|
+
out vec4 fragColor;
|
|
2356
|
+
|
|
2357
|
+
void main() {
|
|
2358
|
+
vec3 color = texture(u_colorTexture, v_texCoord).rgb;
|
|
2359
|
+
float alpha = texture(u_alphaTexture, v_texCoord).r;
|
|
2360
|
+
fragColor = vec4(color, alpha);
|
|
2361
|
+
}
|
|
2362
|
+
`),n=this.gl.createProgram();return this.gl.attachShader(n,e),this.gl.attachShader(n,t),this.gl.linkProgram(n),n}createShader(e,t){let n=this.gl.createShader(e);return this.gl.shaderSource(n,t),this.gl.compileShader(n),n}createVAO(){let e=this.gl.createVertexArray();this.gl.bindVertexArray(e);let t=new Float32Array([-1,-1,0,1,1,-1,1,1,-1,1,0,0,1,1,1,0]),n=this.gl.createBuffer();this.gl.bindBuffer(this.gl.ARRAY_BUFFER,n),this.gl.bufferData(this.gl.ARRAY_BUFFER,t,this.gl.STATIC_DRAW);let o=this.gl.getAttribLocation(this.program,"a_position"),i=this.gl.getAttribLocation(this.program,"a_texCoord");return this.gl.enableVertexAttribArray(o),this.gl.vertexAttribPointer(o,2,this.gl.FLOAT,!1,16,0),this.gl.enableVertexAttribArray(i),this.gl.vertexAttribPointer(i,2,this.gl.FLOAT,!1,16,8),e}createTexture(){let e=this.gl.createTexture();return this.gl.bindTexture(this.gl.TEXTURE_2D,e),this.gl.texParameteri(this.gl.TEXTURE_2D,this.gl.TEXTURE_WRAP_S,this.gl.CLAMP_TO_EDGE),this.gl.texParameteri(this.gl.TEXTURE_2D,this.gl.TEXTURE_WRAP_T,this.gl.CLAMP_TO_EDGE),this.gl.texParameteri(this.gl.TEXTURE_2D,this.gl.TEXTURE_MIN_FILTER,this.gl.LINEAR),this.gl.texParameteri(this.gl.TEXTURE_2D,this.gl.TEXTURE_MAG_FILTER,this.gl.LINEAR),e}update(e,t){(e.displayWidth!==this.canvas.width||e.displayHeight!==this.canvas.height)&&(this.canvas.width=e.displayWidth,this.canvas.height=e.displayHeight),this.gl.activeTexture(this.gl.TEXTURE0),this.gl.bindTexture(this.gl.TEXTURE_2D,this.colorTexture),this.gl.texImage2D(this.gl.TEXTURE_2D,0,this.gl.RGBA,this.gl.RGBA,this.gl.UNSIGNED_BYTE,e),this.gl.activeTexture(this.gl.TEXTURE1),this.gl.bindTexture(this.gl.TEXTURE_2D,this.alphaTexture),this.gl.texImage2D(this.gl.TEXTURE_2D,0,this.gl.RGBA,this.gl.RGBA,this.gl.UNSIGNED_BYTE,t),this.gl.viewport(0,0,this.canvas.width,this.canvas.height),this.gl.clear(this.gl.COLOR_BUFFER_BIT),this.gl.bindVertexArray(this.vao),this.gl.drawArrays(this.gl.TRIANGLE_STRIP,0,4)}close(){this.gl.getExtension("WEBGL_lose_context")?.loseContext(),this.gl=null}},Ct=class extends dr{constructor(e){if(!(e instanceof ke))throw new TypeError("videoTrack must be an InputVideoTrack.");super(),this._track=e}async _createDecoder(e,t){if(!await this._track.canDecode())throw new Error("This video track cannot be decoded by this browser. Make sure to check decodability before using a track.");let n=this._track.codec,o=this._track.rotation,i=await this._track.getDecoderConfig(),s=this._track.timeResolution;return h(n&&i),new Qo(e,t,n,i,o,s)}_createPacketSink(){return new st(this._track)}async getSample(e){Ne(e);for await(let t of this.mediaSamplesAtTimestamps([e]))return t;throw new Error("Internal error: Iterator returned nothing.")}samples(e=0,t=1/0){return this.mediaSamplesInRange(e,t)}samplesAtTimestamps(e){return this.mediaSamplesAtTimestamps(e)}},fr=class{constructor(e,t={}){if(this._nextCanvasIndex=0,!(e instanceof ke))throw new TypeError("videoTrack must be an InputVideoTrack.");if(t&&typeof t!="object")throw new TypeError("options must be an object.");if(t.alpha!==void 0&&typeof t.alpha!="boolean")throw new TypeError("options.alpha, when provided, must be a boolean.");if(t.width!==void 0&&(!Number.isInteger(t.width)||t.width<=0))throw new TypeError("options.width, when defined, must be a positive integer.");if(t.height!==void 0&&(!Number.isInteger(t.height)||t.height<=0))throw new TypeError("options.height, when defined, must be a positive integer.");if(t.fit!==void 0&&!["fill","contain","cover"].includes(t.fit))throw new TypeError('options.fit, when provided, must be one of "fill", "contain", or "cover".');if(t.width!==void 0&&t.height!==void 0&&t.fit===void 0)throw new TypeError("When both options.width and options.height are provided, options.fit must also be provided.");if(t.rotation!==void 0&&![0,90,180,270].includes(t.rotation))throw new TypeError("options.rotation, when provided, must be 0, 90, 180 or 270.");if(t.crop!==void 0&&Ko(t.crop,"options."),t.poolSize!==void 0&&(typeof t.poolSize!="number"||!Number.isInteger(t.poolSize)||t.poolSize<0))throw new TypeError("poolSize must be a non-negative integer.");let n=t.rotation??e.rotation,[o,i]=n%180===0?[e.codedWidth,e.codedHeight]:[e.codedHeight,e.codedWidth],s=t.crop;s&&$o(s,o,i);let[a,c]=s?[s.width,s.height]:[o,i],l=a/c;t.width!==void 0&&t.height===void 0?(a=t.width,c=Math.round(a/l)):t.width===void 0&&t.height!==void 0?(c=t.height,a=Math.round(c*l)):t.width!==void 0&&t.height!==void 0&&(a=t.width,c=t.height),this._videoTrack=e,this._alpha=t.alpha??!1,this._width=a,this._height=c,this._rotation=n,this._crop=s,this._fit=t.fit??"fill",this._videoSampleSink=new Ct(e),this._canvasPool=Array.from({length:t.poolSize??0},()=>null)}_videoSampleToWrappedCanvas(e){let t=this._canvasPool[this._nextCanvasIndex],n=!1;t||(typeof document<"u"?(t=document.createElement("canvas"),t.width=this._width,t.height=this._height):t=new OffscreenCanvas(this._width,this._height),this._canvasPool.length>0&&(this._canvasPool[this._nextCanvasIndex]=t),n=!0),this._canvasPool.length>0&&(this._nextCanvasIndex=(this._nextCanvasIndex+1)%this._canvasPool.length);let o=t.getContext("2d",{alpha:this._alpha||rr()});h(o),o.resetTransform(),n||(!this._alpha&&rr()?(o.fillStyle="black",o.fillRect(0,0,this._width,this._height)):o.clearRect(0,0,this._width,this._height)),e.drawWithFit(o,{fit:this._fit,rotation:this._rotation,crop:this._crop});let i={canvas:t,timestamp:e.timestamp,duration:e.duration};return e.close(),i}async getCanvas(e){Ne(e);let t=await this._videoSampleSink.getSample(e);return t&&this._videoSampleToWrappedCanvas(t)}canvases(e=0,t=1/0){return zo(this._videoSampleSink.samples(e,t),n=>this._videoSampleToWrappedCanvas(n))}canvasesAtTimestamps(e){return zo(this._videoSampleSink.samplesAtTimestamps(e),t=>t&&this._videoSampleToWrappedCanvas(t))}},Zo=class extends ur{constructor(e,t,n,o){super(e,t),this.decoder=null,this.customDecoder=null,this.customDecoderCallSerializer=new tr,this.customDecoderQueueSize=0,this.currentTimestamp=null;let i=a=>{(this.currentTimestamp===null||Math.abs(a.timestamp-this.currentTimestamp)>=a.duration)&&(this.currentTimestamp=a.timestamp);let c=this.currentTimestamp;if(this.currentTimestamp+=a.duration,a.numberOfFrames===0){a.close();return}let l=o.sampleRate;a.setTimestamp(Math.round(c*l)/l),e(a)},s=mn.find(a=>a.supports(n,o));if(s)this.customDecoder=new s,this.customDecoder.codec=n,this.customDecoder.config=o,this.customDecoder.onSample=a=>{if(!(a instanceof vt))throw new TypeError("The argument passed to onSample must be an AudioSample.");i(a)},this.customDecoderCallSerializer.call(()=>this.customDecoder.init());else{let a=new Error("Decoding error").stack;this.decoder=new AudioDecoder({output:c=>{try{i(new vt(c))}catch(l){this.onError(l)}},error:c=>{c.stack=a,this.onError(c)}}),this.decoder.configure(o)}}getDecodeQueueSize(){return this.customDecoder?this.customDecoderQueueSize:(h(this.decoder),this.decoder.decodeQueueSize)}decode(e){this.customDecoder?(this.customDecoderQueueSize++,this.customDecoderCallSerializer.call(()=>this.customDecoder.decode(e)).then(()=>this.customDecoderQueueSize--)):(h(this.decoder),this.decoder.decode(e.toEncodedAudioChunk()))}flush(){return this.customDecoder?this.customDecoderCallSerializer.call(()=>this.customDecoder.flush()):(h(this.decoder),this.decoder.flush())}close(){this.customDecoder?this.customDecoderCallSerializer.call(()=>this.customDecoder.close()):(h(this.decoder),this.decoder.close())}},Jo=class extends ur{constructor(e,t,n){super(e,t),this.decoderConfig=n,this.currentTimestamp=null,h(ze.includes(n.codec)),this.codec=n.codec;let{dataType:o,sampleSize:i,littleEndian:s}=sn(this.codec);switch(this.inputSampleSize=i,i){case 1:o==="unsigned"?this.readInputValue=(a,c)=>a.getUint8(c)-2**7:o==="signed"?this.readInputValue=(a,c)=>a.getInt8(c):o==="ulaw"?this.readInputValue=(a,c)=>ys(a.getUint8(c)):o==="alaw"?this.readInputValue=(a,c)=>Ts(a.getUint8(c)):h(!1);break;case 2:o==="unsigned"?this.readInputValue=(a,c)=>a.getUint16(c,s)-2**15:o==="signed"?this.readInputValue=(a,c)=>a.getInt16(c,s):h(!1);break;case 3:o==="unsigned"?this.readInputValue=(a,c)=>Qe(a,c,s)-2**23:o==="signed"?this.readInputValue=(a,c)=>es(a,c,s):h(!1);break;case 4:o==="unsigned"?this.readInputValue=(a,c)=>a.getUint32(c,s)-2**31:o==="signed"?this.readInputValue=(a,c)=>a.getInt32(c,s):o==="float"?this.readInputValue=(a,c)=>a.getFloat32(c,s):h(!1);break;case 8:o==="float"?this.readInputValue=(a,c)=>a.getFloat64(c,s):h(!1);break;default:se(i),h(!1)}switch(i){case 1:o==="ulaw"||o==="alaw"?(this.outputSampleSize=2,this.outputFormat="s16",this.writeOutputValue=(a,c,l)=>a.setInt16(c,l,!0)):(this.outputSampleSize=1,this.outputFormat="u8",this.writeOutputValue=(a,c,l)=>a.setUint8(c,l+2**7));break;case 2:this.outputSampleSize=2,this.outputFormat="s16",this.writeOutputValue=(a,c,l)=>a.setInt16(c,l,!0);break;case 3:this.outputSampleSize=4,this.outputFormat="s32",this.writeOutputValue=(a,c,l)=>a.setInt32(c,l<<8,!0);break;case 4:this.outputSampleSize=4,o==="float"?(this.outputFormat="f32",this.writeOutputValue=(a,c,l)=>a.setFloat32(c,l,!0)):(this.outputFormat="s32",this.writeOutputValue=(a,c,l)=>a.setInt32(c,l,!0));break;case 8:this.outputSampleSize=4,this.outputFormat="f32",this.writeOutputValue=(a,c,l)=>a.setFloat32(c,l,!0);break;default:se(i),h(!1)}}getDecodeQueueSize(){return 0}decode(e){let t=z(e.data),n=e.byteLength/this.decoderConfig.numberOfChannels/this.inputSampleSize,o=n*this.decoderConfig.numberOfChannels*this.outputSampleSize,i=new ArrayBuffer(o),s=new DataView(i);for(let d=0;d<n*this.decoderConfig.numberOfChannels;d++){let u=d*this.inputSampleSize,f=d*this.outputSampleSize,m=this.readInputValue(t,u);this.writeOutputValue(s,f,m)}let a=n/this.decoderConfig.sampleRate;(this.currentTimestamp===null||Math.abs(e.timestamp-this.currentTimestamp)>=a)&&(this.currentTimestamp=e.timestamp);let c=this.currentTimestamp;this.currentTimestamp+=a;let l=new vt({format:this.outputFormat,data:i,numberOfChannels:this.decoderConfig.numberOfChannels,sampleRate:this.decoderConfig.sampleRate,numberOfFrames:n,timestamp:c});this.onSample(l)}async flush(){}close(){}},mr=class extends dr{constructor(e){if(!(e instanceof G))throw new TypeError("audioTrack must be an InputAudioTrack.");super(),this._track=e}async _createDecoder(e,t){if(!await this._track.canDecode())throw new Error("This audio track cannot be decoded by this browser. Make sure to check decodability before using a track.");let n=this._track.codec,o=await this._track.getDecoderConfig();return h(n&&o),ze.includes(o.codec)?new Jo(e,t,o):new Zo(e,t,n,o)}_createPacketSink(){return new st(this._track)}async getSample(e){Ne(e);for await(let t of this.mediaSamplesAtTimestamps([e]))return t;throw new Error("Internal error: Iterator returned nothing.")}samples(e=0,t=1/0){return this.mediaSamplesInRange(e,t)}samplesAtTimestamps(e){return this.mediaSamplesAtTimestamps(e)}};var It=class{constructor(e,t){this.input=e,this._backing=t}isVideoTrack(){return this instanceof ke}isAudioTrack(){return this instanceof G}get id(){return this._backing.getId()}get internalCodecId(){return this._backing.getInternalCodecId()}get languageCode(){return this._backing.getLanguageCode()}get name(){return this._backing.getName()}get timeResolution(){return this._backing.getTimeResolution()}get disposition(){return this._backing.getDisposition()}getFirstTimestamp(){return this._backing.getFirstTimestamp()}computeDuration(){return this._backing.computeDuration()}async computePacketStats(e=1/0){let t=new st(this),n=1/0,o=-1/0,i=0,s=0;for await(let a of t.packets(void 0,void 0,{metadataOnly:!0})){if(i>=e&&a.timestamp>=o)break;n=Math.min(n,a.timestamp),o=Math.max(o,a.timestamp+a.duration),i++,s+=a.byteLength}return{packetCount:i,averagePacketRate:i?Number((i/(o-n)).toPrecision(16)):0,averageBitrate:i?Number((8*s/(o-n)).toPrecision(16)):0}}},ke=class extends It{constructor(e,t){super(e,t),this._backing=t}get type(){return"video"}get codec(){return this._backing.getCodec()}get codedWidth(){return this._backing.getCodedWidth()}get codedHeight(){return this._backing.getCodedHeight()}get rotation(){return this._backing.getRotation()}get displayWidth(){return this._backing.getRotation()%180===0?this._backing.getCodedWidth():this._backing.getCodedHeight()}get displayHeight(){return this._backing.getRotation()%180===0?this._backing.getCodedHeight():this._backing.getCodedWidth()}getColorSpace(){return this._backing.getColorSpace()}async hasHighDynamicRange(){let e=await this._backing.getColorSpace();return e.primaries==="bt2020"||e.primaries==="smpte432"||e.transfer==="pg"||e.transfer==="hlg"||e.matrix==="bt2020-ncl"}canBeTransparent(){return this._backing.canBeTransparent()}getDecoderConfig(){return this._backing.getDecoderConfig()}async getCodecParameterString(){return(await this._backing.getDecoderConfig())?.codec??null}async canDecode(){try{let e=await this._backing.getDecoderConfig();if(!e)return!1;let t=this._backing.getCodec();return h(t!==null),fn.some(o=>o.supports(t,e))?!0:typeof VideoDecoder>"u"?!1:(await VideoDecoder.isConfigSupported(e)).supported===!0}catch(e){return console.error("Error during decodability check:",e),!1}}async determinePacketType(e){if(!(e instanceof V))throw new TypeError("packet must be an EncodedPacket.");if(e.isMetadataOnly)throw new TypeError("packet must not be metadata-only to determine its type.");if(this.codec===null)return null;let t=await this.getDecoderConfig();return h(t),dn(this.codec,t,e.data)}},G=class extends It{constructor(e,t){super(e,t),this._backing=t}get type(){return"audio"}get codec(){return this._backing.getCodec()}get numberOfChannels(){return this._backing.getNumberOfChannels()}get sampleRate(){return this._backing.getSampleRate()}getDecoderConfig(){return this._backing.getDecoderConfig()}async getCodecParameterString(){return(await this._backing.getDecoderConfig())?.codec??null}async canDecode(){try{let e=await this._backing.getDecoderConfig();if(!e)return!1;let t=this._backing.getCodec();return h(t!==null),mn.some(n=>n.supports(t,e))||e.codec.startsWith("pcm-")?!0:typeof AudioDecoder>"u"?!1:(await AudioDecoder.isConfigSupported(e)).supported===!0}catch(e){return console.error("Error during decodability check:",e),!1}}async determinePacketType(e){if(!(e instanceof V))throw new TypeError("packet must be an EncodedPacket.");return this.codec===null?null:"key"}};var As=r=>{let t=(r.hasVideo?"video/":r.hasAudio?"audio/":"application/")+(r.isQuickTime?"quicktime":"mp4");if(r.codecStrings.length>0){let n=[...new Set(r.codecStrings)];t+=`; codecs="${n.join(", ")}"`}return t};var at=8,At=16,Ae=r=>{let e=v(r),t=L(r,4),n=8;e===1&&(e=ne(r),n=16);let i=e-n;return i<0?null:{name:t,totalSize:e,headerSize:n,contentSize:i}},Ve=r=>_e(r)/65536,pn=r=>_e(r)/1073741824,hn=r=>{let e=0;for(let t=0;t<4;t++){e<<=7;let n=A(r);if(e|=n&127,(n&128)===0)break}return e},ue=r=>{let e=W(r);return r.skip(2),e=Math.min(e,r.remainingLength),$.decode(E(r,e))},_s=r=>{let e=Ae(r);if(!e||e.name!=="data"||r.remainingLength<8)return null;let t=v(r);r.skip(4);let n=E(r,e.contentSize-8);switch(t){case 1:return $.decode(n);case 2:return new TextDecoder("utf-16be").decode(n);case 13:return new Oe(n,"image/jpeg");case 14:return new Oe(n,"image/png");case 27:return new Oe(n,"image/bmp");default:return n}};var gn=class extends Q{constructor(e){super(e),this.moovSlice=null,this.currentTrack=null,this.tracks=[],this.metadataPromise=null,this.movieTimescale=-1,this.movieDurationInTimescale=-1,this.isQuickTime=!1,this.metadataTags={},this.currentMetadataKeys=null,this.isFragmented=!1,this.fragmentTrackDefaults=[],this.currentFragment=null,this.lastReadFragment=null,this.reader=e._reader}async computeDuration(){let e=await this.getTracks(),t=await Promise.all(e.map(n=>n.computeDuration()));return Math.max(0,...t)}async getTracks(){return await this.readMetadata(),this.tracks.map(e=>e.inputTrack)}async getMimeType(){await this.readMetadata();let e=await Promise.all(this.tracks.map(t=>t.inputTrack.getCodecParameterString()));return As({isQuickTime:this.isQuickTime,hasVideo:this.tracks.some(t=>t.info?.type==="video"),hasAudio:this.tracks.some(t=>t.info?.type==="audio"),codecStrings:e.filter(Boolean)})}async getMetadataTags(){return await this.readMetadata(),this.metadataTags}readMetadata(){return this.metadataPromise??=(async()=>{let e=0;for(;;){let t=this.reader.requestSliceRange(e,at,At);if(t instanceof Promise&&(t=await t),!t)break;let n=e,o=Ae(t);if(!o)break;if(o.name==="ftyp"){let i=L(t,4);this.isQuickTime=i==="qt "}else if(o.name==="moov"){let i=this.reader.requestSlice(t.filePos,o.contentSize);if(i instanceof Promise&&(i=await i),!i)break;this.moovSlice=i,this.readContiguousBoxes(this.moovSlice),this.tracks.sort((s,a)=>Number(a.disposition.default)-Number(s.disposition.default));for(let s of this.tracks){let a=s.editListPreviousSegmentDurations/this.movieTimescale;s.editListOffset-=Math.round(a*s.timescale)}break}e=n+o.totalSize}if(this.isFragmented&&this.reader.fileSize!==null){let t=this.reader.requestSlice(this.reader.fileSize-4,4);t instanceof Promise&&(t=await t),h(t);let n=v(t),o=this.reader.fileSize-n;if(o>=0&&o<=this.reader.fileSize-At){let i=this.reader.requestSliceRange(o,at,At);if(i instanceof Promise&&(i=await i),i){let s=Ae(i);if(s&&s.name==="mfra"){let a=this.reader.requestSlice(i.filePos,s.contentSize);a instanceof Promise&&(a=await a),a&&this.readContiguousBoxes(a)}}}}})()}getSampleTableForTrack(e){if(e.sampleTable)return e.sampleTable;let t={sampleTimingEntries:[],sampleCompositionTimeOffsets:[],sampleSizes:[],keySampleIndices:null,chunkOffsets:[],sampleToChunk:[],presentationTimestamps:null,presentationTimestampIndexMap:null};e.sampleTable=t,h(this.moovSlice);let n=this.moovSlice.slice(e.sampleTableByteOffset);if(this.currentTrack=e,this.traverseBox(n),this.currentTrack=null,e.info?.type==="audio"&&e.info.codec&&ze.includes(e.info.codec)&&t.sampleCompositionTimeOffsets.length===0){h(e.info?.type==="audio");let i=sn(e.info.codec),s=[],a=[];for(let c=0;c<t.sampleToChunk.length;c++){let l=t.sampleToChunk[c],d=t.sampleToChunk[c+1],u=(d?d.startChunkIndex:t.chunkOffsets.length)-l.startChunkIndex;for(let f=0;f<u;f++){let m=l.startSampleIndex+f*l.samplesPerChunk,p=m+l.samplesPerChunk,g=B(t.sampleTimingEntries,m,C=>C.startIndex),x=t.sampleTimingEntries[g],y=B(t.sampleTimingEntries,p,C=>C.startIndex),b=t.sampleTimingEntries[y],w=x.startDecodeTimestamp+(m-x.startIndex)*x.delta,P=b.startDecodeTimestamp+(p-b.startIndex)*b.delta-w,S=Y(s);S&&S.delta===P?S.count++:s.push({startIndex:l.startChunkIndex+f,startDecodeTimestamp:w,count:1,delta:P});let _=l.samplesPerChunk*i.sampleSize*e.info.numberOfChannels;a.push(_)}l.startSampleIndex=l.startChunkIndex,l.samplesPerChunk=1}t.sampleTimingEntries=s,t.sampleSizes=a}if(t.sampleCompositionTimeOffsets.length>0){t.presentationTimestamps=[];for(let i of t.sampleTimingEntries)for(let s=0;s<i.count;s++)t.presentationTimestamps.push({presentationTimestamp:i.startDecodeTimestamp+s*i.delta,sampleIndex:i.startIndex+s});for(let i of t.sampleCompositionTimeOffsets)for(let s=0;s<i.count;s++){let a=i.startIndex+s,c=t.presentationTimestamps[a];c&&(c.presentationTimestamp+=i.offset)}t.presentationTimestamps.sort((i,s)=>i.presentationTimestamp-s.presentationTimestamp),t.presentationTimestampIndexMap=Array(t.presentationTimestamps.length).fill(-1);for(let i=0;i<t.presentationTimestamps.length;i++)t.presentationTimestampIndexMap[t.presentationTimestamps[i].sampleIndex]=i}return t}async readFragment(e){if(this.lastReadFragment?.moofOffset===e)return this.lastReadFragment;let t=this.reader.requestSliceRange(e,at,At);t instanceof Promise&&(t=await t),h(t);let n=Ae(t);h(n?.name==="moof");let o=this.reader.requestSlice(e,n.totalSize);o instanceof Promise&&(o=await o),h(o),this.traverseBox(o);let i=this.lastReadFragment;h(i&&i.moofOffset===e);for(let[,s]of i.trackData){let a=s.track,{fragmentPositionCache:c}=a;if(!s.startTimestampIsFinal){let d=a.fragmentLookupTable.find(u=>u.moofOffset===i.moofOffset);if(d)ei(s,d.timestamp);else{let u=B(c,i.moofOffset-1,f=>f.moofOffset);if(u!==-1){let f=c[u];ei(s,f.endTimestamp)}}s.startTimestampIsFinal=!0}let l=B(c,s.startTimestamp,d=>d.startTimestamp);(l===-1||c[l].moofOffset!==i.moofOffset)&&c.splice(l+1,0,{moofOffset:i.moofOffset,startTimestamp:s.startTimestamp,endTimestamp:s.endTimestamp})}return i}readContiguousBoxes(e){let t=e.filePos;for(;e.filePos-t<=e.length-at&&this.traverseBox(e););}*iterateContiguousBoxes(e){let t=e.filePos;for(;e.filePos-t<=e.length-at;){let n=e.filePos,o=Ae(e);if(!o)break;yield{boxInfo:o,slice:e},e.filePos=n+o.totalSize}}traverseBox(e){let t=e.filePos,n=Ae(e);if(!n)return!1;let o=e.filePos,i=t+n.totalSize;switch(n.name){case"mdia":case"minf":case"dinf":case"mfra":case"edts":this.readContiguousBoxes(e.slice(o,n.contentSize));break;case"mvhd":{let s=A(e);e.skip(3),s===1?(e.skip(16),this.movieTimescale=v(e),this.movieDurationInTimescale=ne(e)):(e.skip(8),this.movieTimescale=v(e),this.movieDurationInTimescale=v(e))}break;case"trak":{let s={id:-1,demuxer:this,inputTrack:null,disposition:{...te},info:null,timescale:-1,durationInMovieTimescale:-1,durationInMediaTimescale:-1,rotation:0,internalCodecId:null,name:null,languageCode:K,sampleTableByteOffset:-1,sampleTable:null,fragmentLookupTable:[],currentFragmentState:null,fragmentPositionCache:[],editListPreviousSegmentDurations:0,editListOffset:0};if(this.currentTrack=s,this.readContiguousBoxes(e.slice(o,n.contentSize)),s.id!==-1&&s.timescale!==-1&&s.info!==null){if(s.info.type==="video"&&s.info.width!==-1){let a=s;s.inputTrack=new ke(this.input,new ti(a)),this.tracks.push(s)}else if(s.info.type==="audio"&&s.info.numberOfChannels!==-1){let a=s;s.inputTrack=new G(this.input,new ri(a)),this.tracks.push(s)}}this.currentTrack=null}break;case"tkhd":{let s=this.currentTrack;if(!s)break;let a=A(e),l=!!(Le(e)&1);if(s.disposition.default=l,a===0)e.skip(8),s.id=v(e),e.skip(4),s.durationInMovieTimescale=v(e);else if(a===1)e.skip(16),s.id=v(e),e.skip(4),s.durationInMovieTimescale=ne(e);else throw new Error(`Incorrect track header version ${a}.`);e.skip(16);let d=[Ve(e),Ve(e),pn(e),Ve(e),Ve(e),pn(e),Ve(e),Ve(e),pn(e)],u=$r(rs(Nc(d),90));h(u===0||u===90||u===180||u===270),s.rotation=u}break;case"elst":{let s=this.currentTrack;if(!s)break;let a=A(e);e.skip(3);let c=!1,l=0,d=v(e);for(let u=0;u<d;u++){let f=a===1?ne(e):v(e),m=a===1?Fs(e):_e(e),p=Ve(e);if(f!==0){if(c){console.warn("Unsupported edit list: multiple edits are not currently supported. Only using first edit.");break}if(m===-1){l+=f;continue}if(p!==1){console.warn("Unsupported edit list entry: media rate must be 1.");break}s.editListPreviousSegmentDurations=l,s.editListOffset=m,c=!0}}}break;case"mdhd":{let s=this.currentTrack;if(!s)break;let a=A(e);e.skip(3),a===0?(e.skip(8),s.timescale=v(e),s.durationInMediaTimescale=v(e)):a===1&&(e.skip(16),s.timescale=v(e),s.durationInMediaTimescale=ne(e));let c=W(e);if(c>0){s.languageCode="";for(let l=0;l<3;l++)s.languageCode=String.fromCharCode(96+(c&31))+s.languageCode,c>>=5;Jr(s.languageCode)||(s.languageCode=K)}}break;case"hdlr":{let s=this.currentTrack;if(!s)break;e.skip(8);let a=L(e,4);a==="vide"?s.info={type:"video",width:-1,height:-1,codec:null,codecDescription:null,colorSpace:null,avcType:null,avcCodecInfo:null,hevcCodecInfo:null,vp9CodecInfo:null,av1CodecInfo:null}:a==="soun"&&(s.info={type:"audio",numberOfChannels:-1,sampleRate:-1,codec:null,codecDescription:null,aacCodecInfo:null})}break;case"stbl":{let s=this.currentTrack;if(!s)break;s.sampleTableByteOffset=t,this.readContiguousBoxes(e.slice(o,n.contentSize))}break;case"stsd":{let s=this.currentTrack;if(!s||s.info===null||s.sampleTable)break;let a=A(e);e.skip(3);let c=v(e);for(let l=0;l<c;l++){let d=e.filePos,u=Ae(e);if(!u)break;s.internalCodecId=u.name;let f=u.name.toLowerCase();if(s.info.type==="video")f==="avc1"||f==="avc3"?(s.info.codec="avc",s.info.avcType=f==="avc1"?1:3):f==="hvc1"||f==="hev1"?s.info.codec="hevc":f==="vp08"?s.info.codec="vp8":f==="vp09"?s.info.codec="vp9":f==="av01"?s.info.codec="av1":console.warn(`Unsupported video codec (sample entry type '${u.name}').`),e.skip(24),s.info.width=W(e),s.info.height=W(e),e.skip(50),this.readContiguousBoxes(e.slice(e.filePos,d+u.totalSize-e.filePos));else{f==="mp4a"||(f==="opus"?s.info.codec="opus":f==="flac"?s.info.codec="flac":f==="twos"||f==="sowt"||f==="raw "||f==="in24"||f==="in32"||f==="fl32"||f==="fl64"||f==="lpcm"||f==="ipcm"||f==="fpcm"||(f==="ulaw"?s.info.codec="ulaw":f==="alaw"?s.info.codec="alaw":console.warn(`Unsupported audio codec (sample entry type '${u.name}').`))),e.skip(8);let m=W(e);e.skip(6);let p=W(e),g=W(e);e.skip(4);let x=v(e)/65536;if(a===0&&m>0){if(m===1)e.skip(4),g=8*v(e),e.skip(8);else if(m===2){e.skip(4),x=bn(e),p=v(e),e.skip(4),g=v(e);let y=v(e);if(e.skip(8),f==="lpcm"){let b=g+7>>3,w=!!(y&1),k=!!(y&2),P=y&4?-1:0;g>0&&g<=64&&(w?g===32&&(s.info.codec=k?"pcm-f32be":"pcm-f32"):P&1<<b-1?b===1?s.info.codec="pcm-s8":b===2?s.info.codec=k?"pcm-s16be":"pcm-s16":b===3?s.info.codec=k?"pcm-s24be":"pcm-s24":b===4&&(s.info.codec=k?"pcm-s32be":"pcm-s32"):b===1&&(s.info.codec="pcm-u8")),s.info.codec===null&&console.warn("Unsupported PCM format.")}}}s.info.codec==="opus"&&(x=tt),s.info.numberOfChannels=p,s.info.sampleRate=x,f==="twos"?g===8?s.info.codec="pcm-s8":g===16?s.info.codec="pcm-s16be":(console.warn(`Unsupported sample size ${g} for codec 'twos'.`),s.info.codec=null):f==="sowt"?g===8?s.info.codec="pcm-s8":g===16?s.info.codec="pcm-s16":(console.warn(`Unsupported sample size ${g} for codec 'sowt'.`),s.info.codec=null):f==="raw "?s.info.codec="pcm-u8":f==="in24"?s.info.codec="pcm-s24be":f==="in32"?s.info.codec="pcm-s32be":f==="fl32"?s.info.codec="pcm-f32be":f==="fl64"?s.info.codec="pcm-f64be":f==="ipcm"?s.info.codec="pcm-s16be":f==="fpcm"&&(s.info.codec="pcm-f32be"),this.readContiguousBoxes(e.slice(e.filePos,d+u.totalSize-e.filePos))}}}break;case"avcC":{let s=this.currentTrack;if(!s)break;h(s.info),s.info.codecDescription=E(e,n.contentSize)}break;case"hvcC":{let s=this.currentTrack;if(!s)break;h(s.info),s.info.codecDescription=E(e,n.contentSize)}break;case"vpcC":{let s=this.currentTrack;if(!s)break;h(s.info?.type==="video"),e.skip(4);let a=A(e),c=A(e),l=A(e),d=l>>4,u=l>>1&7,f=l&1,m=A(e),p=A(e),g=A(e);s.info.vp9CodecInfo={profile:a,level:c,bitDepth:d,chromaSubsampling:u,videoFullRangeFlag:f,colourPrimaries:m,transferCharacteristics:p,matrixCoefficients:g}}break;case"av1C":{let s=this.currentTrack;if(!s)break;h(s.info?.type==="video"),e.skip(1);let a=A(e),c=a>>5,l=a&31,d=A(e),u=d>>7,f=d>>6&1,m=d>>5&1,p=d>>4&1,g=d>>3&1,x=d>>2&1,y=d&3,b=c===2&&f?m?12:10:f?10:8;s.info.av1CodecInfo={profile:c,level:l,tier:u,bitDepth:b,monochrome:p,chromaSubsamplingX:g,chromaSubsamplingY:x,chromaSamplePosition:y}}break;case"colr":{let s=this.currentTrack;if(!s||(h(s.info?.type==="video"),L(e,4)!=="nclx"))break;let c=W(e),l=W(e),d=W(e),u=!!(A(e)&128);s.info.colorSpace={primaries:Kr[c],transfer:Xr[l],matrix:Qr[d],fullRange:u}}break;case"wave":this.readContiguousBoxes(e.slice(o,n.contentSize));break;case"esds":{let s=this.currentTrack;if(!s)break;h(s.info?.type==="audio"),e.skip(4);let a=A(e);h(a===3),hn(e),e.skip(2);let c=A(e),l=(c&128)!==0,d=(c&64)!==0,u=(c&32)!==0;if(l&&e.skip(2),d){let x=A(e);e.skip(x)}u&&e.skip(2);let f=A(e);h(f===4);let m=hn(e),p=e.filePos,g=A(e);if(g===64||g===103?(s.info.codec="aac",s.info.aacCodecInfo={isMpeg2:g===103}):g===105||g===107?s.info.codec="mp3":g===221?s.info.codec="vorbis":console.warn(`Unsupported audio codec (objectTypeIndication ${g}) - discarding track.`),e.skip(12),m>e.filePos-p){let x=A(e);h(x===5);let y=hn(e);if(s.info.codecDescription=E(e,y),s.info.codec==="aac"){let b=Lo(s.info.codecDescription);b.numberOfChannels!==null&&(s.info.numberOfChannels=b.numberOfChannels),b.sampleRate!==null&&(s.info.sampleRate=b.sampleRate)}}}break;case"enda":{let s=this.currentTrack;if(!s)break;h(s.info?.type==="audio"),W(e)&255&&(s.info.codec==="pcm-s16be"?s.info.codec="pcm-s16":s.info.codec==="pcm-s24be"?s.info.codec="pcm-s24":s.info.codec==="pcm-s32be"?s.info.codec="pcm-s32":s.info.codec==="pcm-f32be"?s.info.codec="pcm-f32":s.info.codec==="pcm-f64be"&&(s.info.codec="pcm-f64"))}break;case"pcmC":{let s=this.currentTrack;if(!s)break;h(s.info?.type==="audio"),e.skip(4);let c=!!(A(e)&1),l=A(e);s.info.codec==="pcm-s16be"?c?l===16?s.info.codec="pcm-s16":l===24?s.info.codec="pcm-s24":l===32?s.info.codec="pcm-s32":(console.warn(`Invalid ipcm sample size ${l}.`),s.info.codec=null):l===16?s.info.codec="pcm-s16be":l===24?s.info.codec="pcm-s24be":l===32?s.info.codec="pcm-s32be":(console.warn(`Invalid ipcm sample size ${l}.`),s.info.codec=null):s.info.codec==="pcm-f32be"&&(c?l===32?s.info.codec="pcm-f32":l===64?s.info.codec="pcm-f64":(console.warn(`Invalid fpcm sample size ${l}.`),s.info.codec=null):l===32?s.info.codec="pcm-f32be":l===64?s.info.codec="pcm-f64be":(console.warn(`Invalid fpcm sample size ${l}.`),s.info.codec=null));break}case"dOps":{let s=this.currentTrack;if(!s)break;h(s.info?.type==="audio"),e.skip(1);let a=A(e),c=W(e),l=v(e),d=pr(e),u=A(e),f;u!==0?f=E(e,2+a):f=new Uint8Array(0);let m=new Uint8Array(19+f.byteLength),p=new DataView(m.buffer);p.setUint32(0,1332770163,!1),p.setUint32(4,1214603620,!1),p.setUint8(8,1),p.setUint8(9,a),p.setUint16(10,c,!0),p.setUint32(12,l,!0),p.setInt16(16,d,!0),p.setUint8(18,u),m.set(f,19),s.info.codecDescription=m,s.info.numberOfChannels=a}break;case"dfLa":{let s=this.currentTrack;if(!s)break;h(s.info?.type==="audio"),e.skip(4);let a=127,c=128,l=e.filePos;for(;e.filePos<i;){let p=A(e),g=Le(e);if((p&a)===Ue.STREAMINFO){e.skip(10);let y=v(e),b=y>>>12,w=(y>>9&7)+1;s.info.sampleRate=b,s.info.numberOfChannels=w,e.skip(20)}else e.skip(g);if(p&c)break}let d=e.filePos;e.filePos=l;let u=E(e,d-l),f=new Uint8Array(4+u.byteLength);new DataView(f.buffer).setUint32(0,1716281667,!1),f.set(u,4),s.info.codecDescription=f}break;case"stts":{let s=this.currentTrack;if(!s||!s.sampleTable)break;e.skip(4);let a=v(e),c=0,l=0;for(let d=0;d<a;d++){let u=v(e),f=v(e);s.sampleTable.sampleTimingEntries.push({startIndex:c,startDecodeTimestamp:l,count:u,delta:f}),c+=u,l+=u*f}}break;case"ctts":{let s=this.currentTrack;if(!s||!s.sampleTable)break;e.skip(4);let a=v(e),c=0;for(let l=0;l<a;l++){let d=v(e),u=_e(e);s.sampleTable.sampleCompositionTimeOffsets.push({startIndex:c,count:d,offset:u}),c+=d}}break;case"stsz":{let s=this.currentTrack;if(!s||!s.sampleTable)break;e.skip(4);let a=v(e),c=v(e);if(a===0)for(let l=0;l<c;l++){let d=v(e);s.sampleTable.sampleSizes.push(d)}else s.sampleTable.sampleSizes.push(a)}break;case"stz2":{let s=this.currentTrack;if(!s||!s.sampleTable)break;e.skip(4),e.skip(3);let a=A(e),c=v(e),l=E(e,Math.ceil(c*a/8)),d=new N(l);for(let u=0;u<c;u++){let f=d.readBits(a);s.sampleTable.sampleSizes.push(f)}}break;case"stss":{let s=this.currentTrack;if(!s||!s.sampleTable)break;e.skip(4),s.sampleTable.keySampleIndices=[];let a=v(e);for(let c=0;c<a;c++){let l=v(e)-1;s.sampleTable.keySampleIndices.push(l)}s.sampleTable.keySampleIndices[0]!==0&&s.sampleTable.keySampleIndices.unshift(0)}break;case"stsc":{let s=this.currentTrack;if(!s||!s.sampleTable)break;e.skip(4);let a=v(e);for(let l=0;l<a;l++){let d=v(e)-1,u=v(e),f=v(e);s.sampleTable.sampleToChunk.push({startSampleIndex:-1,startChunkIndex:d,samplesPerChunk:u,sampleDescriptionIndex:f})}let c=0;for(let l=0;l<s.sampleTable.sampleToChunk.length;l++)if(s.sampleTable.sampleToChunk[l].startSampleIndex=c,l<s.sampleTable.sampleToChunk.length-1){let u=s.sampleTable.sampleToChunk[l+1].startChunkIndex-s.sampleTable.sampleToChunk[l].startChunkIndex;c+=u*s.sampleTable.sampleToChunk[l].samplesPerChunk}}break;case"stco":{let s=this.currentTrack;if(!s||!s.sampleTable)break;e.skip(4);let a=v(e);for(let c=0;c<a;c++){let l=v(e);s.sampleTable.chunkOffsets.push(l)}}break;case"co64":{let s=this.currentTrack;if(!s||!s.sampleTable)break;e.skip(4);let a=v(e);for(let c=0;c<a;c++){let l=ne(e);s.sampleTable.chunkOffsets.push(l)}}break;case"mvex":this.isFragmented=!0,this.readContiguousBoxes(e.slice(o,n.contentSize));break;case"mehd":{let s=A(e);e.skip(3);let a=s===1?ne(e):v(e);this.movieDurationInTimescale=a}break;case"trex":{e.skip(4);let s=v(e),a=v(e),c=v(e),l=v(e),d=v(e);this.fragmentTrackDefaults.push({trackId:s,defaultSampleDescriptionIndex:a,defaultSampleDuration:c,defaultSampleSize:l,defaultSampleFlags:d})}break;case"tfra":{let s=A(e);e.skip(3);let a=v(e),c=this.tracks.find(b=>b.id===a);if(!c)break;let l=v(e),d=(l&48)>>4,u=(l&12)>>2,f=l&3,m=[A,W,Le,v],p=m[d],g=m[u],x=m[f],y=v(e);for(let b=0;b<y;b++){let w=s===1?ne(e):v(e),k=s===1?ne(e):v(e);p(e),g(e),x(e),c.fragmentLookupTable.push({timestamp:w,moofOffset:k})}c.fragmentLookupTable.sort((b,w)=>b.timestamp-w.timestamp);for(let b=0;b<c.fragmentLookupTable.length-1;b++){let w=c.fragmentLookupTable[b],k=c.fragmentLookupTable[b+1];w.timestamp===k.timestamp&&(c.fragmentLookupTable.splice(b+1,1),b--)}}break;case"moof":this.currentFragment={moofOffset:t,moofSize:n.totalSize,implicitBaseDataOffset:t,trackData:new Map},this.readContiguousBoxes(e.slice(o,n.contentSize)),this.lastReadFragment=this.currentFragment,this.currentFragment=null;break;case"traf":if(h(this.currentFragment),this.readContiguousBoxes(e.slice(o,n.contentSize)),this.currentTrack){let s=this.currentFragment.trackData.get(this.currentTrack.id);if(s){let{currentFragmentState:a}=this.currentTrack;h(a),a.startTimestamp!==null&&(ei(s,a.startTimestamp),s.startTimestampIsFinal=!0)}this.currentTrack.currentFragmentState=null,this.currentTrack=null}break;case"tfhd":{h(this.currentFragment),e.skip(1);let s=Le(e),a=!!(s&1),c=!!(s&2),l=!!(s&8),d=!!(s&16),u=!!(s&32),f=!!(s&65536),m=!!(s&131072),p=v(e),g=this.tracks.find(y=>y.id===p);if(!g)break;let x=this.fragmentTrackDefaults.find(y=>y.trackId===p);this.currentTrack=g,g.currentFragmentState={baseDataOffset:this.currentFragment.implicitBaseDataOffset,sampleDescriptionIndex:x?.defaultSampleDescriptionIndex??null,defaultSampleDuration:x?.defaultSampleDuration??null,defaultSampleSize:x?.defaultSampleSize??null,defaultSampleFlags:x?.defaultSampleFlags??null,startTimestamp:null},a?g.currentFragmentState.baseDataOffset=ne(e):m&&(g.currentFragmentState.baseDataOffset=this.currentFragment.moofOffset),c&&(g.currentFragmentState.sampleDescriptionIndex=v(e)),l&&(g.currentFragmentState.defaultSampleDuration=v(e)),d&&(g.currentFragmentState.defaultSampleSize=v(e)),u&&(g.currentFragmentState.defaultSampleFlags=v(e)),f&&(g.currentFragmentState.defaultSampleDuration=0)}break;case"tfdt":{let s=this.currentTrack;if(!s)break;h(s.currentFragmentState);let a=A(e);e.skip(3);let c=a===0?v(e):ne(e);s.currentFragmentState.startTimestamp=c}break;case"trun":{let s=this.currentTrack;if(!s)break;if(h(this.currentFragment),h(s.currentFragmentState),this.currentFragment.trackData.has(s.id)){console.warn("Can't have two trun boxes for the same track in one fragment. Ignoring...");break}let a=A(e),c=Le(e),l=!!(c&1),d=!!(c&4),u=!!(c&256),f=!!(c&512),m=!!(c&1024),p=!!(c&2048),g=v(e),x=s.currentFragmentState.baseDataOffset;l&&(x+=_e(e));let y=null;d&&(y=v(e));let b=x;if(g===0){this.currentFragment.implicitBaseDataOffset=b;break}let w=0,k={track:s,startTimestamp:0,endTimestamp:0,firstKeyFrameTimestamp:null,samples:[],presentationTimestamps:[],startTimestampIsFinal:!1};this.currentFragment.trackData.set(s.id,k);for(let _=0;_<g;_++){let C;u?C=v(e):(h(s.currentFragmentState.defaultSampleDuration!==null),C=s.currentFragmentState.defaultSampleDuration);let F;f?F=v(e):(h(s.currentFragmentState.defaultSampleSize!==null),F=s.currentFragmentState.defaultSampleSize);let O;m?O=v(e):(h(s.currentFragmentState.defaultSampleFlags!==null),O=s.currentFragmentState.defaultSampleFlags),_===0&&y!==null&&(O=y);let R=0;p&&(a===0?R=v(e):R=_e(e));let j=!(O&65536);k.samples.push({presentationTimestamp:w+R,duration:C,byteOffset:b,byteSize:F,isKeyFrame:j}),b+=F,w+=C}k.presentationTimestamps=k.samples.map((_,C)=>({presentationTimestamp:_.presentationTimestamp,sampleIndex:C})).sort((_,C)=>_.presentationTimestamp-C.presentationTimestamp);for(let _=0;_<k.presentationTimestamps.length;_++){let C=k.presentationTimestamps[_],F=k.samples[C.sampleIndex];if(k.firstKeyFrameTimestamp===null&&F.isKeyFrame&&(k.firstKeyFrameTimestamp=F.presentationTimestamp),_<k.presentationTimestamps.length-1){let O=k.presentationTimestamps[_+1];F.duration=O.presentationTimestamp-C.presentationTimestamp}}let P=k.samples[k.presentationTimestamps[0].sampleIndex],S=k.samples[Y(k.presentationTimestamps).sampleIndex];k.startTimestamp=P.presentationTimestamp,k.endTimestamp=S.presentationTimestamp+S.duration,this.currentFragment.implicitBaseDataOffset=b}break;case"udta":{let s=this.iterateContiguousBoxes(e.slice(o,n.contentSize));for(let{boxInfo:a,slice:c}of s){if(a.name!=="meta"&&!this.currentTrack){let l=c.filePos;this.metadataTags.raw??={},a.name[0]==="\xA9"?this.metadataTags.raw[a.name]??=ue(c):this.metadataTags.raw[a.name]??=E(c,a.contentSize),c.filePos=l}switch(a.name){case"meta":c.skip(-a.headerSize),this.traverseBox(c);break;case"\xA9nam":case"name":this.currentTrack?this.currentTrack.name=$.decode(E(c,a.contentSize)):this.metadataTags.title??=ue(c);break;case"\xA9des":this.currentTrack||(this.metadataTags.description??=ue(c));break;case"\xA9ART":this.currentTrack||(this.metadataTags.artist??=ue(c));break;case"\xA9alb":this.currentTrack||(this.metadataTags.album??=ue(c));break;case"albr":this.currentTrack||(this.metadataTags.albumArtist??=ue(c));break;case"\xA9gen":this.currentTrack||(this.metadataTags.genre??=ue(c));break;case"\xA9day":if(!this.currentTrack){let l=new Date(ue(c));Number.isNaN(l.getTime())||(this.metadataTags.date??=l)}break;case"\xA9cmt":this.currentTrack||(this.metadataTags.comment??=ue(c));break;case"\xA9lyr":this.currentTrack||(this.metadataTags.lyrics??=ue(c));break}}}break;case"meta":{if(this.currentTrack)break;let a=v(e)!==0;this.currentMetadataKeys=new Map,a?this.readContiguousBoxes(e.slice(o,n.contentSize)):this.readContiguousBoxes(e.slice(o+4,n.contentSize-4)),this.currentMetadataKeys=null}break;case"keys":{if(!this.currentMetadataKeys)break;e.skip(4);let s=v(e);for(let a=0;a<s;a++){let c=v(e);e.skip(4);let l=$.decode(E(e,c-8));this.currentMetadataKeys.set(a+1,l)}}break;case"ilst":{if(!this.currentMetadataKeys)break;let s=this.iterateContiguousBoxes(e.slice(o,n.contentSize));for(let{boxInfo:a,slice:c}of s){let l=a.name,d=(l.charCodeAt(0)<<24)+(l.charCodeAt(1)<<16)+(l.charCodeAt(2)<<8)+l.charCodeAt(3);this.currentMetadataKeys.has(d)&&(l=this.currentMetadataKeys.get(d));let u=_s(c);switch(this.metadataTags.raw??={},this.metadataTags.raw[l]??=u,l){case"\xA9nam":case"titl":case"com.apple.quicktime.title":case"title":typeof u=="string"&&(this.metadataTags.title??=u);break;case"\xA9des":case"desc":case"dscp":case"com.apple.quicktime.description":case"description":typeof u=="string"&&(this.metadataTags.description??=u);break;case"\xA9ART":case"com.apple.quicktime.artist":case"artist":typeof u=="string"&&(this.metadataTags.artist??=u);break;case"\xA9alb":case"albm":case"com.apple.quicktime.album":case"album":typeof u=="string"&&(this.metadataTags.album??=u);break;case"aART":case"album_artist":typeof u=="string"&&(this.metadataTags.albumArtist??=u);break;case"\xA9cmt":case"com.apple.quicktime.comment":case"comment":typeof u=="string"&&(this.metadataTags.comment??=u);break;case"\xA9gen":case"gnre":case"com.apple.quicktime.genre":case"genre":typeof u=="string"&&(this.metadataTags.genre??=u);break;case"\xA9lyr":case"lyrics":typeof u=="string"&&(this.metadataTags.lyrics??=u);break;case"\xA9day":case"rldt":case"com.apple.quicktime.creationdate":case"date":if(typeof u=="string"){let f=new Date(u);Number.isNaN(f.getTime())||(this.metadataTags.date??=f)}break;case"covr":case"com.apple.quicktime.artwork":u instanceof Oe?(this.metadataTags.images??=[],this.metadataTags.images.push({data:u.data,kind:"coverFront",mimeType:u.mimeType})):u instanceof Uint8Array&&(this.metadataTags.images??=[],this.metadataTags.images.push({data:u,kind:"coverFront",mimeType:"image/*"}));break;case"track":if(typeof u=="string"){let f=u.split("/"),m=Number.parseInt(f[0],10),p=f[1]&&Number.parseInt(f[1],10);Number.isInteger(m)&&m>0&&(this.metadataTags.trackNumber??=m),p&&Number.isInteger(p)&&p>0&&(this.metadataTags.tracksTotal??=p)}break;case"trkn":if(u instanceof Uint8Array&&u.length>=6){let f=z(u),m=f.getUint16(2,!1),p=f.getUint16(4,!1);m>0&&(this.metadataTags.trackNumber??=m),p>0&&(this.metadataTags.tracksTotal??=p)}break;case"disc":case"disk":if(u instanceof Uint8Array&&u.length>=6){let f=z(u),m=f.getUint16(2,!1),p=f.getUint16(4,!1);m>0&&(this.metadataTags.discNumber??=m),p>0&&(this.metadataTags.discsTotal??=p)}break}}}break}return e.filePos=i,!0}},xn=class{constructor(e){this.internalTrack=e,this.packetToSampleIndex=new WeakMap,this.packetToFragmentLocation=new WeakMap}getId(){return this.internalTrack.id}getCodec(){throw new Error("Not implemented on base class.")}getInternalCodecId(){return this.internalTrack.internalCodecId}getName(){return this.internalTrack.name}getLanguageCode(){return this.internalTrack.languageCode}getTimeResolution(){return this.internalTrack.timescale}getDisposition(){return this.internalTrack.disposition}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}async getFirstTimestamp(){return(await this.getFirstPacket({metadataOnly:!0}))?.timestamp??0}async getFirstPacket(e){let t=await this.fetchPacketForSampleIndex(0,e);return t||!this.internalTrack.demuxer.isFragmented?t:this.performFragmentedLookup(null,n=>n.trackData.get(this.internalTrack.id)?{sampleIndex:0,correctSampleFound:!0}:{sampleIndex:-1,correctSampleFound:!1},-1/0,1/0,e)}mapTimestampIntoTimescale(e){return Ze(e*this.internalTrack.timescale)+this.internalTrack.editListOffset}async getPacket(e,t){let n=this.mapTimestampIntoTimescale(e),o=this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack),i=ni(o,n),s=await this.fetchPacketForSampleIndex(i,t);return!Es(o)||!this.internalTrack.demuxer.isFragmented?s:this.performFragmentedLookup(null,a=>{let c=a.trackData.get(this.internalTrack.id);if(!c)return{sampleIndex:-1,correctSampleFound:!1};let l=B(c.presentationTimestamps,n,f=>f.presentationTimestamp),d=l!==-1?c.presentationTimestamps[l].sampleIndex:-1,u=l!==-1&&n<c.endTimestamp;return{sampleIndex:d,correctSampleFound:u}},n,n,t)}async getNextPacket(e,t){let n=this.packetToSampleIndex.get(e);if(n!==void 0)return this.fetchPacketForSampleIndex(n+1,t);let o=this.packetToFragmentLocation.get(e);if(o===void 0)throw new Error("Packet was not created from this track.");return this.performFragmentedLookup(o.fragment,i=>{if(i===o.fragment){let s=i.trackData.get(this.internalTrack.id);if(o.sampleIndex+1<s.samples.length)return{sampleIndex:o.sampleIndex+1,correctSampleFound:!0}}else if(i.trackData.get(this.internalTrack.id))return{sampleIndex:0,correctSampleFound:!0};return{sampleIndex:-1,correctSampleFound:!1}},-1/0,1/0,t)}async getKeyPacket(e,t){let n=this.mapTimestampIntoTimescale(e),o=this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack),i=Oc(o,n),s=await this.fetchPacketForSampleIndex(i,t);return!Es(o)||!this.internalTrack.demuxer.isFragmented?s:this.performFragmentedLookup(null,a=>{let c=a.trackData.get(this.internalTrack.id);if(!c)return{sampleIndex:-1,correctSampleFound:!1};let l=Zr(c.presentationTimestamps,f=>c.samples[f.sampleIndex].isKeyFrame&&f.presentationTimestamp<=n),d=l!==-1?c.presentationTimestamps[l].sampleIndex:-1,u=l!==-1&&n<c.endTimestamp;return{sampleIndex:d,correctSampleFound:u}},n,n,t)}async getNextKeyPacket(e,t){let n=this.packetToSampleIndex.get(e);if(n!==void 0){let i=this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack),s=Uc(i,n);return this.fetchPacketForSampleIndex(s,t)}let o=this.packetToFragmentLocation.get(e);if(o===void 0)throw new Error("Packet was not created from this track.");return this.performFragmentedLookup(o.fragment,i=>{if(i===o.fragment){let a=i.trackData.get(this.internalTrack.id).samples.findIndex((c,l)=>c.isKeyFrame&&l>o.sampleIndex);if(a!==-1)return{sampleIndex:a,correctSampleFound:!0}}else{let s=i.trackData.get(this.internalTrack.id);if(s&&s.firstKeyFrameTimestamp!==null){let a=s.samples.findIndex(c=>c.isKeyFrame);return h(a!==-1),{sampleIndex:a,correctSampleFound:!0}}}return{sampleIndex:-1,correctSampleFound:!1}},-1/0,1/0,t)}async fetchPacketForSampleIndex(e,t){if(e===-1)return null;let n=this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack),o=zc(n,e);if(!o)return null;let i;if(t.metadataOnly)i=H;else{let l=this.internalTrack.demuxer.reader.requestSlice(o.sampleOffset,o.sampleSize);l instanceof Promise&&(l=await l),h(l),i=E(l,o.sampleSize)}let s=(o.presentationTimestamp-this.internalTrack.editListOffset)/this.internalTrack.timescale,a=o.duration/this.internalTrack.timescale,c=new V(i,o.isKeyFrame?"key":"delta",s,a,e,o.sampleSize);return this.packetToSampleIndex.set(c,e),c}async fetchPacketInFragment(e,t,n){if(t===-1)return null;let i=e.trackData.get(this.internalTrack.id).samples[t];h(i);let s;if(n.metadataOnly)s=H;else{let d=this.internalTrack.demuxer.reader.requestSlice(i.byteOffset,i.byteSize);d instanceof Promise&&(d=await d),h(d),s=E(d,i.byteSize)}let a=(i.presentationTimestamp-this.internalTrack.editListOffset)/this.internalTrack.timescale,c=i.duration/this.internalTrack.timescale,l=new V(s,i.isKeyFrame?"key":"delta",a,c,e.moofOffset+t,i.byteSize);return this.packetToFragmentLocation.set(l,{fragment:e,sampleIndex:t}),l}async performFragmentedLookup(e,t,n,o,i){let s=this.internalTrack.demuxer,a=null,c=null,l=-1;if(e){let{sampleIndex:x,correctSampleFound:y}=t(e);if(y)return this.fetchPacketInFragment(e,x,i);x!==-1&&(c=e,l=x)}let d=B(this.internalTrack.fragmentLookupTable,n,x=>x.timestamp),u=d!==-1?this.internalTrack.fragmentLookupTable[d]:null,f=B(this.internalTrack.fragmentPositionCache,n,x=>x.startTimestamp),m=f!==-1?this.internalTrack.fragmentPositionCache[f]:null,p=Math.max(u?.moofOffset??0,m?.moofOffset??0)||null,g;for(e?p===null||e.moofOffset>=p?(g=e.moofOffset+e.moofSize,a=e):g=p:g=p??0;;){if(a){let w=a.trackData.get(this.internalTrack.id);if(w&&w.startTimestamp>o)break}let x=s.reader.requestSliceRange(g,at,At);if(x instanceof Promise&&(x=await x),!x)break;let y=g,b=Ae(x);if(!b)break;if(b.name==="moof"){a=await s.readFragment(y);let{sampleIndex:w,correctSampleFound:k}=t(a);if(k)return this.fetchPacketInFragment(a,w,i);w!==-1&&(c=a,l=w)}g=y+b.totalSize}if(u&&(!c||c.moofOffset<u.moofOffset)){let x=this.internalTrack.fragmentLookupTable[d-1];h(!x||x.timestamp<u.timestamp);let y=x?.timestamp??-1/0;return this.performFragmentedLookup(null,t,y,o,i)}return c?this.fetchPacketInFragment(c,l,i):null}},ti=class extends xn{constructor(e){super(e),this.decoderConfigPromise=null,this.internalTrack=e}getCodec(){return this.internalTrack.info.codec}getCodedWidth(){return this.internalTrack.info.width}getCodedHeight(){return this.internalTrack.info.height}getRotation(){return this.internalTrack.rotation}async getColorSpace(){return{primaries:this.internalTrack.info.colorSpace?.primaries,transfer:this.internalTrack.info.colorSpace?.transfer,matrix:this.internalTrack.info.colorSpace?.matrix,fullRange:this.internalTrack.info.colorSpace?.fullRange}}async canBeTransparent(){return!1}async getDecoderConfig(){return this.internalTrack.info.codec?this.decoderConfigPromise??=(async()=>{if(this.internalTrack.info.codec==="vp9"&&!this.internalTrack.info.vp9CodecInfo){let e=await this.getFirstPacket({});this.internalTrack.info.vp9CodecInfo=e&&ln(e.data)}else if(this.internalTrack.info.codec==="av1"&&!this.internalTrack.info.av1CodecInfo){let e=await this.getFirstPacket({});this.internalTrack.info.av1CodecInfo=e&&un(e.data)}return{codec:nn(this.internalTrack.info),codedWidth:this.internalTrack.info.width,codedHeight:this.internalTrack.info.height,description:this.internalTrack.info.codecDescription??void 0,colorSpace:this.internalTrack.info.colorSpace??void 0}})():null}},ri=class extends xn{constructor(e){super(e),this.decoderConfig=null,this.internalTrack=e}getCodec(){return this.internalTrack.info.codec}getNumberOfChannels(){return this.internalTrack.info.numberOfChannels}getSampleRate(){return this.internalTrack.info.sampleRate}async getDecoderConfig(){return this.internalTrack.info.codec?this.decoderConfig??={codec:on(this.internalTrack.info),numberOfChannels:this.internalTrack.info.numberOfChannels,sampleRate:this.internalTrack.info.sampleRate,description:this.internalTrack.info.codecDescription??void 0}:null}},ni=(r,e)=>{if(r.presentationTimestamps){let t=B(r.presentationTimestamps,e,n=>n.presentationTimestamp);return t===-1?-1:r.presentationTimestamps[t].sampleIndex}else{let t=B(r.sampleTimingEntries,e,o=>o.startDecodeTimestamp);if(t===-1)return-1;let n=r.sampleTimingEntries[t];return n.startIndex+Math.min(Math.floor((e-n.startDecodeTimestamp)/n.delta),n.count-1)}},Oc=(r,e)=>{if(!r.keySampleIndices)return ni(r,e);if(r.presentationTimestamps){let t=B(r.presentationTimestamps,e,n=>n.presentationTimestamp);if(t===-1)return-1;for(let n=t;n>=0;n--){let o=r.presentationTimestamps[n].sampleIndex;if(Xe(r.keySampleIndices,o,s=>s)!==-1)return o}return-1}else{let t=ni(r,e),n=B(r.keySampleIndices,t,o=>o);return r.keySampleIndices[n]??-1}},zc=(r,e)=>{let t=B(r.sampleTimingEntries,e,y=>y.startIndex),n=r.sampleTimingEntries[t];if(!n||n.startIndex+n.count<=e)return null;let i=n.startDecodeTimestamp+(e-n.startIndex)*n.delta,s=B(r.sampleCompositionTimeOffsets,e,y=>y.startIndex),a=r.sampleCompositionTimeOffsets[s];a&&e-a.startIndex<a.count&&(i+=a.offset);let c=r.sampleSizes[Math.min(e,r.sampleSizes.length-1)],l=B(r.sampleToChunk,e,y=>y.startSampleIndex),d=r.sampleToChunk[l];h(d);let u=d.startChunkIndex+Math.floor((e-d.startSampleIndex)/d.samplesPerChunk),f=r.chunkOffsets[u],m=d.startSampleIndex+(u-d.startChunkIndex)*d.samplesPerChunk,p=0,g=f;if(r.sampleSizes.length===1)g+=c*(e-m),p+=c*d.samplesPerChunk;else for(let y=m;y<m+d.samplesPerChunk;y++){let b=r.sampleSizes[y];y<e&&(g+=b),p+=b}let x=n.delta;if(r.presentationTimestamps){let y=r.presentationTimestampIndexMap[e];h(y!==void 0),y<r.presentationTimestamps.length-1&&(x=r.presentationTimestamps[y+1].presentationTimestamp-i)}return{presentationTimestamp:i,duration:x,sampleOffset:g,sampleSize:c,chunkOffset:f,chunkSize:p,isKeyFrame:r.keySampleIndices?Xe(r.keySampleIndices,e,y=>y)!==-1:!0}},Uc=(r,e)=>{if(!r.keySampleIndices)return e+1;let t=B(r.keySampleIndices,e,n=>n);return r.keySampleIndices[t+1]??-1},ei=(r,e)=>{r.startTimestamp+=e,r.endTimestamp+=e;for(let t of r.samples)t.presentationTimestamp+=e;for(let t of r.presentationTimestamps)t.presentationTimestamp+=e},Nc=r=>{let[e,,,t]=r,n=Math.hypot(e,t),o=e/n,i=t/n,s=-Math.atan2(i,o)*(180/Math.PI);return Number.isFinite(s)?s:0},Es=r=>r.sampleSizes.length===0;var T;(function(r){r[r.EBML=440786851]="EBML",r[r.EBMLVersion=17030]="EBMLVersion",r[r.EBMLReadVersion=17143]="EBMLReadVersion",r[r.EBMLMaxIDLength=17138]="EBMLMaxIDLength",r[r.EBMLMaxSizeLength=17139]="EBMLMaxSizeLength",r[r.DocType=17026]="DocType",r[r.DocTypeVersion=17031]="DocTypeVersion",r[r.DocTypeReadVersion=17029]="DocTypeReadVersion",r[r.Void=236]="Void",r[r.Segment=408125543]="Segment",r[r.SeekHead=290298740]="SeekHead",r[r.Seek=19899]="Seek",r[r.SeekID=21419]="SeekID",r[r.SeekPosition=21420]="SeekPosition",r[r.Duration=17545]="Duration",r[r.Info=357149030]="Info",r[r.TimestampScale=2807729]="TimestampScale",r[r.MuxingApp=19840]="MuxingApp",r[r.WritingApp=22337]="WritingApp",r[r.Tracks=374648427]="Tracks",r[r.TrackEntry=174]="TrackEntry",r[r.TrackNumber=215]="TrackNumber",r[r.TrackUID=29637]="TrackUID",r[r.TrackType=131]="TrackType",r[r.FlagEnabled=185]="FlagEnabled",r[r.FlagDefault=136]="FlagDefault",r[r.FlagForced=21930]="FlagForced",r[r.FlagOriginal=21934]="FlagOriginal",r[r.FlagHearingImpaired=21931]="FlagHearingImpaired",r[r.FlagVisualImpaired=21932]="FlagVisualImpaired",r[r.FlagCommentary=21935]="FlagCommentary",r[r.FlagLacing=156]="FlagLacing",r[r.Name=21358]="Name",r[r.Language=2274716]="Language",r[r.LanguageBCP47=2274717]="LanguageBCP47",r[r.CodecID=134]="CodecID",r[r.CodecPrivate=25506]="CodecPrivate",r[r.CodecDelay=22186]="CodecDelay",r[r.SeekPreRoll=22203]="SeekPreRoll",r[r.DefaultDuration=2352003]="DefaultDuration",r[r.Video=224]="Video",r[r.PixelWidth=176]="PixelWidth",r[r.PixelHeight=186]="PixelHeight",r[r.AlphaMode=21440]="AlphaMode",r[r.Audio=225]="Audio",r[r.SamplingFrequency=181]="SamplingFrequency",r[r.Channels=159]="Channels",r[r.BitDepth=25188]="BitDepth",r[r.SimpleBlock=163]="SimpleBlock",r[r.BlockGroup=160]="BlockGroup",r[r.Block=161]="Block",r[r.BlockAdditions=30113]="BlockAdditions",r[r.BlockMore=166]="BlockMore",r[r.BlockAdditional=165]="BlockAdditional",r[r.BlockAddID=238]="BlockAddID",r[r.BlockDuration=155]="BlockDuration",r[r.ReferenceBlock=251]="ReferenceBlock",r[r.Cluster=524531317]="Cluster",r[r.Timestamp=231]="Timestamp",r[r.Cues=475249515]="Cues",r[r.CuePoint=187]="CuePoint",r[r.CueTime=179]="CueTime",r[r.CueTrackPositions=183]="CueTrackPositions",r[r.CueTrack=247]="CueTrack",r[r.CueClusterPosition=241]="CueClusterPosition",r[r.Colour=21936]="Colour",r[r.MatrixCoefficients=21937]="MatrixCoefficients",r[r.TransferCharacteristics=21946]="TransferCharacteristics",r[r.Primaries=21947]="Primaries",r[r.Range=21945]="Range",r[r.Projection=30320]="Projection",r[r.ProjectionType=30321]="ProjectionType",r[r.ProjectionPoseRoll=30325]="ProjectionPoseRoll",r[r.Attachments=423732329]="Attachments",r[r.AttachedFile=24999]="AttachedFile",r[r.FileDescription=18046]="FileDescription",r[r.FileName=18030]="FileName",r[r.FileMediaType=18016]="FileMediaType",r[r.FileData=18012]="FileData",r[r.FileUID=18094]="FileUID",r[r.Chapters=272869232]="Chapters",r[r.Tags=307544935]="Tags",r[r.Tag=29555]="Tag",r[r.Targets=25536]="Targets",r[r.TargetTypeValue=26826]="TargetTypeValue",r[r.TargetType=25546]="TargetType",r[r.TagTrackUID=25541]="TagTrackUID",r[r.TagEditionUID=25545]="TagEditionUID",r[r.TagChapterUID=25540]="TagChapterUID",r[r.TagAttachmentUID=25542]="TagAttachmentUID",r[r.SimpleTag=26568]="SimpleTag",r[r.TagName=17827]="TagName",r[r.TagLanguage=17530]="TagLanguage",r[r.TagString=17543]="TagString",r[r.TagBinary=17541]="TagBinary",r[r.ContentEncodings=28032]="ContentEncodings",r[r.ContentEncoding=25152]="ContentEncoding",r[r.ContentEncodingOrder=20529]="ContentEncodingOrder",r[r.ContentEncodingScope=20530]="ContentEncodingScope",r[r.ContentCompression=20532]="ContentCompression",r[r.ContentCompAlgo=16980]="ContentCompAlgo",r[r.ContentCompSettings=16981]="ContentCompSettings",r[r.ContentEncryption=20533]="ContentEncryption"})(T||(T={}));var Vc=[T.EBML,T.Segment],_t=[T.SeekHead,T.Info,T.Cluster,T.Tracks,T.Cues,T.Attachments,T.Chapters,T.Tags],hr=[...Vc,..._t];var oi=8,oe=2,de=2*oi,ii=r=>{let e=A(r);if(r.skip(-1),e===0)return null;let t=1,n=128;for(;(e&n)===0;)t++,n>>=1;return t},Et=r=>{let e=A(r);if(e===0)return null;let t=1,n=128;for(;(e&n)===0;)t++,n>>=1;let o=e&n-1;for(let i=1;i<t;i++)o*=256,o+=A(r);return o},D=(r,e)=>{if(e<1||e>8)throw new Error("Bad unsigned int size "+e);let t=0;for(let n=0;n<e;n++)t*=256,t+=A(r);return t},Ds=(r,e)=>{if(e<1)throw new Error("Bad unsigned int size "+e);let t=0n;for(let n=0;n<e;n++)t<<=8n,t+=BigInt(A(r));return t};var yn=r=>{let e=ii(r);return e===null?null:D(r,e)},si=r=>{let e=A(r);return e===255?e=null:(r.skip(-1),e=Et(r),e===72057594037927940&&(e=null)),e},fe=r=>{let e=yn(r);if(e===null)return null;let t=si(r);return{id:e,size:t}},He=(r,e)=>{let t=E(r,e),n=0;for(;n<e&&t[n]!==0;)n+=1;return String.fromCharCode(...t.subarray(0,n))},Ft=(r,e)=>{let t=E(r,e),n=0;for(;n<e&&t[n]!==0;)n+=1;return $.decode(t.subarray(0,n))},Tn=(r,e)=>{if(e===0)return 0;if(e!==4&&e!==8)throw new Error("Bad float size "+e);return e===4?Rs(r):bn(r)},wn=async(r,e,t,n)=>{let o=new Set(t),i=e;for(;n===null||i<n;){let s=r.requestSliceRange(i,oe,de);if(s instanceof Promise&&(s=await s),!s)break;let a=fe(s);if(!a)break;if(o.has(a.id))return{pos:i,found:!0};Ee(a.size),i=s.filePos+a.size}return{pos:n!==null&&n>i?n:i,found:!1}},ai=async(r,e,t,n)=>{let i=new Set(t),s=e;for(;s<n;){let a=r.requestSliceRange(s,0,Math.min(65536,n-s));if(a instanceof Promise&&(a=await a),!a||a.length<oi)break;for(let c=0;c<a.length-oi;c++){a.filePos=s;let l=yn(a);if(l!==null&&i.has(l))return s;s++}}return null},me={avc:"V_MPEG4/ISO/AVC",hevc:"V_MPEGH/ISO/HEVC",vp8:"V_VP8",vp9:"V_VP9",av1:"V_AV1",aac:"A_AAC",mp3:"A_MPEG/L3",opus:"A_OPUS",vorbis:"A_VORBIS",flac:"A_FLAC","pcm-u8":"A_PCM/INT/LIT","pcm-s16":"A_PCM/INT/LIT","pcm-s16be":"A_PCM/INT/BIG","pcm-s24":"A_PCM/INT/LIT","pcm-s24be":"A_PCM/INT/BIG","pcm-s32":"A_PCM/INT/LIT","pcm-s32be":"A_PCM/INT/BIG","pcm-f32":"A_PCM/FLOAT/IEEE","pcm-f64":"A_PCM/FLOAT/IEEE",webvtt:"S_TEXT/WEBVTT"};function Ee(r){if(r===null)throw new Error("Undefined element size is used in a place where it is not supported.")}var Ms=r=>{let t=(r.hasVideo?"video/":r.hasAudio?"audio/":"application/")+(r.isWebM?"webm":"x-matroska");if(r.codecStrings.length>0){let n=[...new Set(r.codecStrings.filter(Boolean))];t+=`; codecs="${n.join(", ")}"`}return t};var Fe;(function(r){r[r.None=0]="None",r[r.Xiph=1]="Xiph",r[r.FixedSize=2]="FixedSize",r[r.Ebml=3]="Ebml"})(Fe||(Fe={}));var kn;(function(r){r[r.Block=1]="Block",r[r.Private=2]="Private",r[r.Next=4]="Next"})(kn||(kn={}));var gr;(function(r){r[r.Zlib=0]="Zlib",r[r.Bzlib=1]="Bzlib",r[r.lzo1x=2]="lzo1x",r[r.HeaderStripping=3]="HeaderStripping"})(gr||(gr={}));var ci=[{id:T.SeekHead,flag:"seekHeadSeen"},{id:T.Info,flag:"infoSeen"},{id:T.Tracks,flag:"tracksSeen"},{id:T.Cues,flag:"cuesSeen"}],Bs=10*2**20,Sn=class extends Q{constructor(e){super(e),this.readMetadataPromise=null,this.segments=[],this.currentSegment=null,this.currentTrack=null,this.currentCluster=null,this.currentBlock=null,this.currentBlockAdditional=null,this.currentCueTime=null,this.currentDecodingInstruction=null,this.currentTagTargetIsMovie=!0,this.currentSimpleTagName=null,this.currentAttachedFile=null,this.isWebM=!1,this.reader=e._reader}async computeDuration(){let e=await this.getTracks(),t=await Promise.all(e.map(n=>n.computeDuration()));return Math.max(0,...t)}async getTracks(){return await this.readMetadata(),this.segments.flatMap(e=>e.tracks.map(t=>t.inputTrack))}async getMimeType(){await this.readMetadata();let e=await this.getTracks(),t=await Promise.all(e.map(n=>n.getCodecParameterString()));return Ms({isWebM:this.isWebM,hasVideo:this.segments.some(n=>n.tracks.some(o=>o.info?.type==="video")),hasAudio:this.segments.some(n=>n.tracks.some(o=>o.info?.type==="audio")),codecStrings:t.filter(Boolean)})}async getMetadataTags(){await this.readMetadata();for(let t of this.segments)t.metadataTagsCollected||(this.reader.fileSize!==null&&await this.loadSegmentMetadata(t),t.metadataTagsCollected=!0);let e={};for(let t of this.segments)e={...e,...t.metadataTags};return e}readMetadata(){return this.readMetadataPromise??=(async()=>{let e=0;for(;;){let t=this.reader.requestSliceRange(e,oe,de);if(t instanceof Promise&&(t=await t),!t)break;let n=fe(t);if(!n)break;let o=n.id,i=n.size,s=t.filePos;if(o===T.EBML){Ee(i);let a=this.reader.requestSlice(s,i);if(a instanceof Promise&&(a=await a),!a)break;this.readContiguousElements(a)}else if(o===T.Segment){if(await this.readSegment(s,i),i===null||this.reader.fileSize===null)break}else if(o===T.Cluster){if(this.reader.fileSize===null)break;i===null&&(i=(await wn(this.reader,s,hr,this.reader.fileSize)).pos-s);let a=Y(this.segments);a&&(a.elementEndPos=s+i)}Ee(i),e=s+i}})()}async readSegment(e,t){this.currentSegment={seekHeadSeen:!1,infoSeen:!1,tracksSeen:!1,cuesSeen:!1,tagsSeen:!1,attachmentsSeen:!1,timestampScale:-1,timestampFactor:-1,duration:-1,seekEntries:[],tracks:[],cuePoints:[],dataStartPos:e,elementEndPos:t===null?null:e+t,clusterSeekStartPos:e,lastReadCluster:null,metadataTags:{},metadataTagsCollected:!1},this.segments.push(this.currentSegment);let n=e;for(;this.currentSegment.elementEndPos===null||n<this.currentSegment.elementEndPos;){let a=this.reader.requestSliceRange(n,oe,de);if(a instanceof Promise&&(a=await a),!a)break;let c=n,l=fe(a);if(!l||!_t.includes(l.id)&&l.id!==T.Void){let p=await ai(this.reader,c,_t,Math.min(this.currentSegment.elementEndPos??1/0,c+Bs));if(p){n=p;continue}else break}let{id:d,size:u}=l,f=a.filePos,m=ci.findIndex(p=>p.id===d);if(m!==-1){let p=ci[m].flag;this.currentSegment[p]=!0,Ee(u);let g=this.reader.requestSlice(f,u);g instanceof Promise&&(g=await g),g&&this.readContiguousElements(g)}else if(d===T.Tags||d===T.Attachments){d===T.Tags?this.currentSegment.tagsSeen=!0:this.currentSegment.attachmentsSeen=!0,Ee(u);let p=this.reader.requestSlice(f,u);p instanceof Promise&&(p=await p),p&&this.readContiguousElements(p)}else if(d===T.Cluster){this.currentSegment.clusterSeekStartPos=c;break}if(u===null)break;n=f+u}if(this.currentSegment.seekEntries.sort((a,c)=>a.segmentPosition-c.segmentPosition),this.reader.fileSize!==null)for(let a of this.currentSegment.seekEntries){let c=ci.find(p=>p.id===a.id);if(!c||this.currentSegment[c.flag])continue;let l=this.reader.requestSliceRange(e+a.segmentPosition,oe,de);if(l instanceof Promise&&(l=await l),!l)continue;let d=fe(l);if(!d)continue;let{id:u,size:f}=d;if(u!==c.id)continue;Ee(f),this.currentSegment[c.flag]=!0;let m=this.reader.requestSlice(l.filePos,f);m instanceof Promise&&(m=await m),m&&this.readContiguousElements(m)}this.currentSegment.timestampScale===-1&&(this.currentSegment.timestampScale=1e6,this.currentSegment.timestampFactor=1e9/1e6),this.currentSegment.tracks.sort((a,c)=>Number(c.disposition.default)-Number(a.disposition.default));let o=new Map(this.currentSegment.tracks.map(a=>[a.id,a]));for(let a of this.currentSegment.cuePoints){let c=o.get(a.trackId);c&&c.cuePoints.push(a)}for(let a of this.currentSegment.tracks){a.cuePoints.sort((c,l)=>c.time-l.time);for(let c=0;c<a.cuePoints.length-1;c++){let l=a.cuePoints[c],d=a.cuePoints[c+1];l.time===d.time&&(a.cuePoints.splice(c+1,1),c--)}}let i=null,s=-1/0;for(let a of this.currentSegment.tracks)a.cuePoints.length>s&&(s=a.cuePoints.length,i=a);for(let a of this.currentSegment.tracks)a.cuePoints.length===0&&(a.cuePoints=i.cuePoints);this.currentSegment=null}async readCluster(e,t){if(t.lastReadCluster?.elementStartPos===e)return t.lastReadCluster;let n=this.reader.requestSliceRange(e,oe,de);n instanceof Promise&&(n=await n),h(n);let o=e,i=fe(n);h(i);let s=i.id;h(s===T.Cluster);let a=i.size,c=n.filePos;a===null&&(a=(await wn(this.reader,c,hr,t.elementEndPos)).pos-c);let l=this.reader.requestSlice(c,a);l instanceof Promise&&(l=await l);let d={segment:t,elementStartPos:o,elementEndPos:c+a,dataStartPos:c,timestamp:-1,trackData:new Map};if(this.currentCluster=d,l){let u=this.readContiguousElements(l,hr);d.elementEndPos=u}for(let[,u]of d.trackData){let f=u.track;h(u.blocks.length>0);let m=!1;for(let y=0;y<u.blocks.length;y++){let b=u.blocks[y];b.timestamp+=d.timestamp,m||=b.lacing!==Fe.None}u.presentationTimestamps=u.blocks.map((y,b)=>({timestamp:y.timestamp,blockIndex:b})).sort((y,b)=>y.timestamp-b.timestamp);for(let y=0;y<u.presentationTimestamps.length;y++){let b=u.presentationTimestamps[y],w=u.blocks[b.blockIndex];if(u.firstKeyFrameTimestamp===null&&w.isKeyFrame&&(u.firstKeyFrameTimestamp=w.timestamp),y<u.presentationTimestamps.length-1){let k=u.presentationTimestamps[y+1];w.duration=k.timestamp-w.timestamp}else w.duration===0&&f.defaultDuration!=null&&w.lacing===Fe.None&&(w.duration=f.defaultDuration)}m&&(this.expandLacedBlocks(u.blocks,f),u.presentationTimestamps=u.blocks.map((y,b)=>({timestamp:y.timestamp,blockIndex:b})).sort((y,b)=>y.timestamp-b.timestamp));let p=u.blocks[u.presentationTimestamps[0].blockIndex],g=u.blocks[Y(u.presentationTimestamps).blockIndex];u.startTimestamp=p.timestamp,u.endTimestamp=g.timestamp+g.duration;let x=B(f.clusterPositionCache,u.startTimestamp,y=>y.startTimestamp);(x===-1||f.clusterPositionCache[x].elementStartPos!==o)&&f.clusterPositionCache.splice(x+1,0,{elementStartPos:d.elementStartPos,startTimestamp:u.startTimestamp})}return t.lastReadCluster=d,d}getTrackDataInCluster(e,t){let n=e.trackData.get(t);if(!n){let o=e.segment.tracks.find(i=>i.id===t);if(!o)return null;n={track:o,startTimestamp:0,endTimestamp:0,firstKeyFrameTimestamp:null,blocks:[],presentationTimestamps:[]},e.trackData.set(t,n)}return n}expandLacedBlocks(e,t){for(let n=0;n<e.length;n++){let o=e[n];if(o.lacing===Fe.None)continue;o.decoded||(o.data=this.decodeBlockData(t,o.data),o.decoded=!0);let i=Dt.tempFromBytes(o.data),s=[],a=A(i)+1;switch(o.lacing){case Fe.Xiph:{let l=0;for(let d=0;d<a-1;d++){let u=0;for(;i.bufferPos<i.length;){let f=A(i);if(u+=f,f<255){s.push(u),l+=u;break}}}s.push(i.length-(i.bufferPos+l))}break;case Fe.FixedSize:{let l=i.length-1,d=Math.floor(l/a);for(let u=0;u<a;u++)s.push(d)}break;case Fe.Ebml:{let l=Et(i);h(l!==null);let d=l;s.push(d);let u=d;for(let f=1;f<a-1;f++){let m=i.bufferPos,p=Et(i);h(p!==null);let g=p,y=(1<<(i.bufferPos-m)*7-1)-1,b=g-y;d+=b,s.push(d),u+=d}s.push(i.length-(i.bufferPos+u))}break;default:h(!1)}h(s.length===a),e.splice(n,1);let c=o.duration||a*(t.defaultDuration??0);for(let l=0;l<a;l++){let d=s[l],u=E(i,d),f=o.timestamp+c*l/a,m=c/a;e.splice(n+l,0,{timestamp:f,duration:m,isKeyFrame:o.isKeyFrame,data:u,lacing:Fe.None,decoded:!0,mainAdditional:o.mainAdditional})}n+=a,n--}}async loadSegmentMetadata(e){for(let t of e.seekEntries){if(!(t.id===T.Tags&&!e.tagsSeen)){if(!(t.id===T.Attachments&&!e.attachmentsSeen))continue}let n=this.reader.requestSliceRange(e.dataStartPos+t.segmentPosition,oe,de);if(n instanceof Promise&&(n=await n),!n)continue;let o=fe(n);if(!o||o.id!==t.id)continue;let{size:i}=o;Ee(i),h(!this.currentSegment),this.currentSegment=e;let s=this.reader.requestSlice(n.filePos,i);s instanceof Promise&&(s=await s),s&&this.readContiguousElements(s),this.currentSegment=null,t.id===T.Tags?e.tagsSeen=!0:t.id===T.Attachments&&(e.attachmentsSeen=!0)}}readContiguousElements(e,t){let n=e.filePos;for(;e.filePos-n<=e.length-oe;){let o=e.filePos;if(!this.traverseElement(e,t))return o}return e.filePos}traverseElement(e,t){let n=fe(e);if(!n||t&&t.includes(n.id))return!1;let{id:o,size:i}=n,s=e.filePos;switch(Ee(i),o){case T.DocType:this.isWebM=He(e,i)==="webm";break;case T.Seek:{if(!this.currentSegment)break;let a={id:-1,segmentPosition:-1};this.currentSegment.seekEntries.push(a),this.readContiguousElements(e.slice(s,i)),(a.id===-1||a.segmentPosition===-1)&&this.currentSegment.seekEntries.pop()}break;case T.SeekID:{let a=this.currentSegment?.seekEntries[this.currentSegment.seekEntries.length-1];if(!a)break;a.id=D(e,i)}break;case T.SeekPosition:{let a=this.currentSegment?.seekEntries[this.currentSegment.seekEntries.length-1];if(!a)break;a.segmentPosition=D(e,i)}break;case T.TimestampScale:{if(!this.currentSegment)break;this.currentSegment.timestampScale=D(e,i),this.currentSegment.timestampFactor=1e9/this.currentSegment.timestampScale}break;case T.Duration:{if(!this.currentSegment)break;this.currentSegment.duration=Tn(e,i)}break;case T.TrackEntry:{if(!this.currentSegment)break;if(this.currentTrack={id:-1,segment:this.currentSegment,demuxer:this,clusterPositionCache:[],cuePoints:[],disposition:{...te},inputTrack:null,codecId:null,codecPrivate:null,defaultDuration:null,name:null,languageCode:K,decodingInstructions:[],info:null},this.readContiguousElements(e.slice(s,i)),this.currentTrack.decodingInstructions.some(a=>a.data?.type!=="decompress"||a.scope!==kn.Block||a.data.algorithm!==gr.HeaderStripping)&&(console.warn(`Track #${this.currentTrack.id} has an unsupported content encoding; dropping.`),this.currentTrack=null),this.currentTrack&&this.currentTrack.id!==-1&&this.currentTrack.codecId&&this.currentTrack.info){let a=this.currentTrack.codecId.indexOf("/"),c=a===-1?this.currentTrack.codecId:this.currentTrack.codecId.slice(0,a);if(this.currentTrack.info.type==="video"&&this.currentTrack.info.width!==-1&&this.currentTrack.info.height!==-1){this.currentTrack.codecId===me.avc?(this.currentTrack.info.codec="avc",this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate):this.currentTrack.codecId===me.hevc?(this.currentTrack.info.codec="hevc",this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate):c===me.vp8?this.currentTrack.info.codec="vp8":c===me.vp9?this.currentTrack.info.codec="vp9":c===me.av1&&(this.currentTrack.info.codec="av1");let l=this.currentTrack,d=new ke(this.input,new li(l));this.currentTrack.inputTrack=d,this.currentSegment.tracks.push(this.currentTrack)}else if(this.currentTrack.info.type==="audio"&&this.currentTrack.info.numberOfChannels!==-1&&this.currentTrack.info.sampleRate!==-1){c===me.aac?(this.currentTrack.info.codec="aac",this.currentTrack.info.aacCodecInfo={isMpeg2:this.currentTrack.codecId.includes("MPEG2")},this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate):this.currentTrack.codecId===me.mp3?this.currentTrack.info.codec="mp3":c===me.opus?(this.currentTrack.info.codec="opus",this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate,this.currentTrack.info.sampleRate=tt):c===me.vorbis?(this.currentTrack.info.codec="vorbis",this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate):c===me.flac?(this.currentTrack.info.codec="flac",this.currentTrack.info.codecDescription=this.currentTrack.codecPrivate):this.currentTrack.codecId==="A_PCM/INT/LIT"?this.currentTrack.info.bitDepth===8?this.currentTrack.info.codec="pcm-u8":this.currentTrack.info.bitDepth===16?this.currentTrack.info.codec="pcm-s16":this.currentTrack.info.bitDepth===24?this.currentTrack.info.codec="pcm-s24":this.currentTrack.info.bitDepth===32&&(this.currentTrack.info.codec="pcm-s32"):this.currentTrack.codecId==="A_PCM/INT/BIG"?this.currentTrack.info.bitDepth===8?this.currentTrack.info.codec="pcm-u8":this.currentTrack.info.bitDepth===16?this.currentTrack.info.codec="pcm-s16be":this.currentTrack.info.bitDepth===24?this.currentTrack.info.codec="pcm-s24be":this.currentTrack.info.bitDepth===32&&(this.currentTrack.info.codec="pcm-s32be"):this.currentTrack.codecId==="A_PCM/FLOAT/IEEE"&&(this.currentTrack.info.bitDepth===32?this.currentTrack.info.codec="pcm-f32":this.currentTrack.info.bitDepth===64&&(this.currentTrack.info.codec="pcm-f64"));let l=this.currentTrack,d=new G(this.input,new ui(l));this.currentTrack.inputTrack=d,this.currentSegment.tracks.push(this.currentTrack)}}this.currentTrack=null}break;case T.TrackNumber:{if(!this.currentTrack)break;this.currentTrack.id=D(e,i)}break;case T.TrackType:{if(!this.currentTrack)break;let a=D(e,i);a===1?this.currentTrack.info={type:"video",width:-1,height:-1,rotation:0,codec:null,codecDescription:null,colorSpace:null,alphaMode:!1}:a===2&&(this.currentTrack.info={type:"audio",numberOfChannels:-1,sampleRate:-1,bitDepth:-1,codec:null,codecDescription:null,aacCodecInfo:null})}break;case T.FlagEnabled:{if(!this.currentTrack)break;D(e,i)||(this.currentSegment.tracks.pop(),this.currentTrack=null)}break;case T.FlagDefault:{if(!this.currentTrack)break;this.currentTrack.disposition.default=!!D(e,i)}break;case T.FlagForced:{if(!this.currentTrack)break;this.currentTrack.disposition.forced=!!D(e,i)}break;case T.FlagOriginal:{if(!this.currentTrack)break;this.currentTrack.disposition.original=!!D(e,i)}break;case T.FlagHearingImpaired:{if(!this.currentTrack)break;this.currentTrack.disposition.hearingImpaired=!!D(e,i)}break;case T.FlagVisualImpaired:{if(!this.currentTrack)break;this.currentTrack.disposition.visuallyImpaired=!!D(e,i)}break;case T.FlagCommentary:{if(!this.currentTrack)break;this.currentTrack.disposition.commentary=!!D(e,i)}break;case T.CodecID:{if(!this.currentTrack)break;this.currentTrack.codecId=He(e,i)}break;case T.CodecPrivate:{if(!this.currentTrack)break;this.currentTrack.codecPrivate=E(e,i)}break;case T.DefaultDuration:{if(!this.currentTrack)break;this.currentTrack.defaultDuration=this.currentTrack.segment.timestampFactor*D(e,i)/1e9}break;case T.Name:{if(!this.currentTrack)break;this.currentTrack.name=Ft(e,i)}break;case T.Language:{if(!this.currentTrack||this.currentTrack.languageCode!==K)break;this.currentTrack.languageCode=He(e,i),Jr(this.currentTrack.languageCode)||(this.currentTrack.languageCode=K)}break;case T.LanguageBCP47:{if(!this.currentTrack)break;let c=He(e,i).split("-")[0];c?this.currentTrack.languageCode=c:this.currentTrack.languageCode=K}break;case T.Video:{if(this.currentTrack?.info?.type!=="video")break;this.readContiguousElements(e.slice(s,i))}break;case T.PixelWidth:{if(this.currentTrack?.info?.type!=="video")break;this.currentTrack.info.width=D(e,i)}break;case T.PixelHeight:{if(this.currentTrack?.info?.type!=="video")break;this.currentTrack.info.height=D(e,i)}break;case T.AlphaMode:{if(this.currentTrack?.info?.type!=="video")break;this.currentTrack.info.alphaMode=D(e,i)===1}break;case T.Colour:{if(this.currentTrack?.info?.type!=="video")break;this.currentTrack.info.colorSpace={},this.readContiguousElements(e.slice(s,i))}break;case T.MatrixCoefficients:{if(this.currentTrack?.info?.type!=="video"||!this.currentTrack.info.colorSpace)break;let a=D(e,i),c=Qr[a]??null;this.currentTrack.info.colorSpace.matrix=c}break;case T.Range:{if(this.currentTrack?.info?.type!=="video"||!this.currentTrack.info.colorSpace)break;this.currentTrack.info.colorSpace.fullRange=D(e,i)===2}break;case T.TransferCharacteristics:{if(this.currentTrack?.info?.type!=="video"||!this.currentTrack.info.colorSpace)break;let a=D(e,i),c=Xr[a]??null;this.currentTrack.info.colorSpace.transfer=c}break;case T.Primaries:{if(this.currentTrack?.info?.type!=="video"||!this.currentTrack.info.colorSpace)break;let a=D(e,i),c=Kr[a]??null;this.currentTrack.info.colorSpace.primaries=c}break;case T.Projection:{if(this.currentTrack?.info?.type!=="video")break;this.readContiguousElements(e.slice(s,i))}break;case T.ProjectionPoseRoll:{if(this.currentTrack?.info?.type!=="video")break;let c=-Tn(e,i);try{this.currentTrack.info.rotation=$r(c)}catch{}}break;case T.Audio:{if(this.currentTrack?.info?.type!=="audio")break;this.readContiguousElements(e.slice(s,i))}break;case T.SamplingFrequency:{if(this.currentTrack?.info?.type!=="audio")break;this.currentTrack.info.sampleRate=Tn(e,i)}break;case T.Channels:{if(this.currentTrack?.info?.type!=="audio")break;this.currentTrack.info.numberOfChannels=D(e,i)}break;case T.BitDepth:{if(this.currentTrack?.info?.type!=="audio")break;this.currentTrack.info.bitDepth=D(e,i)}break;case T.CuePoint:{if(!this.currentSegment)break;this.readContiguousElements(e.slice(s,i)),this.currentCueTime=null}break;case T.CueTime:this.currentCueTime=D(e,i);break;case T.CueTrackPositions:{if(this.currentCueTime===null)break;h(this.currentSegment);let a={time:this.currentCueTime,trackId:-1,clusterPosition:-1};this.currentSegment.cuePoints.push(a),this.readContiguousElements(e.slice(s,i)),(a.trackId===-1||a.clusterPosition===-1)&&this.currentSegment.cuePoints.pop()}break;case T.CueTrack:{let a=this.currentSegment?.cuePoints[this.currentSegment.cuePoints.length-1];if(!a)break;a.trackId=D(e,i)}break;case T.CueClusterPosition:{let a=this.currentSegment?.cuePoints[this.currentSegment.cuePoints.length-1];if(!a)break;h(this.currentSegment),a.clusterPosition=this.currentSegment.dataStartPos+D(e,i)}break;case T.Timestamp:{if(!this.currentCluster)break;this.currentCluster.timestamp=D(e,i)}break;case T.SimpleBlock:{if(!this.currentCluster)break;let a=Et(e);if(a===null)break;let c=this.getTrackDataInCluster(this.currentCluster,a);if(!c)break;let l=pr(e),d=A(e),u=d>>1&3,f=!!(d&128);c.track.info?.type==="audio"&&c.track.info.codec&&(f=!0);let m=E(e,i-(e.filePos-s)),p=c.track.decodingInstructions.length>0;c.blocks.push({timestamp:l,duration:0,isKeyFrame:f,data:m,lacing:u,decoded:!p,mainAdditional:null})}break;case T.BlockGroup:{if(!this.currentCluster)break;this.readContiguousElements(e.slice(s,i)),this.currentBlock=null}break;case T.Block:{if(!this.currentCluster)break;let a=Et(e);if(a===null)break;let c=this.getTrackDataInCluster(this.currentCluster,a);if(!c)break;let l=pr(e),u=A(e)>>1&3,f=E(e,i-(e.filePos-s)),m=c.track.decodingInstructions.length>0;this.currentBlock={timestamp:l,duration:0,isKeyFrame:!0,data:f,lacing:u,decoded:!m,mainAdditional:null},c.blocks.push(this.currentBlock)}break;case T.BlockAdditions:this.readContiguousElements(e.slice(s,i));break;case T.BlockMore:{if(!this.currentBlock)break;this.currentBlockAdditional={addId:1,data:null},this.readContiguousElements(e.slice(s,i)),this.currentBlockAdditional.data&&this.currentBlockAdditional.addId===1&&(this.currentBlock.mainAdditional=this.currentBlockAdditional.data),this.currentBlockAdditional=null}break;case T.BlockAdditional:{if(!this.currentBlockAdditional)break;this.currentBlockAdditional.data=E(e,i)}break;case T.BlockAddID:{if(!this.currentBlockAdditional)break;this.currentBlockAdditional.addId=D(e,i)}break;case T.BlockDuration:{if(!this.currentBlock)break;this.currentBlock.duration=D(e,i)}break;case T.ReferenceBlock:{if(!this.currentBlock)break;this.currentBlock.isKeyFrame=!1}break;case T.Tag:this.currentTagTargetIsMovie=!0,this.readContiguousElements(e.slice(s,i));break;case T.Targets:this.readContiguousElements(e.slice(s,i));break;case T.TargetTypeValue:D(e,i)!==50&&(this.currentTagTargetIsMovie=!1);break;case T.TagTrackUID:case T.TagEditionUID:case T.TagChapterUID:case T.TagAttachmentUID:this.currentTagTargetIsMovie=!1;break;case T.SimpleTag:{if(!this.currentTagTargetIsMovie)break;this.currentSimpleTagName=null,this.readContiguousElements(e.slice(s,i))}break;case T.TagName:this.currentSimpleTagName=Ft(e,i);break;case T.TagString:{if(!this.currentSimpleTagName)break;let a=Ft(e,i);this.processTagValue(this.currentSimpleTagName,a)}break;case T.TagBinary:{if(!this.currentSimpleTagName)break;let a=E(e,i);this.processTagValue(this.currentSimpleTagName,a)}break;case T.AttachedFile:{if(!this.currentSegment)break;this.currentAttachedFile={fileUid:null,fileName:null,fileMediaType:null,fileData:null,fileDescription:null},this.readContiguousElements(e.slice(s,i));let a=this.currentSegment.metadataTags;if(this.currentAttachedFile.fileUid&&this.currentAttachedFile.fileData&&(a.raw??={},a.raw[this.currentAttachedFile.fileUid.toString()]=new rn(this.currentAttachedFile.fileData,this.currentAttachedFile.fileMediaType??void 0,this.currentAttachedFile.fileName??void 0,this.currentAttachedFile.fileDescription??void 0)),this.currentAttachedFile.fileMediaType?.startsWith("image/")&&this.currentAttachedFile.fileData){let c=this.currentAttachedFile.fileName,l="unknown";if(c){let d=c.toLowerCase();d.startsWith("cover.")?l="coverFront":d.startsWith("back.")&&(l="coverBack")}a.images??=[],a.images.push({data:this.currentAttachedFile.fileData,mimeType:this.currentAttachedFile.fileMediaType,kind:l,name:this.currentAttachedFile.fileName??void 0,description:this.currentAttachedFile.fileDescription??void 0})}this.currentAttachedFile=null}break;case T.FileUID:{if(!this.currentAttachedFile)break;this.currentAttachedFile.fileUid=Ds(e,i)}break;case T.FileName:{if(!this.currentAttachedFile)break;this.currentAttachedFile.fileName=Ft(e,i)}break;case T.FileMediaType:{if(!this.currentAttachedFile)break;this.currentAttachedFile.fileMediaType=He(e,i)}break;case T.FileData:{if(!this.currentAttachedFile)break;this.currentAttachedFile.fileData=E(e,i)}break;case T.FileDescription:{if(!this.currentAttachedFile)break;this.currentAttachedFile.fileDescription=Ft(e,i)}break;case T.ContentEncodings:{if(!this.currentTrack)break;this.readContiguousElements(e.slice(s,i)),this.currentTrack.decodingInstructions.sort((a,c)=>c.order-a.order)}break;case T.ContentEncoding:this.currentDecodingInstruction={order:0,scope:kn.Block,data:null},this.readContiguousElements(e.slice(s,i)),this.currentDecodingInstruction.data&&this.currentTrack.decodingInstructions.push(this.currentDecodingInstruction),this.currentDecodingInstruction=null;break;case T.ContentEncodingOrder:{if(!this.currentDecodingInstruction)break;this.currentDecodingInstruction.order=D(e,i)}break;case T.ContentEncodingScope:{if(!this.currentDecodingInstruction)break;this.currentDecodingInstruction.scope=D(e,i)}break;case T.ContentCompression:{if(!this.currentDecodingInstruction)break;this.currentDecodingInstruction.data={type:"decompress",algorithm:gr.Zlib,settings:null},this.readContiguousElements(e.slice(s,i))}break;case T.ContentCompAlgo:{if(this.currentDecodingInstruction?.data?.type!=="decompress")break;this.currentDecodingInstruction.data.algorithm=D(e,i)}break;case T.ContentCompSettings:{if(this.currentDecodingInstruction?.data?.type!=="decompress")break;this.currentDecodingInstruction.data.settings=E(e,i)}break;case T.ContentEncryption:{if(!this.currentDecodingInstruction)break;this.currentDecodingInstruction.data={type:"decrypt"}}break}return e.filePos=s+i,!0}decodeBlockData(e,t){h(e.decodingInstructions.length>0);let n=t;for(let o of e.decodingInstructions)switch(h(o.data),o.data.type){case"decompress":switch(o.data.algorithm){case gr.HeaderStripping:if(o.data.settings&&o.data.settings.length>0){let i=o.data.settings,s=new Uint8Array(i.length+n.length);s.set(i,0),s.set(n,i.length),n=s}break;default:}break;default:}return n}processTagValue(e,t){if(!this.currentSegment?.metadataTags)return;let n=this.currentSegment.metadataTags;if(n.raw??={},n.raw[e]??=t,typeof t=="string")switch(e.toLowerCase()){case"title":n.title??=t;break;case"description":n.description??=t;break;case"artist":n.artist??=t;break;case"album":n.album??=t;break;case"album_artist":n.albumArtist??=t;break;case"genre":n.genre??=t;break;case"comment":n.comment??=t;break;case"lyrics":n.lyrics??=t;break;case"date":{let o=new Date(t);Number.isNaN(o.getTime())||(n.date??=o)}break;case"track_number":case"part_number":{let o=t.split("/"),i=Number.parseInt(o[0],10),s=o[1]&&Number.parseInt(o[1],10);Number.isInteger(i)&&i>0&&(n.trackNumber??=i),s&&Number.isInteger(s)&&s>0&&(n.tracksTotal??=s)}break;case"disc_number":case"disc":{let o=t.split("/"),i=Number.parseInt(o[0],10),s=o[1]&&Number.parseInt(o[1],10);Number.isInteger(i)&&i>0&&(n.discNumber??=i),s&&Number.isInteger(s)&&s>0&&(n.discsTotal??=s)}break}}},vn=class{constructor(e){this.internalTrack=e,this.packetToClusterLocation=new WeakMap}getId(){return this.internalTrack.id}getCodec(){throw new Error("Not implemented on base class.")}getInternalCodecId(){return this.internalTrack.codecId}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}getName(){return this.internalTrack.name}getLanguageCode(){return this.internalTrack.languageCode}async getFirstTimestamp(){return(await this.getFirstPacket({metadataOnly:!0}))?.timestamp??0}getTimeResolution(){return this.internalTrack.segment.timestampFactor}getDisposition(){return this.internalTrack.disposition}async getFirstPacket(e){return this.performClusterLookup(null,t=>t.trackData.get(this.internalTrack.id)?{blockIndex:0,correctBlockFound:!0}:{blockIndex:-1,correctBlockFound:!1},-1/0,1/0,e)}intoTimescale(e){return Ze(e*this.internalTrack.segment.timestampFactor)}async getPacket(e,t){let n=this.intoTimescale(e);return this.performClusterLookup(null,o=>{let i=o.trackData.get(this.internalTrack.id);if(!i)return{blockIndex:-1,correctBlockFound:!1};let s=B(i.presentationTimestamps,n,l=>l.timestamp),a=s!==-1?i.presentationTimestamps[s].blockIndex:-1,c=s!==-1&&n<i.endTimestamp;return{blockIndex:a,correctBlockFound:c}},n,n,t)}async getNextPacket(e,t){let n=this.packetToClusterLocation.get(e);if(n===void 0)throw new Error("Packet was not created from this track.");return this.performClusterLookup(n.cluster,o=>{if(o===n.cluster){let i=o.trackData.get(this.internalTrack.id);if(n.blockIndex+1<i.blocks.length)return{blockIndex:n.blockIndex+1,correctBlockFound:!0}}else if(o.trackData.get(this.internalTrack.id))return{blockIndex:0,correctBlockFound:!0};return{blockIndex:-1,correctBlockFound:!1}},-1/0,1/0,t)}async getKeyPacket(e,t){let n=this.intoTimescale(e);return this.performClusterLookup(null,o=>{let i=o.trackData.get(this.internalTrack.id);if(!i)return{blockIndex:-1,correctBlockFound:!1};let s=Zr(i.presentationTimestamps,l=>i.blocks[l.blockIndex].isKeyFrame&&l.timestamp<=n),a=s!==-1?i.presentationTimestamps[s].blockIndex:-1,c=s!==-1&&n<i.endTimestamp;return{blockIndex:a,correctBlockFound:c}},n,n,t)}async getNextKeyPacket(e,t){let n=this.packetToClusterLocation.get(e);if(n===void 0)throw new Error("Packet was not created from this track.");return this.performClusterLookup(n.cluster,o=>{if(o===n.cluster){let s=o.trackData.get(this.internalTrack.id).blocks.findIndex((a,c)=>a.isKeyFrame&&c>n.blockIndex);if(s!==-1)return{blockIndex:s,correctBlockFound:!0}}else{let i=o.trackData.get(this.internalTrack.id);if(i&&i.firstKeyFrameTimestamp!==null){let s=i.blocks.findIndex(a=>a.isKeyFrame);return h(s!==-1),{blockIndex:s,correctBlockFound:!0}}}return{blockIndex:-1,correctBlockFound:!1}},-1/0,1/0,t)}async fetchPacketInCluster(e,t,n){if(t===-1)return null;let i=e.trackData.get(this.internalTrack.id).blocks[t];h(i),i.decoded||(i.data=this.internalTrack.demuxer.decodeBlockData(this.internalTrack,i.data),i.decoded=!0);let s=n.metadataOnly?H:i.data,a=i.timestamp/this.internalTrack.segment.timestampFactor,c=i.duration/this.internalTrack.segment.timestampFactor,l={};i.mainAdditional&&this.internalTrack.info?.type==="video"&&this.internalTrack.info.alphaMode&&(l.alpha=n.metadataOnly?H:i.mainAdditional,l.alphaByteLength=i.mainAdditional.byteLength);let d=new V(s,i.isKeyFrame?"key":"delta",a,c,e.dataStartPos+t,i.data.byteLength,l);return this.packetToClusterLocation.set(d,{cluster:e,blockIndex:t}),d}async performClusterLookup(e,t,n,o,i){let{demuxer:s,segment:a}=this.internalTrack,c=null,l=null,d=-1;if(e){let{blockIndex:y,correctBlockFound:b}=t(e);if(b)return this.fetchPacketInCluster(e,y,i);y!==-1&&(l=e,d=y)}let u=B(this.internalTrack.cuePoints,n,y=>y.time),f=u!==-1?this.internalTrack.cuePoints[u]:null,m=B(this.internalTrack.clusterPositionCache,n,y=>y.startTimestamp),p=m!==-1?this.internalTrack.clusterPositionCache[m]:null,g=Math.max(f?.clusterPosition??0,p?.elementStartPos??0)||null,x;for(e?g===null||e.elementStartPos>=g?(x=e.elementEndPos,c=e):x=g:x=g??a.clusterSeekStartPos;a.elementEndPos===null||x<=a.elementEndPos-oe;){if(c){let C=c.trackData.get(this.internalTrack.id);if(C&&C.startTimestamp>o)break}let y=s.reader.requestSliceRange(x,oe,de);if(y instanceof Promise&&(y=await y),!y)break;let b=x,w=fe(y);if(!w||!_t.includes(w.id)&&w.id!==T.Void){let C=await ai(s.reader,b,_t,Math.min(a.elementEndPos??1/0,b+Bs));if(C){x=C;continue}else break}let k=w.id,P=w.size,S=y.filePos;if(k===T.Cluster){c=await s.readCluster(b,a),P=c.elementEndPos-S;let{blockIndex:C,correctBlockFound:F}=t(c);if(F)return this.fetchPacketInCluster(c,C,i);C!==-1&&(l=c,d=C)}P===null&&(h(k!==T.Cluster),P=(await wn(s.reader,S,hr,a.elementEndPos)).pos-S);let _=S+P;if(a.elementEndPos===null){let C=s.reader.requestSliceRange(_,oe,de);if(C instanceof Promise&&(C=await C),!C)break;if(yn(C)===T.Segment){a.elementEndPos=_;break}}x=_}if(f&&(!l||l.elementStartPos<f.clusterPosition)){let y=this.internalTrack.cuePoints[u-1];h(!y||y.time<f.time);let b=y?.time??-1/0;return this.performClusterLookup(null,t,b,o,i)}return l?this.fetchPacketInCluster(l,d,i):null}},li=class extends vn{constructor(e){super(e),this.decoderConfigPromise=null,this.internalTrack=e}getCodec(){return this.internalTrack.info.codec}getCodedWidth(){return this.internalTrack.info.width}getCodedHeight(){return this.internalTrack.info.height}getRotation(){return this.internalTrack.info.rotation}async getColorSpace(){return{primaries:this.internalTrack.info.colorSpace?.primaries,transfer:this.internalTrack.info.colorSpace?.transfer,matrix:this.internalTrack.info.colorSpace?.matrix,fullRange:this.internalTrack.info.colorSpace?.fullRange}}async canBeTransparent(){return this.internalTrack.info.alphaMode}async getDecoderConfig(){return this.internalTrack.info.codec?this.decoderConfigPromise??=(async()=>{let e=null;return(this.internalTrack.info.codec==="vp9"||this.internalTrack.info.codec==="av1"||this.internalTrack.info.codec==="avc"&&!this.internalTrack.info.codecDescription||this.internalTrack.info.codec==="hevc"&&!this.internalTrack.info.codecDescription)&&(e=await this.getFirstPacket({})),{codec:nn({width:this.internalTrack.info.width,height:this.internalTrack.info.height,codec:this.internalTrack.info.codec,codecDescription:this.internalTrack.info.codecDescription,colorSpace:this.internalTrack.info.colorSpace,avcType:1,avcCodecInfo:this.internalTrack.info.codec==="avc"&&e?fs(e.data):null,hevcCodecInfo:this.internalTrack.info.codec==="hevc"&&e?ps(e.data):null,vp9CodecInfo:this.internalTrack.info.codec==="vp9"&&e?ln(e.data):null,av1CodecInfo:this.internalTrack.info.codec==="av1"&&e?un(e.data):null}),codedWidth:this.internalTrack.info.width,codedHeight:this.internalTrack.info.height,description:this.internalTrack.info.codecDescription??void 0,colorSpace:this.internalTrack.info.colorSpace??void 0}})():null}},ui=class extends vn{constructor(e){super(e),this.decoderConfig=null,this.internalTrack=e}getCodec(){return this.internalTrack.info.codec}getNumberOfChannels(){return this.internalTrack.info.numberOfChannels}getSampleRate(){return this.internalTrack.info.sampleRate}async getDecoderConfig(){return this.internalTrack.info.codec?this.decoderConfig??={codec:on({codec:this.internalTrack.info.codec,codecDescription:this.internalTrack.info.codecDescription,aacCodecInfo:this.internalTrack.info.aacCodecInfo}),numberOfChannels:this.internalTrack.info.numberOfChannels,sampleRate:this.internalTrack.info.sampleRate,description:this.internalTrack.info.codecDescription??void 0}:null}};var Lc=[44100,48e3,32e3],Hc=[-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,32,40,48,56,64,80,96,112,128,160,192,224,256,320,-1,-1,32,48,56,64,80,96,112,128,160,192,224,256,320,384,-1,-1,32,64,96,128,160,192,224,256,288,320,352,384,416,448,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,8,16,24,32,40,48,56,64,80,96,112,128,144,160,-1,-1,8,16,24,32,40,48,56,64,80,96,112,128,144,160,-1,-1,32,48,56,64,80,96,112,128,144,160,176,192,224,256,-1],Os=1483304551,zs=1231971951,qc=(r,e,t,n,o)=>e===0?0:e===1?Math.floor(144*t/(n<<r))+o:e===2?Math.floor(144*t/n)+o:(Math.floor(12*t/n)+o)*4,Us=(r,e)=>r===3?e===3?21:36:e===3?13:21,Ns=(r,e)=>{let t=r>>>24,n=r>>>16&255,o=r>>>8&255,i=r&255;if(t!==255&&n!==255&&o!==255&&i!==255)return{header:null,bytesAdvanced:4};if(t!==255)return{header:null,bytesAdvanced:1};if((n&224)!==224)return{header:null,bytesAdvanced:1};let s=0,a=0;n&16?s=n&8?0:1:(s=1,a=1);let c=n>>3&3,l=n>>1&3,d=o>>4&15,u=(o>>2&3)%3,f=o>>1&1,m=i>>6&3,p=i>>4&3,g=i>>3&1,x=i>>2&1,y=i&3,b=Hc[s*16*4+l*16+d];if(b===-1)return{header:null,bytesAdvanced:1};let w=b*1e3,k=Lc[u]>>s+a,P=qc(s,l,w,k,f);if(e!==null&&e<P)return{header:null,bytesAdvanced:1};let S;return c===3?S=l===3?384:1152:l===3?S=384:l===2?S=1152:S=576,{header:{totalSize:P,mpegVersionId:c,layer:l,bitrate:w,frequencyIndex:u,sampleRate:k,channel:m,modeExtension:p,copyright:g,original:x,emphasis:y,audioSamplesInFrame:S},bytesAdvanced:1}};var Pn=r=>{let e=2130706432,t=0;for(;e!==0;)t>>=1,t|=r&e,e>>=8;return t};var Mt;(function(r){r[r.Unsynchronisation=128]="Unsynchronisation",r[r.ExtendedHeader=64]="ExtendedHeader",r[r.ExperimentalIndicator=32]="ExperimentalIndicator",r[r.Footer=16]="Footer"})(Mt||(Mt={}));var Bt;(function(r){r[r.ISO_8859_1=0]="ISO_8859_1",r[r.UTF_16_WITH_BOM=1]="UTF_16_WITH_BOM",r[r.UTF_16_BE_NO_BOM=2]="UTF_16_BE_NO_BOM",r[r.UTF_8=3]="UTF_8"})(Bt||(Bt={}));var xr=128,zt=10,Ot=["Blues","Classic rock","Country","Dance","Disco","Funk","Grunge","Hip-hop","Jazz","Metal","New age","Oldies","Other","Pop","Rhythm and blues","Rap","Reggae","Rock","Techno","Industrial","Alternative","Ska","Death metal","Pranks","Soundtrack","Euro-techno","Ambient","Trip-hop","Vocal","Jazz & funk","Fusion","Trance","Classical","Instrumental","Acid","House","Game","Sound clip","Gospel","Noise","Alternative rock","Bass","Soul","Punk","Space","Meditative","Instrumental pop","Instrumental rock","Ethnic","Gothic","Darkwave","Techno-industrial","Electronic","Pop-folk","Eurodance","Dream","Southern rock","Comedy","Cult","Gangsta","Top 40","Christian rap","Pop/funk","Jungle music","Native US","Cabaret","New wave","Psychedelic","Rave","Showtunes","Trailer","Lo-fi","Tribal","Acid punk","Acid jazz","Polka","Retro","Musical","Rock 'n' roll","Hard rock","Folk","Folk rock","National folk","Swing","Fast fusion","Bebop","Latin","Revival","Celtic","Bluegrass","Avantgarde","Gothic rock","Progressive rock","Psychedelic rock","Symphonic rock","Slow rock","Big band","Chorus","Easy listening","Acoustic","Humour","Speech","Chanson","Opera","Chamber music","Sonata","Symphony","Booty bass","Primus","Porn groove","Satire","Slow jam","Club","Tango","Samba","Folklore","Ballad","Power ballad","Rhythmic Soul","Freestyle","Duet","Punk rock","Drum solo","A cappella","Euro-house","Dance hall","Goa music","Drum & bass","Club-house","Hardcore techno","Terror","Indie","Britpop","Negerpunk","Polsk punk","Beat","Christian gangsta rap","Heavy metal","Black metal","Crossover","Contemporary Christian","Christian rock","Merengue","Salsa","Thrash metal","Anime","Jpop","Synthpop","Christmas","Art rock","Baroque","Bhangra","Big beat","Breakbeat","Chillout","Downtempo","Dub","EBM","Eclectic","Electro","Electroclash","Emo","Experimental","Garage","Global","IDM","Illbient","Industro-Goth","Jam Band","Krautrock","Leftfield","Lounge","Math rock","New romantic","Nu-breakz","Post-punk","Post-rock","Psytrance","Shoegaze","Space rock","Trop rock","World music","Neoclassical","Audiobook","Audio theatre","Neue Deutsche Welle","Podcast","Indie rock","G-Funk","Dubstep","Garage rock","Psybient"],Vs=(r,e)=>{let t=r.filePos;e.raw??={},e.raw.TAG??=E(r,xr-3),r.filePos=t;let n=Rt(r,30);n&&(e.title??=n);let o=Rt(r,30);o&&(e.artist??=o);let i=Rt(r,30);i&&(e.album??=i);let s=Rt(r,4),a=Number.parseInt(s,10);Number.isInteger(a)&&a>0&&(e.date??=new Date(a,0,1));let c=E(r,30),l;if(c[28]===0&&c[29]!==0){let u=c[29];u>0&&(e.trackNumber??=u),r.skip(-30),l=Rt(r,28),r.skip(2)}else r.skip(-30),l=Rt(r,30);l&&(e.comment??=l);let d=A(r);d<Ot.length&&(e.genre??=Ot[d])},Rt=(r,e)=>{let t=E(r,e),n=Je(t.indexOf(0),t.length),o=t.subarray(0,n),i="";for(let s=0;s<o.length;s++)i+=String.fromCharCode(o[s]);return i.trimEnd()},ct=r=>{let e=r.filePos,t=L(r,3),n=A(r),o=A(r),i=A(r),s=v(r);if(t!=="ID3"||n===255||o===255||(s&2155905152)!==0)return r.filePos=e,null;let a=Pn(s);return{majorVersion:n,revision:o,flags:i,size:a}},Cn=(r,e,t)=>{if(![2,3,4].includes(e.majorVersion)){console.warn(`Unsupported ID3v2 major version: ${e.majorVersion}`);return}let n=E(r,e.size),o=new di(e,n);if(e.flags&Mt.Footer&&o.removeFooter(),e.flags&Mt.Unsynchronisation&&e.majorVersion===3&&o.ununsynchronizeAll(),e.flags&Mt.ExtendedHeader){let i=o.readU32();e.majorVersion===3?o.pos+=i:o.pos+=i-4}for(;o.pos<=o.bytes.length-o.frameHeaderSize();){let i=o.readId3V2Frame();if(!i)break;let s=o.pos,a=o.pos+i.size,c=!1,l=!1,d=!1;if(e.majorVersion===3?(c=!!(i.flags&64),l=!!(i.flags&128)):e.majorVersion===4&&(c=!!(i.flags&4),l=!!(i.flags&8),d=!!(i.flags&2)||!!(e.flags&Mt.Unsynchronisation)),c){console.warn(`Skipping encrypted ID3v2 frame ${i.id}`),o.pos=a;continue}if(l){console.warn(`Skipping compressed ID3v2 frame ${i.id}`),o.pos=a;continue}switch(d&&o.ununsynchronizeRegion(o.pos,a),t.raw??={},i.id[0]==="T"?t.raw[i.id]??=o.readId3V2EncodingAndText(a):t.raw[i.id]??=o.readBytes(i.size),o.pos=s,i.id){case"TIT2":case"TT2":t.title??=o.readId3V2EncodingAndText(a);break;case"TIT3":case"TT3":t.description??=o.readId3V2EncodingAndText(a);break;case"TPE1":case"TP1":t.artist??=o.readId3V2EncodingAndText(a);break;case"TALB":case"TAL":t.album??=o.readId3V2EncodingAndText(a);break;case"TPE2":case"TP2":t.albumArtist??=o.readId3V2EncodingAndText(a);break;case"TRCK":case"TRK":{let f=o.readId3V2EncodingAndText(a).split("/"),m=Number.parseInt(f[0],10),p=f[1]&&Number.parseInt(f[1],10);Number.isInteger(m)&&m>0&&(t.trackNumber??=m),p&&Number.isInteger(p)&&p>0&&(t.tracksTotal??=p)}break;case"TPOS":case"TPA":{let f=o.readId3V2EncodingAndText(a).split("/"),m=Number.parseInt(f[0],10),p=f[1]&&Number.parseInt(f[1],10);Number.isInteger(m)&&m>0&&(t.discNumber??=m),p&&Number.isInteger(p)&&p>0&&(t.discsTotal??=p)}break;case"TCON":case"TCO":{let u=o.readId3V2EncodingAndText(a),f=/^\((\d+)\)/.exec(u);if(f){let m=Number.parseInt(f[1]);if(Ot[m]!==void 0){t.genre??=Ot[m];break}}if(f=/^\d+$/.exec(u),f){let m=Number.parseInt(f[0]);if(Ot[m]!==void 0){t.genre??=Ot[m];break}}t.genre??=u}break;case"TDRC":case"TDAT":{let u=o.readId3V2EncodingAndText(a),f=new Date(u);Number.isNaN(f.getTime())||(t.date??=f)}break;case"TYER":case"TYE":{let u=o.readId3V2EncodingAndText(a),f=Number.parseInt(u,10);Number.isInteger(f)&&(t.date??=new Date(f,0,1))}break;case"USLT":case"ULT":{let u=o.readU8();o.pos+=3,o.readId3V2Text(u,a),t.lyrics??=o.readId3V2Text(u,a)}break;case"COMM":case"COM":{let u=o.readU8();o.pos+=3,o.readId3V2Text(u,a),t.comment??=o.readId3V2Text(u,a)}break;case"APIC":case"PIC":{let u=o.readId3V2TextEncoding(),f;if(e.majorVersion===2){let x=o.readAscii(3);f=x==="PNG"?"image/png":x==="JPG"?"image/jpeg":"image/*"}else f=o.readId3V2Text(u,a);let m=o.readU8(),p=o.readId3V2Text(u,a).trimEnd(),g=a-o.pos;if(g>=0){let x=o.readBytes(g);t.images||(t.images=[]),t.images.push({data:x,mimeType:f,kind:m===3?"coverFront":m===4?"coverBack":"unknown",description:p})}}break;default:o.pos+=i.size;break}o.pos=a}},di=class{constructor(e,t){this.header=e,this.bytes=t,this.pos=0,this.view=new DataView(t.buffer,t.byteOffset,t.byteLength)}frameHeaderSize(){return this.header.majorVersion===2?6:10}ununsynchronizeAll(){let e=[];for(let t=0;t<this.bytes.length;t++){let n=this.bytes[t];e.push(n),n===255&&t!==this.bytes.length-1&&this.bytes[t]===0&&t++}this.bytes=new Uint8Array(e),this.view=new DataView(this.bytes.buffer)}ununsynchronizeRegion(e,t){let n=[];for(let s=e;s<t;s++){let a=this.bytes[s];n.push(a),a===255&&s!==t-1&&this.bytes[s+1]===0&&s++}let o=this.bytes.subarray(0,e),i=this.bytes.subarray(t);this.bytes=new Uint8Array(o.length+n.length+i.length),this.bytes.set(o,0),this.bytes.set(n,o.length),this.bytes.set(i,o.length+n.length),this.view=new DataView(this.bytes.buffer)}removeFooter(){this.bytes=this.bytes.subarray(0,this.bytes.length-zt),this.view=new DataView(this.bytes.buffer)}readBytes(e){let t=this.bytes.subarray(this.pos,this.pos+e);return this.pos+=e,t}readU8(){let e=this.view.getUint8(this.pos);return this.pos+=1,e}readU16(){let e=this.view.getUint16(this.pos,!1);return this.pos+=2,e}readU24(){let e=this.view.getUint16(this.pos,!1),t=this.view.getUint8(this.pos+1);return this.pos+=3,e*256+t}readU32(){let e=this.view.getUint32(this.pos,!1);return this.pos+=4,e}readAscii(e){let t="";for(let n=0;n<e;n++)t+=String.fromCharCode(this.view.getUint8(this.pos+n));return this.pos+=e,t}readId3V2Frame(){if(this.header.majorVersion===2){let e=this.readAscii(3);if(e==="\0\0\0")return null;let t=this.readU24();return{id:e,size:t,flags:0}}else{let e=this.readAscii(4);if(e==="\0\0\0\0")return null;let t=this.readU32(),n=this.header.majorVersion===4?Pn(t):t,o=this.readU16(),i=this.pos,s=a=>{let c=this.pos+a;if(c>this.bytes.length)return!1;if(c<=this.bytes.length-this.frameHeaderSize()){this.pos+=a;let l=this.readAscii(4);if(l!=="\0\0\0\0"&&!/[0-9A-Z]{4}/.test(l))return!1}return!0};if(!s(n)){let a=this.header.majorVersion===4?t:Pn(t);s(a)&&(n=a)}return this.pos=i,{id:e,size:n,flags:o}}}readId3V2TextEncoding(){let e=this.readU8();if(e>3)throw new Error(`Unsupported text encoding: ${e}`);return e}readId3V2Text(e,t){let n=this.pos,o=this.readBytes(t-this.pos);switch(e){case Bt.ISO_8859_1:{let i="";for(let s=0;s<o.length;s++){let a=o[s];if(a===0){this.pos=n+s+1;break}i+=String.fromCharCode(a)}return i}case Bt.UTF_16_WITH_BOM:if(o[0]===255&&o[1]===254){let i=new TextDecoder("utf-16le"),s=Je(o.findIndex((a,c)=>a===0&&o[c+1]===0&&c%2===0),o.length);return this.pos=n+Math.min(s+2,o.length),i.decode(o.subarray(2,s))}else if(o[0]===254&&o[1]===255){let i=new TextDecoder("utf-16be"),s=Je(o.findIndex((a,c)=>a===0&&o[c+1]===0&&c%2===0),o.length);return this.pos=n+Math.min(s+2,o.length),i.decode(o.subarray(2,s))}else{let i=Je(o.findIndex(s=>s===0),o.length);return this.pos=n+Math.min(i+1,o.length),$.decode(o.subarray(0,i))}case Bt.UTF_16_BE_NO_BOM:{let i=new TextDecoder("utf-16be"),s=Je(o.findIndex((a,c)=>a===0&&o[c+1]===0&&c%2===0),o.length);return this.pos=n+Math.min(s+2,o.length),i.decode(o.subarray(0,s))}case Bt.UTF_8:{let i=Je(o.findIndex(s=>s===0),o.length);return this.pos=n+Math.min(i+1,o.length),$.decode(o.subarray(0,i))}}}readId3V2EncodingAndText(e){if(this.pos>=e)return"";let t=this.readId3V2TextEncoding();return this.readId3V2Text(t,e)}};var br=async(r,e,t)=>{let n=e;for(;t===null||n<t;){let o=r.requestSlice(n,4);if(o instanceof Promise&&(o=await o),!o)break;let i=v(o),s=Ns(i,r.fileSize!==null?r.fileSize-n:null);if(s.header)return{header:s.header,startPos:n};n+=s.bytesAdvanced}return null};var In=class extends Q{constructor(e){super(e),this.metadataPromise=null,this.firstFrameHeader=null,this.loadedSamples=[],this.metadataTags=null,this.tracks=[],this.readingMutex=new ye,this.lastSampleLoaded=!1,this.lastLoadedPos=0,this.nextTimestampInSamples=0,this.reader=e._reader}async readMetadata(){return this.metadataPromise??=(async()=>{for(;!this.firstFrameHeader&&!this.lastSampleLoaded;)await this.advanceReader();if(!this.firstFrameHeader)throw new Error("No valid MP3 frame found.");this.tracks=[new G(this.input,new fi(this))]})()}async advanceReader(){if(this.lastLoadedPos===0)for(;;){let a=this.reader.requestSlice(this.lastLoadedPos,zt);if(a instanceof Promise&&(a=await a),!a){this.lastSampleLoaded=!0;return}let c=ct(a);if(!c)break;this.lastLoadedPos=a.filePos+c.size}let e=await br(this.reader,this.lastLoadedPos,this.reader.fileSize);if(!e){this.lastSampleLoaded=!0;return}let t=e.header;this.lastLoadedPos=e.startPos+t.totalSize-1;let n=Us(t.mpegVersionId,t.channel),o=this.reader.requestSlice(e.startPos+n,4);if(o instanceof Promise&&(o=await o),o){let a=v(o);if(a===Os||a===zs)return}this.firstFrameHeader||(this.firstFrameHeader=t),t.sampleRate!==this.firstFrameHeader.sampleRate&&console.warn(`MP3 changed sample rate mid-file: ${this.firstFrameHeader.sampleRate} Hz to ${t.sampleRate} Hz. Might be a bug, so please report this file.`);let i=t.audioSamplesInFrame/this.firstFrameHeader.sampleRate,s={timestamp:this.nextTimestampInSamples/this.firstFrameHeader.sampleRate,duration:i,dataStart:e.startPos,dataSize:t.totalSize};this.loadedSamples.push(s),this.nextTimestampInSamples+=t.audioSamplesInFrame}async getMimeType(){return"audio/mpeg"}async getTracks(){return await this.readMetadata(),this.tracks}async computeDuration(){await this.readMetadata();let e=this.tracks[0];return h(e),e.computeDuration()}async getMetadataTags(){let e=await this.readingMutex.acquire();try{if(await this.readMetadata(),this.metadataTags)return this.metadataTags;this.metadataTags={};let t=0,n=!1;for(;;){let o=this.reader.requestSlice(t,zt);if(o instanceof Promise&&(o=await o),!o)break;let i=ct(o);if(!i)break;n=!0;let s=this.reader.requestSlice(o.filePos,i.size);if(s instanceof Promise&&(s=await s),!s)break;Cn(s,i,this.metadataTags),t=o.filePos+i.size}if(!n&&this.reader.fileSize!==null&&this.reader.fileSize>=xr){let o=this.reader.requestSlice(this.reader.fileSize-xr,xr);o instanceof Promise&&(o=await o),h(o),L(o,3)==="TAG"&&Vs(o,this.metadataTags)}return this.metadataTags}finally{e()}}},fi=class{constructor(e){this.demuxer=e}getId(){return 1}async getFirstTimestamp(){return 0}getTimeResolution(){return h(this.demuxer.firstFrameHeader),this.demuxer.firstFrameHeader.sampleRate/this.demuxer.firstFrameHeader.audioSamplesInFrame}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}getName(){return null}getLanguageCode(){return K}getCodec(){return"mp3"}getInternalCodecId(){return null}getNumberOfChannels(){return h(this.demuxer.firstFrameHeader),this.demuxer.firstFrameHeader.channel===3?1:2}getSampleRate(){return h(this.demuxer.firstFrameHeader),this.demuxer.firstFrameHeader.sampleRate}getDisposition(){return{...te}}async getDecoderConfig(){return h(this.demuxer.firstFrameHeader),{codec:"mp3",numberOfChannels:this.demuxer.firstFrameHeader.channel===3?1:2,sampleRate:this.demuxer.firstFrameHeader.sampleRate}}async getPacketAtIndex(e,t){if(e===-1)return null;let n=this.demuxer.loadedSamples[e];if(!n)return null;let o;if(t.metadataOnly)o=H;else{let i=this.demuxer.reader.requestSlice(n.dataStart,n.dataSize);if(i instanceof Promise&&(i=await i),!i)return null;o=E(i,n.dataSize)}return new V(o,"key",n.timestamp,n.duration,e,n.dataSize)}getFirstPacket(e){return this.getPacketAtIndex(0,e)}async getNextPacket(e,t){let n=await this.demuxer.readingMutex.acquire();try{let o=Xe(this.demuxer.loadedSamples,e.timestamp,s=>s.timestamp);if(o===-1)throw new Error("Packet was not created from this track.");let i=o+1;for(;i>=this.demuxer.loadedSamples.length&&!this.demuxer.lastSampleLoaded;)await this.demuxer.advanceReader();return this.getPacketAtIndex(i,t)}finally{n()}}async getPacket(e,t){let n=await this.demuxer.readingMutex.acquire();try{for(;;){let o=B(this.demuxer.loadedSamples,e,i=>i.timestamp);if(o===-1&&this.demuxer.loadedSamples.length>0)return null;if(this.demuxer.lastSampleLoaded)return this.getPacketAtIndex(o,t);if(o>=0&&o+1<this.demuxer.loadedSamples.length)return this.getPacketAtIndex(o,t);await this.demuxer.advanceReader()}}finally{n()}}getKeyPacket(e,t){return this.getPacket(e,t)}getNextKeyPacket(e,t){return this.getNextPacket(e,t)}};var mi=1399285583,Gc=79764919,Hs=new Uint32Array(256);for(let r=0;r<256;r++){let e=r<<24;for(let t=0;t<8;t++)e=e&2147483648?e<<1^Gc:e<<1;Hs[r]=e>>>0&4294967295}var qs=r=>{let e=z(r),t=e.getUint32(22,!0);e.setUint32(22,0,!0);let n=0;for(let o=0;o<r.length;o++){let i=r[o];n=(n<<8^Hs[n>>>24^i])>>>0}return e.setUint32(22,t,!0),n},Gs=(r,e,t)=>{let n=0,o=null;if(r.length>0)if(e.codec==="vorbis"){h(e.vorbisInfo);let i=e.vorbisInfo.modeBlockflags.length,a=(1<<ns(i-1))-1<<1,c=(r[0]&a)>>1;if(c>=e.vorbisInfo.modeBlockflags.length)throw new Error("Invalid mode number.");let l=t,d=e.vorbisInfo.modeBlockflags[c];if(o=e.vorbisInfo.blocksizes[d],d===1){let u=(a|1)+1,f=r[0]&u?1:0;l=e.vorbisInfo.blocksizes[f]}n=l!==null?l+o>>2:0}else e.codec==="opus"&&(n=xs(r).durationInSamples);return{durationInSamples:n,vorbisBlockSize:o}},Ws=r=>{let e="audio/ogg";if(r.codecStrings){let t=[...new Set(r.codecStrings)];e+=`; codecs="${t.join(", ")}"`}return e};var qe=27,ut=282,js=ut+65025,Ut=r=>{let e=r.filePos;if(lt(r)!==mi)return null;r.skip(1);let n=A(r),o=Ks(r),i=lt(r),s=lt(r),a=lt(r),c=A(r),l=new Uint8Array(c);for(let m=0;m<c;m++)l[m]=A(r);let d=27+c,u=l.reduce((m,p)=>m+p,0),f=d+u;return{headerStartPos:e,totalSize:f,dataStartPos:e+d,dataSize:u,headerType:n,granulePosition:o,serialNumber:i,sequenceNumber:s,checksum:a,lacingValues:l}},$s=(r,e)=>{for(;r.filePos<e-3;){let t=lt(r),n=t&255,o=t>>>8&255,i=t>>>16&255,s=t>>>24&255,a=79;if(!(n!==a&&o!==a&&i!==a&&s!==a)){if(r.skip(-4),t===mi)return!0;r.skip(1)}}return!1};var An=class extends Q{constructor(e){super(e),this.metadataPromise=null,this.bitstreams=[],this.tracks=[],this.metadataTags={},this.reader=e._reader}async readMetadata(){return this.metadataPromise??=(async()=>{let e=0;for(;;){let t=this.reader.requestSliceRange(e,qe,ut);if(t instanceof Promise&&(t=await t),!t)break;let n=Ut(t);if(!n||!!!(n.headerType&2))break;this.bitstreams.push({serialNumber:n.serialNumber,bosPage:n,description:null,numberOfChannels:-1,sampleRate:-1,codecInfo:{codec:null,vorbisInfo:null,opusInfo:null},lastMetadataPacket:null}),e=n.headerStartPos+n.totalSize}for(let t of this.bitstreams){let n=await this.readPacket(t.bosPage,0);n&&(n.data.byteLength>=7&&n.data[0]===1&&n.data[1]===118&&n.data[2]===111&&n.data[3]===114&&n.data[4]===98&&n.data[5]===105&&n.data[6]===115?await this.readVorbisMetadata(n,t):n.data.byteLength>=8&&n.data[0]===79&&n.data[1]===112&&n.data[2]===117&&n.data[3]===115&&n.data[4]===72&&n.data[5]===101&&n.data[6]===97&&n.data[7]===100&&await this.readOpusMetadata(n,t),t.codecInfo.codec!==null&&this.tracks.push(new G(this.input,new pi(t,this))))}})()}async readVorbisMetadata(e,t){let n=await this.findNextPacketStart(e);if(!n)return;let o=await this.readPacket(n.startPage,n.startSegmentIndex);if(!o||(n=await this.findNextPacketStart(o),!n))return;let i=await this.readPacket(n.startPage,n.startSegmentIndex);if(!i||o.data[0]!==3||i.data[0]!==5)return;let s=[],a=u=>{for(;s.push(Math.min(255,u)),!(u<255);)u-=255};a(e.data.length),a(o.data.length);let c=new Uint8Array(1+s.length+e.data.length+o.data.length+i.data.length);c[0]=2,c.set(s,1),c.set(e.data,1+s.length),c.set(o.data,1+s.length+e.data.length),c.set(i.data,1+s.length+e.data.length+o.data.length),t.codecInfo.codec="vorbis",t.description=c,t.lastMetadataPacket=i;let l=z(e.data);t.numberOfChannels=l.getUint8(11),t.sampleRate=l.getUint32(12,!0);let d=l.getUint8(28);t.codecInfo.vorbisInfo={blocksizes:[1<<(d&15),1<<(d>>4)],modeBlockflags:bs(i.data).modeBlockflags},sr(o.data.subarray(7),this.metadataTags)}async readOpusMetadata(e,t){let n=await this.findNextPacketStart(e);if(!n)return;let o=await this.readPacket(n.startPage,n.startSegmentIndex);if(!o)return;t.codecInfo.codec="opus",t.description=e.data,t.lastMetadataPacket=o;let i=gs(e.data);t.numberOfChannels=i.outputChannelCount,t.sampleRate=tt,t.codecInfo.opusInfo={preSkip:i.preSkip},sr(o.data.subarray(8),this.metadataTags)}async readPacket(e,t){h(t<e.lacingValues.length);let n=0;for(let u=0;u<t;u++)n+=e.lacingValues[u];let o=e,i=n,s=t,a=[];e:for(;;){let u=this.reader.requestSlice(o.dataStartPos,o.dataSize);u instanceof Promise&&(u=await u),h(u);let f=E(u,o.dataSize);for(;;){if(s===o.lacingValues.length){a.push(f.subarray(n,i));break}let p=o.lacingValues[s];if(i+=p,p<255){a.push(f.subarray(n,i));break e}s++}let m=o.headerStartPos+o.totalSize;for(;;){let p=this.reader.requestSliceRange(m,qe,ut);if(p instanceof Promise&&(p=await p),!p)return null;let g=Ut(p);if(!g)return null;if(o=g,o.serialNumber===e.serialNumber)break;m=o.headerStartPos+o.totalSize}n=0,i=0,s=0}let c=a.reduce((u,f)=>u+f.length,0),l=new Uint8Array(c),d=0;for(let u=0;u<a.length;u++){let f=a[u];l.set(f,d),d+=f.length}return{data:l,endPage:o,endSegmentIndex:s}}async findNextPacketStart(e){if(e.endSegmentIndex<e.endPage.lacingValues.length-1)return{startPage:e.endPage,startSegmentIndex:e.endSegmentIndex+1};if(!!(e.endPage.headerType&4))return null;let n=e.endPage.headerStartPos+e.endPage.totalSize;for(;;){let o=this.reader.requestSliceRange(n,qe,ut);if(o instanceof Promise&&(o=await o),!o)return null;let i=Ut(o);if(!i)return null;if(i.serialNumber===e.endPage.serialNumber)return{startPage:i,startSegmentIndex:0};n=i.headerStartPos+i.totalSize}}async getMimeType(){await this.readMetadata();let e=await Promise.all(this.tracks.map(t=>t.getCodecParameterString()));return Ws({codecStrings:e.filter(Boolean)})}async getTracks(){return await this.readMetadata(),this.tracks}async computeDuration(){let e=await this.getTracks(),t=await Promise.all(e.map(n=>n.computeDuration()));return Math.max(0,...t)}async getMetadataTags(){return await this.readMetadata(),this.metadataTags}},pi=class{constructor(e,t){this.bitstream=e,this.demuxer=t,this.encodedPacketToMetadata=new WeakMap,this.sequentialScanCache=[],this.sequentialScanMutex=new ye,this.internalSampleRate=e.codecInfo.codec==="opus"?tt:e.sampleRate}getId(){return this.bitstream.serialNumber}getNumberOfChannels(){return this.bitstream.numberOfChannels}getSampleRate(){return this.bitstream.sampleRate}getTimeResolution(){return this.bitstream.sampleRate}getCodec(){return this.bitstream.codecInfo.codec}getInternalCodecId(){return null}async getDecoderConfig(){return h(this.bitstream.codecInfo.codec),{codec:this.bitstream.codecInfo.codec,numberOfChannels:this.bitstream.numberOfChannels,sampleRate:this.bitstream.sampleRate,description:this.bitstream.description??void 0}}getName(){return null}getLanguageCode(){return K}getDisposition(){return{...te}}async getFirstTimestamp(){return 0}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}granulePositionToTimestampInSamples(e){return this.bitstream.codecInfo.codec==="opus"?(h(this.bitstream.codecInfo.opusInfo),e-this.bitstream.codecInfo.opusInfo.preSkip):e}createEncodedPacketFromOggPacket(e,t,n){if(!e)return null;let{durationInSamples:o,vorbisBlockSize:i}=Gs(e.data,this.bitstream.codecInfo,t.vorbisLastBlocksize),s=new V(n.metadataOnly?H:e.data,"key",Math.max(0,t.timestampInSamples)/this.internalSampleRate,o/this.internalSampleRate,e.endPage.headerStartPos+e.endSegmentIndex,e.data.byteLength);return this.encodedPacketToMetadata.set(s,{packet:e,timestampInSamples:t.timestampInSamples,durationInSamples:o,vorbisLastBlockSize:t.vorbisLastBlocksize,vorbisBlockSize:i}),s}async getFirstPacket(e){h(this.bitstream.lastMetadataPacket);let t=await this.demuxer.findNextPacketStart(this.bitstream.lastMetadataPacket);if(!t)return null;let n=0;this.bitstream.codecInfo.codec==="opus"&&(h(this.bitstream.codecInfo.opusInfo),n-=this.bitstream.codecInfo.opusInfo.preSkip);let o=await this.demuxer.readPacket(t.startPage,t.startSegmentIndex);return this.createEncodedPacketFromOggPacket(o,{timestampInSamples:n,vorbisLastBlocksize:null},e)}async getNextPacket(e,t){let n=this.encodedPacketToMetadata.get(e);if(!n)throw new Error("Packet was not created from this track.");let o=await this.demuxer.findNextPacketStart(n.packet);if(!o)return null;let i=n.timestampInSamples+n.durationInSamples,s=await this.demuxer.readPacket(o.startPage,o.startSegmentIndex);return this.createEncodedPacketFromOggPacket(s,{timestampInSamples:i,vorbisLastBlocksize:n.vorbisBlockSize},t)}async getPacket(e,t){if(this.demuxer.reader.fileSize===null)return this.getPacketSequential(e,t);let n=Ze(e*this.internalSampleRate);if(n===0)return this.getFirstPacket(t);if(n<0)return null;h(this.bitstream.lastMetadataPacket);let o=await this.demuxer.findNextPacketStart(this.bitstream.lastMetadataPacket);if(!o)return null;let i=o.startPage,s=this.demuxer.reader.fileSize,a=[i];e:for(;i.headerStartPos+i.totalSize<s;){let b=i.headerStartPos,w=Math.floor((b+s)/2),k=w;for(;;){let P=Math.min(k+js,s-qe),S=this.demuxer.reader.requestSlice(k,P-k);if(S instanceof Promise&&(S=await S),h(S),!$s(S,P)){s=w+qe;continue e}let C=this.demuxer.reader.requestSliceRange(S.filePos,qe,ut);C instanceof Promise&&(C=await C),h(C);let F=Ut(C);h(F);let O=!1;if(F.serialNumber===this.bitstream.serialNumber)O=!0;else{let j=this.demuxer.reader.requestSlice(F.headerStartPos,F.totalSize);j instanceof Promise&&(j=await j),h(j);let Ge=E(j,F.totalSize);O=qs(Ge)===F.checksum}if(!O){k=F.headerStartPos+4;continue}if(O&&F.serialNumber!==this.bitstream.serialNumber){k=F.headerStartPos+F.totalSize;continue}if(F.granulePosition===-1){k=F.headerStartPos+F.totalSize;continue}this.granulePositionToTimestampInSamples(F.granulePosition)>n?s=F.headerStartPos:(i=F,a.push(F));continue e}}let c=o.startPage;for(let b of a){if(b.granulePosition===i.granulePosition)break;(!c||b.headerStartPos>c.headerStartPos)&&(c=b)}let l=c,d=[l];for(;!(l.serialNumber===this.bitstream.serialNumber&&l.granulePosition===i.granulePosition);){let b=l.headerStartPos+l.totalSize,w=this.demuxer.reader.requestSliceRange(b,qe,ut);w instanceof Promise&&(w=await w),h(w);let k=Ut(w);h(k),l=k,l.serialNumber===this.bitstream.serialNumber&&d.push(l)}h(l.granulePosition!==-1);let u=null,f,m,p=l,g=0;if(l.headerStartPos===o.startPage.headerStartPos)f=this.granulePositionToTimestampInSamples(0),m=!0,u=0;else{f=0,m=!1;for(let k=l.lacingValues.length-1;k>=0;k--)if(l.lacingValues[k]<255){u=k+1;break}if(u===null)throw new Error("Invalid page with granule position: no packets end on this page.");g=u-1;let b={data:H,endPage:p,endSegmentIndex:g};if(await this.demuxer.findNextPacketStart(b)){let k=Qs(d,l,u);h(k);let P=Xs(d,k.page,k.segmentIndex);P&&(l=P.page,u=P.segmentIndex)}else for(;;){let k=Qs(d,l,u);if(!k)break;let P=Xs(d,k.page,k.segmentIndex);if(!P)break;if(l=P.page,u=P.segmentIndex,k.page.headerStartPos!==p.headerStartPos){p=k.page,g=k.segmentIndex;break}}}let x=null,y=null;for(;l!==null;){h(u!==null);let b=await this.demuxer.readPacket(l,u);if(!b)break;if(!(l.headerStartPos===o.startPage.headerStartPos&&u<o.startSegmentIndex)){let P=this.createEncodedPacketFromOggPacket(b,{timestampInSamples:f,vorbisLastBlocksize:y?.vorbisBlockSize??null},t);h(P);let S=this.encodedPacketToMetadata.get(P);if(h(S),!m&&b.endPage.headerStartPos===p.headerStartPos&&b.endSegmentIndex===g?(f=this.granulePositionToTimestampInSamples(l.granulePosition),m=!0,P=this.createEncodedPacketFromOggPacket(b,{timestampInSamples:f-S.durationInSamples,vorbisLastBlocksize:y?.vorbisBlockSize??null},t),h(P),S=this.encodedPacketToMetadata.get(P),h(S)):f+=S.durationInSamples,x=P,y=S,m&&(Math.max(f,0)>n||Math.max(S.timestampInSamples,0)===n))break}let k=await this.demuxer.findNextPacketStart(b);if(!k)break;l=k.startPage,u=k.startSegmentIndex}return x}async getPacketSequential(e,t){let n=await this.sequentialScanMutex.acquire();try{let o=Ze(e*this.internalSampleRate);e=o/this.internalSampleRate;let i=B(this.sequentialScanCache,o,c=>c.timestampInSamples),s;if(i!==-1){let c=this.sequentialScanCache[i];s=this.createEncodedPacketFromOggPacket(c.packet,{timestampInSamples:c.timestampInSamples,vorbisLastBlocksize:c.vorbisLastBlockSize},t)}else s=await this.getFirstPacket(t);let a=0;for(;s&&s.timestamp<e;){let c=await this.getNextPacket(s,t);if(!c||c.timestamp>e)break;if(s=c,a++,a===100){a=0;let l=this.encodedPacketToMetadata.get(s);h(l),this.sequentialScanCache.length>0&&h(Y(this.sequentialScanCache).timestampInSamples<=l.timestampInSamples),this.sequentialScanCache.push(l)}}return s}finally{n()}}getKeyPacket(e,t){return this.getPacket(e,t)}getNextKeyPacket(e,t){return this.getNextPacket(e,t)}},Xs=(r,e,t)=>{let n=e,o=t;e:for(;;){for(o--,o;o>=0;o--)if(n.lacingValues[o]<255){o++;break e}if(h(o===-1),!(n.headerType&1)){o=0;break}let s=Oo(r,a=>a.headerStartPos<n.headerStartPos);if(!s)return null;n=s,o=n.lacingValues.length}if(h(o!==-1),o===n.lacingValues.length){let i=r[r.indexOf(n)+1];h(i),n=i,o=0}return{page:n,segmentIndex:o}},Qs=(r,e,t)=>{if(t>0)return{page:e,segmentIndex:t-1};let n=Oo(r,o=>o.headerStartPos<e.headerStartPos);return n?{page:n,segmentIndex:n.lacingValues.length-1}:null};var De;(function(r){r[r.PCM=1]="PCM",r[r.IEEE_FLOAT=3]="IEEE_FLOAT",r[r.ALAW=6]="ALAW",r[r.MULAW=7]="MULAW",r[r.EXTENSIBLE=65534]="EXTENSIBLE"})(De||(De={}));var _n=class extends Q{constructor(e){super(e),this.metadataPromise=null,this.dataStart=-1,this.dataSize=-1,this.audioInfo=null,this.tracks=[],this.lastKnownPacketIndex=0,this.metadataTags={},this.reader=e._reader}async readMetadata(){return this.metadataPromise??=(async()=>{let e=this.reader.requestSlice(0,12);e instanceof Promise&&(e=await e),h(e);let t=L(e,4),n=t!=="RIFX",o=t==="RF64",i=Re(e,n),s=o?this.reader.fileSize:Math.min(i+8,this.reader.fileSize??1/0);if(L(e,4)!=="WAVE")throw new Error("Invalid WAVE file - wrong format");let c=0,l=null,d=e.filePos;for(;s===null||d<s;){let f=this.reader.requestSlice(d,8);if(f instanceof Promise&&(f=await f),!f)break;let m=L(f,4),p=Re(f,n),g=f.filePos;if(o&&c===0&&m!=="ds64")throw new Error('Invalid RF64 file: First chunk must be "ds64".');if(m==="fmt ")await this.parseFmtChunk(g,p,n);else if(m==="data"){if(l??=p,this.dataStart=f.filePos,this.dataSize=Math.min(l,(s??1/0)-this.dataStart),this.reader.fileSize===null)break}else if(m==="ds64"){let x=this.reader.requestSlice(g,p);if(x instanceof Promise&&(x=await x),!x)break;let y=gi(x,n);l=gi(x,n),s=Math.min(y+8,this.reader.fileSize??1/0)}else m==="LIST"?await this.parseListChunk(g,p,n):(m==="ID3 "||m==="id3 ")&&await this.parseId3Chunk(g,p);d=g+p+(p&1),c++}if(!this.audioInfo)throw new Error('Invalid WAVE file - missing "fmt " chunk');if(this.dataStart===-1)throw new Error('Invalid WAVE file - missing "data" chunk');let u=this.audioInfo.blockSizeInBytes;this.dataSize=Math.floor(this.dataSize/u)*u,this.tracks.push(new G(this.input,new hi(this)))})()}async parseFmtChunk(e,t,n){let o=this.reader.requestSlice(e,t);if(o instanceof Promise&&(o=await o),!o)return;let i=Vt(o,n),s=Vt(o,n),a=Re(o,n);o.skip(4);let c=Vt(o,n),l;if(t===14?l=8:l=Vt(o,n),t>=18&&i!==357){let d=Vt(o,n),u=t-18;if(Math.min(u,d)>=22&&i===De.EXTENSIBLE){o.skip(6);let m=E(o,16);i=m[0]|m[1]<<8}}(i===De.MULAW||i===De.ALAW)&&(l=8),this.audioInfo={format:i,numberOfChannels:s,sampleRate:a,sampleSizeInBytes:Math.ceil(l/8),blockSizeInBytes:c}}async parseListChunk(e,t,n){let o=this.reader.requestSlice(e,t);if(o instanceof Promise&&(o=await o),!o)return;let i=L(o,4);if(i!=="INFO"&&i!=="INF0")return;let s=o.filePos;for(;s<=e+t-8;){o.filePos=s;let a=L(o,4),c=Re(o,n),l=E(o,c),d=0;for(let f=0;f<l.length&&l[f]!==0;f++)d++;let u=String.fromCharCode(...l.subarray(0,d));switch(this.metadataTags.raw??={},this.metadataTags.raw[a]=u,a){case"INAM":case"TITL":this.metadataTags.title??=u;break;case"TIT3":this.metadataTags.description??=u;break;case"IART":this.metadataTags.artist??=u;break;case"IPRD":this.metadataTags.album??=u;break;case"IPRT":case"ITRK":case"TRCK":{let f=u.split("/"),m=Number.parseInt(f[0],10),p=f[1]&&Number.parseInt(f[1],10);Number.isInteger(m)&&m>0&&(this.metadataTags.trackNumber??=m),p&&Number.isInteger(p)&&p>0&&(this.metadataTags.tracksTotal??=p)}break;case"ICRD":case"IDIT":{let f=new Date(u);Number.isNaN(f.getTime())||(this.metadataTags.date??=f)}break;case"YEAR":{let f=Number.parseInt(u,10);Number.isInteger(f)&&f>0&&(this.metadataTags.date??=new Date(f,0,1))}break;case"IGNR":case"GENR":this.metadataTags.genre??=u;break;case"ICMT":case"CMNT":case"COMM":this.metadataTags.comment??=u;break}s+=8+c+(c&1)}}async parseId3Chunk(e,t){let n=this.reader.requestSlice(e,t);if(n instanceof Promise&&(n=await n),!n)return;let o=ct(n);if(o){let i=n.slice(e+10,o.size);Cn(i,o,this.metadataTags)}}getCodec(){if(h(this.audioInfo),this.audioInfo.format===De.MULAW)return"ulaw";if(this.audioInfo.format===De.ALAW)return"alaw";if(this.audioInfo.format===De.PCM){if(this.audioInfo.sampleSizeInBytes===1)return"pcm-u8";if(this.audioInfo.sampleSizeInBytes===2)return"pcm-s16";if(this.audioInfo.sampleSizeInBytes===3)return"pcm-s24";if(this.audioInfo.sampleSizeInBytes===4)return"pcm-s32"}return this.audioInfo.format===De.IEEE_FLOAT&&this.audioInfo.sampleSizeInBytes===4?"pcm-f32":null}async getMimeType(){return"audio/wav"}async computeDuration(){await this.readMetadata();let e=this.tracks[0];return h(e),e.computeDuration()}async getTracks(){return await this.readMetadata(),this.tracks}async getMetadataTags(){return await this.readMetadata(),this.metadataTags}},Nt=2048,hi=class{constructor(e){this.demuxer=e}getId(){return 1}getCodec(){return this.demuxer.getCodec()}getInternalCodecId(){return h(this.demuxer.audioInfo),this.demuxer.audioInfo.format}async getDecoderConfig(){let e=this.demuxer.getCodec();return e?(h(this.demuxer.audioInfo),{codec:e,numberOfChannels:this.demuxer.audioInfo.numberOfChannels,sampleRate:this.demuxer.audioInfo.sampleRate}):null}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}getNumberOfChannels(){return h(this.demuxer.audioInfo),this.demuxer.audioInfo.numberOfChannels}getSampleRate(){return h(this.demuxer.audioInfo),this.demuxer.audioInfo.sampleRate}getTimeResolution(){return h(this.demuxer.audioInfo),this.demuxer.audioInfo.sampleRate}getName(){return null}getLanguageCode(){return K}getDisposition(){return{...te}}async getFirstTimestamp(){return 0}async getPacketAtIndex(e,t){h(this.demuxer.audioInfo);let n=e*Nt*this.demuxer.audioInfo.blockSizeInBytes;if(n>=this.demuxer.dataSize)return null;let o=Math.min(Nt*this.demuxer.audioInfo.blockSizeInBytes,this.demuxer.dataSize-n);if(this.demuxer.reader.fileSize===null){let c=this.demuxer.reader.requestSlice(this.demuxer.dataStart+n,o);if(c instanceof Promise&&(c=await c),!c)return null}let i;if(t.metadataOnly)i=H;else{let c=this.demuxer.reader.requestSlice(this.demuxer.dataStart+n,o);c instanceof Promise&&(c=await c),h(c),i=E(c,o)}let s=e*Nt/this.demuxer.audioInfo.sampleRate,a=o/this.demuxer.audioInfo.blockSizeInBytes/this.demuxer.audioInfo.sampleRate;return this.demuxer.lastKnownPacketIndex=Math.max(e,s),new V(i,"key",s,a,e,o)}getFirstPacket(e){return this.getPacketAtIndex(0,e)}async getPacket(e,t){h(this.demuxer.audioInfo);let n=Math.floor(Math.min(e*this.demuxer.audioInfo.sampleRate/Nt,(this.demuxer.dataSize-1)/(Nt*this.demuxer.audioInfo.blockSizeInBytes))),o=await this.getPacketAtIndex(n,t);if(o)return o;if(n===0)return null;h(this.demuxer.reader.fileSize===null);let i=await this.getPacketAtIndex(this.demuxer.lastKnownPacketIndex,t);for(;i;){let s=await this.getNextPacket(i,t);if(!s)break;i=s}return i}getNextPacket(e,t){h(this.demuxer.audioInfo);let n=Math.round(e.timestamp*this.demuxer.audioInfo.sampleRate/Nt);return this.getPacketAtIndex(n+1,t)}getKeyPacket(e,t){return this.getPacket(e,t)}getNextKeyPacket(e,t){return this.getNextPacket(e,t)}};var Lt=7,Ht=9,yr=r=>{let e=r.filePos,t=E(r,9),n=new N(t);if(n.readBits(12)!==4095||(n.skipBits(1),n.readBits(2)!==0))return null;let s=n.readBits(1),a=n.readBits(2)+1,c=n.readBits(4);if(c===15)return null;n.skipBits(1);let l=n.readBits(3);if(l===0)throw new Error("ADTS frames with channel configuration 0 are not supported.");n.skipBits(1),n.skipBits(1),n.skipBits(1),n.skipBits(1);let d=n.readBits(13);n.skipBits(11);let u=n.readBits(2)+1;if(u!==1)throw new Error("ADTS frames with more than one AAC frame are not supported.");let f=null;return s===1?r.filePos-=2:f=n.readBits(16),{objectType:a,samplingFrequencyIndex:c,channelConfiguration:l,frameLength:d,numberOfAacFrames:u,crcCheck:f,startPos:e}};var xi=1024,En=class extends Q{constructor(e){super(e),this.metadataPromise=null,this.firstFrameHeader=null,this.loadedSamples=[],this.tracks=[],this.readingMutex=new ye,this.lastSampleLoaded=!1,this.lastLoadedPos=0,this.nextTimestampInSamples=0,this.reader=e._reader}async readMetadata(){return this.metadataPromise??=(async()=>{for(;!this.firstFrameHeader&&!this.lastSampleLoaded;)await this.advanceReader();h(this.firstFrameHeader),this.tracks=[new G(this.input,new bi(this))]})()}async advanceReader(){let e=this.reader.requestSliceRange(this.lastLoadedPos,Lt,Ht);if(e instanceof Promise&&(e=await e),!e){this.lastSampleLoaded=!0;return}let t=yr(e);if(!t){this.lastSampleLoaded=!0;return}if(this.reader.fileSize!==null&&t.startPos+t.frameLength>this.reader.fileSize){this.lastSampleLoaded=!0;return}this.firstFrameHeader||(this.firstFrameHeader=t);let n=ir[t.samplingFrequencyIndex];h(n!==void 0);let o=xi/n,i=t.crcCheck?Ht:Lt,s={timestamp:this.nextTimestampInSamples/n,duration:o,dataStart:t.startPos+i,dataSize:t.frameLength-i};this.loadedSamples.push(s),this.nextTimestampInSamples+=xi,this.lastLoadedPos=t.startPos+t.frameLength}async getMimeType(){return"audio/aac"}async getTracks(){return await this.readMetadata(),this.tracks}async computeDuration(){await this.readMetadata();let e=this.tracks[0];return h(e),e.computeDuration()}async getMetadataTags(){return{}}},bi=class{constructor(e){this.demuxer=e}getId(){return 1}async getFirstTimestamp(){return 0}getTimeResolution(){return this.getSampleRate()/xi}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}getName(){return null}getLanguageCode(){return K}getCodec(){return"aac"}getInternalCodecId(){return h(this.demuxer.firstFrameHeader),this.demuxer.firstFrameHeader.objectType}getNumberOfChannels(){h(this.demuxer.firstFrameHeader);let e=Vo[this.demuxer.firstFrameHeader.channelConfiguration];return h(e!==void 0),e}getSampleRate(){h(this.demuxer.firstFrameHeader);let e=ir[this.demuxer.firstFrameHeader.samplingFrequencyIndex];return h(e!==void 0),e}getDisposition(){return{...te}}async getDecoderConfig(){h(this.demuxer.firstFrameHeader);let e=new Uint8Array(3),t=new N(e),{objectType:n,samplingFrequencyIndex:o,channelConfiguration:i}=this.demuxer.firstFrameHeader;return n>31?(t.writeBits(5,31),t.writeBits(6,n-32)):t.writeBits(5,n),t.writeBits(4,o),t.writeBits(4,i),{codec:`mp4a.40.${this.demuxer.firstFrameHeader.objectType}`,numberOfChannels:this.getNumberOfChannels(),sampleRate:this.getSampleRate(),description:e.subarray(0,Math.ceil((t.pos-1)/8))}}async getPacketAtIndex(e,t){if(e===-1)return null;let n=this.demuxer.loadedSamples[e];if(!n)return null;let o;if(t.metadataOnly)o=H;else{let i=this.demuxer.reader.requestSlice(n.dataStart,n.dataSize);if(i instanceof Promise&&(i=await i),!i)return null;o=E(i,n.dataSize)}return new V(o,"key",n.timestamp,n.duration,e,n.dataSize)}getFirstPacket(e){return this.getPacketAtIndex(0,e)}async getNextPacket(e,t){let n=await this.demuxer.readingMutex.acquire();try{let o=Xe(this.demuxer.loadedSamples,e.timestamp,s=>s.timestamp);if(o===-1)throw new Error("Packet was not created from this track.");let i=o+1;for(;i>=this.demuxer.loadedSamples.length&&!this.demuxer.lastSampleLoaded;)await this.demuxer.advanceReader();return this.getPacketAtIndex(i,t)}finally{n()}}async getPacket(e,t){let n=await this.demuxer.readingMutex.acquire();try{for(;;){let o=B(this.demuxer.loadedSamples,e,i=>i.timestamp);if(o===-1&&this.demuxer.loadedSamples.length>0)return null;if(this.demuxer.lastSampleLoaded)return this.getPacketAtIndex(o,t);if(o>=0&&o+1<this.demuxer.loadedSamples.length)return this.getPacketAtIndex(o,t);await this.demuxer.advanceReader()}}finally{n()}}getKeyPacket(e,t){return this.getPacket(e,t)}getNextKeyPacket(e,t){return this.getNextPacket(e,t)}};var Ys=r=>r===0?null:r===1?192:r>=2&&r<=5?144*2**r:r===6?"uncommon-u8":r===7?"uncommon-u16":r>=8&&r<=15?2**r:null,Zs=(r,e)=>{switch(r){case 0:return e;case 1:return 88200;case 2:return 176400;case 3:return 192e3;case 4:return 8e3;case 5:return 16e3;case 6:return 22050;case 7:return 24e3;case 8:return 32e3;case 9:return 44100;case 10:return 48e3;case 11:return 96e3;case 12:return"uncommon-u8";case 13:return"uncommon-u16";case 14:return"uncommon-u16-10";default:return null}},Js=r=>{let e=0,t=new N(E(r,1));for(;t.readBits(1)===1;)e++;if(e===0)return t.readBits(7);let n=[],o=e-1,i=new N(E(r,o)),s=8-e-1;for(let c=0;c<s;c++)n.unshift(t.readBits(1));for(let c=0;c<o;c++)for(let l=0;l<8;l++){let d=i.readBits(1);l<2||n.unshift(d)}return n.reduce((c,l,d)=>c|l<<d,0)},ea=(r,e)=>{if(e==="uncommon-u16")return W(r)+1;if(e==="uncommon-u8")return A(r)+1;if(typeof e=="number")return e;se(e),h(!1)},ta=(r,e)=>e==="uncommon-u16"?W(r):e==="uncommon-u16-10"?W(r)*10:e==="uncommon-u8"?A(r):typeof e=="number"?e:null,ra=r=>{let t=0;for(let n of r){t^=n;for(let o=0;o<8;o++)(t&128)!==0?t=t<<1^7:t<<=1,t&=255}return t};var Fn=class extends Q{constructor(e){super(e),this.loadedSamples=[],this.metadataPromise=null,this.track=null,this.metadataTags={},this.audioInfo=null,this.lastLoadedPos=null,this.blockingBit=null,this.readingMutex=new ye,this.lastSampleLoaded=!1,this.reader=e._reader}async computeDuration(){return await this.readMetadata(),h(this.track),this.track.computeDuration()}async getMetadataTags(){return await this.readMetadata(),this.metadataTags}async getTracks(){return await this.readMetadata(),h(this.track),[this.track]}async getMimeType(){return"audio/flac"}async readMetadata(){let e=4;return this.metadataPromise??=(async()=>{for(;this.reader.fileSize===null||e<this.reader.fileSize;){let t=this.reader.requestSlice(e,4);if(t instanceof Promise&&(t=await t),e+=4,t===null)throw new Error(`Metadata block at position ${e} is too small! Corrupted file.`);h(t);let n=A(t),o=Le(t),i=(n&128)!==0;switch(n&127){case Ue.STREAMINFO:{let a=this.reader.requestSlice(e,o);if(a instanceof Promise&&(a=await a),h(a),a===null)throw new Error(`StreamInfo block at position ${e} is too small! Corrupted file.`);let c=E(a,34),l=new N(c),d=l.readBits(16),u=l.readBits(16),f=l.readBits(24),m=l.readBits(24),p=l.readBits(20),g=l.readBits(3)+1;l.readBits(5);let x=l.readBits(36);l.skipBits(128);let y=new Uint8Array(42);y.set(new Uint8Array([102,76,97,67]),0),y.set(new Uint8Array([128,0,0,34]),4),y.set(c,8),this.audioInfo={numberOfChannels:g,sampleRate:p,totalSamples:x,minimumBlockSize:d,maximumBlockSize:u,minimumFrameSize:f,maximumFrameSize:m,description:y},this.track=new G(this.input,new yi(this));break}case Ue.VORBIS_COMMENT:{let a=this.reader.requestSlice(e,o);a instanceof Promise&&(a=await a),h(a),sr(E(a,o),this.metadataTags);break}case Ue.PICTURE:{let a=this.reader.requestSlice(e,o);a instanceof Promise&&(a=await a),h(a);let c=v(a),l=v(a),d=$.decode(E(a,l)),u=v(a),f=$.decode(E(a,u));a.skip(16);let m=v(a),p=E(a,m);this.metadataTags.images??=[],this.metadataTags.images.push({data:p,mimeType:d,kind:c===3?"coverFront":c===4?"coverBack":"unknown",description:f});break}default:break}if(e+=o,i){this.lastLoadedPos=e;break}}})()}async readNextFlacFrame({startPos:e,isFirstPacket:t}){h(this.audioInfo);let n=6,i=this.audioInfo.maximumFrameSize+16,s=await this.reader.requestSliceRange(e,this.audioInfo.minimumFrameSize,i);if(!s)return null;let a=this.readFlacFrameHeader({slice:s,isFirstPacket:t});if(!a)return null;for(s.filePos=e+this.audioInfo.minimumFrameSize;;){if(s.filePos>s.end-n)return{num:a.num,blockSize:a.blockSize,sampleRate:a.sampleRate,size:s.end-e,isLastFrame:!0};if(A(s)===255){let l=s.filePos,d=A(s),u=this.blockingBit===1?249:248;if(d!==u){s.filePos=l;continue}s.skip(-2);let f=s.filePos-e,m=this.readFlacFrameHeader({slice:s,isFirstPacket:!1});if(!m){s.filePos=l;continue}if(this.blockingBit===0){if(m.num-a.num!==1){s.filePos=l;continue}}else if(m.num-a.num!==a.blockSize){s.filePos=l;continue}return{num:a.num,blockSize:a.blockSize,sampleRate:a.sampleRate,size:f,isLastFrame:!1}}}}readFlacFrameHeader({slice:e,isFirstPacket:t}){let n=e.filePos,o=E(e,4),i=new N(o);if(i.readBits(15)!==32764)return null;if(this.blockingBit===null){h(t);let x=i.readBits(1);this.blockingBit=x}else if(this.blockingBit===1){if(h(!t),i.readBits(1)!==1)return null}else if(this.blockingBit===0){if(h(!t),i.readBits(1)!==0)return null}else throw new Error("Invalid blocking bit");let a=Ys(i.readBits(4));if(!a)return null;h(this.audioInfo);let c=Zs(i.readBits(4),this.audioInfo.sampleRate);if(!c||(i.readBits(4),i.readBits(3),i.readBits(1)!==0))return null;let d=Js(e),u=ea(e,a),f=ta(e,c);if(f===null||f!==this.audioInfo.sampleRate)return null;let m=e.filePos-n,p=A(e);e.skip(-m),e.skip(-1);let g=ra(E(e,m));return p!==g?null:{num:d,blockSize:u,sampleRate:f}}async advanceReader(){await this.readMetadata(),h(this.lastLoadedPos!==null),h(this.audioInfo);let e=this.lastLoadedPos,t=await this.readNextFlacFrame({startPos:e,isFirstPacket:this.loadedSamples.length===0});if(!t){this.lastSampleLoaded=!0;return}let n=this.loadedSamples[this.loadedSamples.length-1],i={blockOffset:n?n.blockOffset+n.blockSize:0,blockSize:t.blockSize,byteOffset:e,byteSize:t.size};if(this.lastLoadedPos=this.lastLoadedPos+t.size,this.loadedSamples.push(i),t.isLastFrame){this.lastSampleLoaded=!0;return}}},yi=class{constructor(e){this.demuxer=e}getId(){return 1}getCodec(){return"flac"}getInternalCodecId(){return null}getNumberOfChannels(){return h(this.demuxer.audioInfo),this.demuxer.audioInfo.numberOfChannels}async computeDuration(){let e=await this.getPacket(1/0,{metadataOnly:!0});return(e?.timestamp??0)+(e?.duration??0)}getSampleRate(){return h(this.demuxer.audioInfo),this.demuxer.audioInfo.sampleRate}getName(){return null}getLanguageCode(){return K}getTimeResolution(){return h(this.demuxer.audioInfo),this.demuxer.audioInfo.sampleRate}getDisposition(){return{...te}}async getFirstTimestamp(){return 0}async getDecoderConfig(){return h(this.demuxer.audioInfo),{codec:"flac",numberOfChannels:this.demuxer.audioInfo.numberOfChannels,sampleRate:this.demuxer.audioInfo.sampleRate,description:this.demuxer.audioInfo.description}}async getPacket(e,t){if(h(this.demuxer.audioInfo),e<0)throw new Error("Timestamp cannot be negative");let n=await this.demuxer.readingMutex.acquire();try{for(;;){let o=B(this.demuxer.loadedSamples,e,c=>c.blockOffset/this.demuxer.audioInfo.sampleRate);if(o===-1){await this.demuxer.advanceReader();continue}let i=this.demuxer.loadedSamples[o],s=i.blockOffset/this.demuxer.audioInfo.sampleRate,a=i.blockSize/this.demuxer.audioInfo.sampleRate;if(s+a<=e){if(this.demuxer.lastSampleLoaded)return this.getPacketAtIndex(this.demuxer.loadedSamples.length-1,t);await this.demuxer.advanceReader();continue}return this.getPacketAtIndex(o,t)}}finally{n()}}async getNextPacket(e,t){let n=await this.demuxer.readingMutex.acquire();try{let o=e.sequenceNumber+1;if(this.demuxer.lastSampleLoaded&&o>=this.demuxer.loadedSamples.length)return null;for(;o>=this.demuxer.loadedSamples.length&&!this.demuxer.lastSampleLoaded;)await this.demuxer.advanceReader();return this.getPacketAtIndex(o,t)}finally{n()}}getKeyPacket(e,t){return this.getPacket(e,t)}getNextKeyPacket(e,t){return this.getNextPacket(e,t)}async getPacketAtIndex(e,t){let n=this.demuxer.loadedSamples[e];if(!n)return null;let o;if(t.metadataOnly)o=H;else{let a=this.demuxer.reader.requestSlice(n.byteOffset,n.byteSize);if(a instanceof Promise&&(a=await a),!a)return null;o=E(a,n.byteSize)}h(this.demuxer.audioInfo);let i=n.blockOffset/this.demuxer.audioInfo.sampleRate,s=n.blockSize/this.demuxer.audioInfo.sampleRate;return new V(o,"key",i,s,e,n.byteSize)}async getFirstPacket(e){for(;this.demuxer.loadedSamples.length===0&&!this.demuxer.lastSampleLoaded;)await this.demuxer.advanceReader();return this.getPacketAtIndex(0,e)}};var ae=class{},Tr=class extends ae{async _getMajorBrand(e){let t=e._reader.requestSlice(0,12);return t instanceof Promise&&(t=await t),!t||(t.skip(4),L(t,4)!=="ftyp")?null:L(t,4)}_createDemuxer(e){return new gn(e)}},Dn=class extends Tr{async _canReadInput(e){let t=await this._getMajorBrand(e);return!!t&&t!=="qt "}get name(){return"MP4"}get mimeType(){return"video/mp4"}},Rn=class extends Tr{async _canReadInput(e){return await this._getMajorBrand(e)==="qt "}get name(){return"QuickTime File Format"}get mimeType(){return"video/quicktime"}},wr=class extends ae{async isSupportedEBMLOfDocType(e,t){let n=e._reader.requestSlice(0,de);if(n instanceof Promise&&(n=await n),!n)return!1;let o=ii(n);if(o===null||o<1||o>8||D(n,o)!==T.EBML)return!1;let s=si(n);if(s===null)return!1;let a=e._reader.requestSlice(n.filePos,s);if(a instanceof Promise&&(a=await a),!a)return!1;let c=n.filePos;for(;a.filePos<=c+s-oe;){let l=fe(a);if(!l)break;let{id:d,size:u}=l,f=a.filePos;if(u===null)return!1;switch(d){case T.EBMLVersion:if(D(a,u)!==1)return!1;break;case T.EBMLReadVersion:if(D(a,u)!==1)return!1;break;case T.DocType:if(He(a,u)!==t)return!1;break;case T.DocTypeVersion:if(D(a,u)>4)return!1;break}a.filePos=f+u}return!0}_canReadInput(e){return this.isSupportedEBMLOfDocType(e,"matroska")}_createDemuxer(e){return new Sn(e)}get name(){return"Matroska"}get mimeType(){return"video/x-matroska"}},Mn=class extends wr{_canReadInput(e){return this.isSupportedEBMLOfDocType(e,"webm")}get name(){return"WebM"}get mimeType(){return"video/webm"}},Bn=class extends ae{async _canReadInput(e){let t=e._reader.requestSlice(0,10);if(t instanceof Promise&&(t=await t),!t)return!1;let n=0,o=!1;for(;;){let l=e._reader.requestSlice(n,zt);if(l instanceof Promise&&(l=await l),!l)break;let d=ct(l);if(!d)break;o=!0,n=l.filePos+d.size}let i=await br(e._reader,n,n+4096);if(!i)return!1;if(o)return!0;n=i.startPos+i.header.totalSize;let s=await br(e._reader,n,n+4);if(!s)return!1;let a=i.header,c=s.header;return!(a.channel!==c.channel||a.sampleRate!==c.sampleRate)}_createDemuxer(e){return new In(e)}get name(){return"MP3"}get mimeType(){return"audio/mpeg"}},On=class extends ae{async _canReadInput(e){let t=e._reader.requestSlice(0,12);if(t instanceof Promise&&(t=await t),!t)return!1;let n=L(t,4);return n!=="RIFF"&&n!=="RIFX"&&n!=="RF64"?!1:(t.skip(4),L(t,4)==="WAVE")}_createDemuxer(e){return new _n(e)}get name(){return"WAVE"}get mimeType(){return"audio/wav"}},zn=class extends ae{async _canReadInput(e){let t=e._reader.requestSlice(0,4);return t instanceof Promise&&(t=await t),t?L(t,4)==="OggS":!1}_createDemuxer(e){return new An(e)}get name(){return"Ogg"}get mimeType(){return"application/ogg"}},Un=class extends ae{async _canReadInput(e){let t=e._reader.requestSlice(0,4);return t instanceof Promise&&(t=await t),t?L(t,4)==="fLaC":!1}get name(){return"FLAC"}get mimeType(){return"audio/flac"}_createDemuxer(e){return new Fn(e)}},Nn=class extends ae{async _canReadInput(e){let t=e._reader.requestSliceRange(0,Lt,Ht);if(t instanceof Promise&&(t=await t),!t)return!1;let n=yr(t);if(!n||(t=e._reader.requestSliceRange(n.frameLength,Lt,Ht),t instanceof Promise&&(t=await t),!t))return!1;let o=yr(t);return o?n.objectType===o.objectType&&n.samplingFrequencyIndex===o.samplingFrequencyIndex&&n.channelConfiguration===o.channelConfiguration:!1}_createDemuxer(e){return new En(e)}get name(){return"ADTS"}get mimeType(){return"audio/aac"}},na=new Dn,oa=new Rn,ia=new wr,sa=new Mn,aa=new Bn,ca=new On,la=new zn,ua=new Nn,da=new Un,ie=[na,oa,ia,sa,ca,la,da,aa,ua];var dt=class{constructor(){this._disposed=!1,this._sizePromise=null,this.onread=null}async getSizeOrNull(){if(this._disposed)throw new q;return this._sizePromise??=Promise.resolve(this._retrieveSize())}async getSize(){if(this._disposed)throw new q;let e=await this.getSizeOrNull();if(e===null)throw new Error("Cannot determine the size of an unsized source.");return e}};var kr=class extends dt{constructor(e,t={}){if(!(e instanceof Blob))throw new TypeError("blob must be a Blob.");if(!t||typeof t!="object")throw new TypeError("options must be an object.");if(t.maxCacheSize!==void 0&&(!or(t.maxCacheSize)||t.maxCacheSize<0))throw new TypeError("options.maxCacheSize, when provided, must be a non-negative number.");super(),this._readers=new WeakMap,this._blob=e,this._orchestrator=new Vn({maxCacheSize:t.maxCacheSize??8*2**20,maxWorkerCount:4,runWorker:this._runWorker.bind(this),prefetchProfile:ma.fileSystem})}_retrieveSize(){let e=this._blob.size;return this._orchestrator.fileSize=e,e}_read(e,t){return this._orchestrator.read(e,t)}async _runWorker(e){let t=this._readers.get(e);for(t===void 0&&("stream"in this._blob&&!Be()?t=this._blob.slice(e.currentPos).stream().getReader():t=null,this._readers.set(e,t));e.currentPos<e.targetPos&&!e.aborted;)if(t){let{done:n,value:o}=await t.read();if(n)throw this._orchestrator.forgetWorker(e),new Error("Blob reader stopped unexpectedly before all requested data was read.");if(e.aborted)break;this.onread?.(e.currentPos,e.currentPos+o.length),this._orchestrator.supplyWorkerData(e,o)}else{let n=await this._blob.slice(e.currentPos,e.targetPos).arrayBuffer();if(e.aborted)break;this.onread?.(e.currentPos,e.currentPos+n.byteLength),this._orchestrator.supplyWorkerData(e,new Uint8Array(n))}e.running=!1,e.aborted&&await t?.cancel()}_dispose(){this._orchestrator.dispose()}},fa=.5*2**20,Wc=((r,e,t)=>{if(e instanceof Error&&(e.message.includes("Failed to fetch")||e.message.includes("Load failed")||e.message.includes("NetworkError when attempting to fetch resource"))){let o=null;try{typeof window<"u"&&typeof window.location<"u"&&(o=new URL(t instanceof Request?t.url:t,window.location.href).origin)}catch{}if((typeof navigator<"u"&&typeof navigator.onLine=="boolean"?navigator.onLine:!0)&&o!==null&&o!==window.location.origin)return console.warn("Request will not be retried because a CORS error was suspected due to different origins. You can modify this behavior by providing your own function for the 'getRetryDelay' option."),null}return Math.min(2**(r-2),16)}),Sr=class extends dt{constructor(e,t={}){if(typeof e!="string"&&!(e instanceof URL)&&!(typeof Request<"u"&&e instanceof Request))throw new TypeError("url must be a string, URL or Request.");if(!t||typeof t!="object")throw new TypeError("options must be an object.");if(t.requestInit!==void 0&&(!t.requestInit||typeof t.requestInit!="object"))throw new TypeError("options.requestInit, when provided, must be an object.");if(t.getRetryDelay!==void 0&&typeof t.getRetryDelay!="function")throw new TypeError("options.getRetryDelay, when provided, must be a function.");if(t.maxCacheSize!==void 0&&(!or(t.maxCacheSize)||t.maxCacheSize<0))throw new TypeError("options.maxCacheSize, when provided, must be a non-negative number.");if(t.fetchFn!==void 0&&typeof t.fetchFn!="function")throw new TypeError("options.fetchFn, when provided, must be a function.");super(),this._existingResponses=new WeakMap,this._url=e,this._options=t,this._getRetryDelay=t.getRetryDelay??Wc,this._orchestrator=new Vn({maxCacheSize:t.maxCacheSize??64*2**20,maxWorkerCount:2,runWorker:this._runWorker.bind(this),prefetchProfile:ma.network})}async _retrieveSize(){let e=new AbortController,t=await No(this._options.fetchFn??fetch,this._url,Uo(this._options.requestInit??{},{headers:{Range:"bytes=0-"},signal:e.signal}),this._getRetryDelay,()=>this._disposed);if(!t.ok)throw new Error(`Error fetching ${String(this._url)}: ${t.status} ${t.statusText}`);let n,o;if(t.status===206)o=this._getTotalLengthFromRangeResponse(t),n=this._orchestrator.createWorker(0,Math.min(o,fa));else{let i=t.headers.get("Content-Length");if(i)o=Number(i),n=this._orchestrator.createWorker(0,o),this._orchestrator.options.maxCacheSize=1/0,console.warn("HTTP server did not respond with 206 Partial Content, meaning the entire remote resource now has to be downloaded. For efficient media file streaming across a network, please make sure your server supports range requests.");else throw new Error(`HTTP response (status ${t.status}) must surface Content-Length header.`)}return this._orchestrator.fileSize=o,this._existingResponses.set(n,{response:t,abortController:e}),this._orchestrator.runWorker(n),o}_read(e,t){return this._orchestrator.read(e,t)}async _runWorker(e){for(;;){let t=this._existingResponses.get(e);this._existingResponses.delete(e);let n=t?.abortController,o=t?.response;if(n||(n=new AbortController,o=await No(this._options.fetchFn??fetch,this._url,Uo(this._options.requestInit??{},{headers:{Range:`bytes=${e.currentPos}-`},signal:n.signal}),this._getRetryDelay,()=>this._disposed)),h(o),!o.ok)throw new Error(`Error fetching ${String(this._url)}: ${o.status} ${o.statusText}`);if(e.currentPos>0&&o.status!==206)throw new Error("HTTP server did not respond with 206 Partial Content to a range request. To enable efficient media file streaming across a network, please make sure your server supports range requests.");if(!o.body)throw new Error("Missing HTTP response body stream. The used fetch function must provide the response body as a ReadableStream.");let i=o.body.getReader();for(;;){if(e.currentPos>=e.targetPos||e.aborted){n.abort(),e.running=!1;return}let s;try{s=await i.read()}catch(l){if(this._disposed)throw l;let d=this._getRetryDelay(1,l,this._url);if(d!==null){console.error("Error while reading response stream. Attempting to resume.",l),await new Promise(u=>setTimeout(u,1e3*d));break}else throw l}if(e.aborted)continue;let{done:a,value:c}=s;if(a){if(e.currentPos>=e.targetPos){this._orchestrator.forgetWorker(e),e.running=!1;return}break}this.onread?.(e.currentPos,e.currentPos+c.length),this._orchestrator.supplyWorkerData(e,c)}}}_getTotalLengthFromRangeResponse(e){let t=e.headers.get("Content-Range");if(t){let o=/\/(\d+)/.exec(t);if(o)return Number(o[1])}let n=e.headers.get("Content-Length");if(n)return Number(n);throw new Error("Partial HTTP response (status 206) must surface either Content-Range or Content-Length header.")}_dispose(){this._orchestrator.dispose()}};var ma={none:(r,e)=>({start:r,end:e}),fileSystem:(r,e)=>(r=Math.floor((r-65536)/65536)*65536,e=Math.ceil((e+65536)/65536)*65536,{start:r,end:e}),network:(r,e,t)=>{r=Math.max(0,Math.floor((r-65536)/65536)*65536);for(let o of t){let s=Math.max((o.startPos+o.targetPos)/2,o.targetPos-8388608);if(en(r,e,s,o.targetPos)){let a=o.targetPos-o.startPos,c=Math.ceil((a+1)/8388608)*8388608,l=2**Math.ceil(Math.log2(a+1)),d=Math.min(l,c);e=Math.max(e,o.startPos+d)}}return e=Math.max(e,r+fa),{start:r,end:e}}},Vn=class{constructor(e){this.options=e,this.fileSize=null,this.nextAge=0,this.workers=[],this.cache=[],this.currentCacheSize=0,this.disposed=!1}read(e,t){h(this.fileSize!==null);let n=this.options.prefetchProfile(e,t,this.workers),o=Math.max(n.start,0),i=Math.min(n.end,this.fileSize);h(o<=e&&t<=i);let s=null,a=B(this.cache,e,b=>b.start),c=a!==-1?this.cache[a]:null;c&&c.start<=e&&t<=c.end&&(c.age=this.nextAge++,s={bytes:c.bytes,view:c.view,offset:c.start});let l=B(this.cache,o,b=>b.start),d=s?null:new Uint8Array(t-e),u=0,f=o,m=[];if(l!==-1){for(let b=l;b<this.cache.length;b++){let w=this.cache[b];if(w.start>=i)break;if(w.end<=o)continue;let k=Math.max(o,w.start),P=Math.min(i,w.end);if(h(k<=P),f<k&&m.push({start:f,end:k}),f=P,d){let S=Math.max(e,w.start),_=Math.min(t,w.end);if(S<_){let C=S-e;d.set(w.bytes.subarray(S-w.start,_-w.start),C),C===u&&(u=_-e)}}w.age=this.nextAge++}f<i&&m.push({start:f,end:i})}else m.push({start:o,end:i});if(d&&u>=d.length&&(s={bytes:d,view:z(d),offset:e}),m.length===0)return h(s),s;let{promise:p,resolve:g,reject:x}=Z(),y=[];for(let b of m){let w=Math.max(e,b.start),k=Math.min(t,b.end);w===b.start&&k===b.end?y.push(b):w<k&&y.push({start:w,end:k})}for(let b of m){let w=d&&{start:e,bytes:d,holes:y,resolve:g,reject:x},k=!1;for(let P of this.workers)if(en(b.start-131072,b.start,P.currentPos,P.targetPos)){P.targetPos=Math.max(P.targetPos,b.end),k=!0,w&&!P.pendingSlices.includes(w)&&P.pendingSlices.push(w),P.running||this.runWorker(P);break}if(!k){let P=this.createWorker(b.start,b.end);w&&(P.pendingSlices=[w]),this.runWorker(P)}}return s||(h(d),s=p.then(b=>({bytes:b,view:z(b),offset:e}))),s}createWorker(e,t){let n={startPos:e,currentPos:e,targetPos:t,running:!1,aborted:this.disposed,pendingSlices:[],age:this.nextAge++};for(this.workers.push(n);this.workers.length>this.options.maxWorkerCount;){let o=0,i=this.workers[0];for(let s=1;s<this.workers.length;s++){let a=this.workers[s];a.age<i.age&&(o=s,i=a)}if(i.running&&i.pendingSlices.length>0)break;i.aborted=!0,this.workers.splice(o,1)}return n}runWorker(e){h(!e.running),h(e.currentPos<e.targetPos),e.running=!0,e.age=this.nextAge++,this.options.runWorker(e).catch(t=>{if(e.running=!1,e.pendingSlices.length>0)e.pendingSlices.forEach(n=>n.reject(t)),e.pendingSlices.length=0;else throw t})}supplyWorkerData(e,t){h(!e.aborted);let n=e.currentPos,o=n+t.length;this.insertIntoCache({start:n,end:o,bytes:t,view:z(t),age:this.nextAge++}),e.currentPos+=t.length,e.targetPos=Math.max(e.targetPos,e.currentPos);for(let i=0;i<e.pendingSlices.length;i++){let s=e.pendingSlices[i],a=Math.max(n,s.start),c=Math.min(o,s.start+s.bytes.length);a<c&&s.bytes.set(t.subarray(a-n,c-n),a-s.start);for(let l=0;l<s.holes.length;l++){let d=s.holes[l];n<=d.start&&o>d.start&&(d.start=o),d.end<=d.start&&(s.holes.splice(l,1),l--)}s.holes.length===0&&(s.resolve(s.bytes),e.pendingSlices.splice(i,1),i--)}for(let i=0;i<this.workers.length;i++){let s=this.workers[i];e===s||s.running||en(n,o,s.currentPos,s.targetPos)&&(this.workers.splice(i,1),i--)}}forgetWorker(e){let t=this.workers.indexOf(e);h(t!==-1),this.workers.splice(t,1)}insertIntoCache(e){if(this.options.maxCacheSize===0)return;let t=B(this.cache,e.start,n=>n.start)+1;if(t>0){let n=this.cache[t-1];if(n.end>=e.end)return;if(n.end>e.start){let o=new Uint8Array(e.end-n.start);o.set(n.bytes,0),o.set(e.bytes,e.start-n.start),this.currentCacheSize+=e.end-n.end,n.bytes=o,n.view=z(o),n.end=e.end,t--,e=n}else this.cache.splice(t,0,e),this.currentCacheSize+=e.bytes.length}else this.cache.splice(t,0,e),this.currentCacheSize+=e.bytes.length;for(let n=t+1;n<this.cache.length;n++){let o=this.cache[n];if(e.end<=o.start)break;if(e.end>=o.end){this.cache.splice(n,1),this.currentCacheSize-=o.bytes.length,n--;continue}let i=new Uint8Array(o.end-e.start);i.set(e.bytes,0),i.set(o.bytes,o.start-e.start),this.currentCacheSize-=e.end-o.start,e.bytes=i,e.view=z(i),e.end=o.end,this.cache.splice(n,1);break}for(;this.currentCacheSize>this.options.maxCacheSize;){let n=0,o=this.cache[0];for(let i=1;i<this.cache.length;i++){let s=this.cache[i];s.age<o.age&&(n=i,o=s)}if(this.currentCacheSize-o.bytes.length<=this.options.maxCacheSize)break;this.cache.splice(n,1),this.currentCacheSize-=o.bytes.length}}dispose(){for(let e of this.workers)e.aborted=!0;this.workers.length=0,this.cache.length=0,this.disposed=!0}};tn();var ee=class{get disposed(){return this._disposed}constructor(e){if(this._demuxerPromise=null,this._format=null,this._disposed=!1,!e||typeof e!="object")throw new TypeError("options must be an object.");if(!Array.isArray(e.formats)||e.formats.some(t=>!(t instanceof ae)))throw new TypeError("options.formats must be an array of InputFormat.");if(!(e.source instanceof dt))throw new TypeError("options.source must be a Source.");if(e.source._disposed)throw new Error("options.source must not be disposed.");this._formats=e.formats,this._source=e.source,this._reader=new Ln(e.source)}_getDemuxer(){return this._demuxerPromise??=(async()=>{this._reader.fileSize=await this._source.getSizeOrNull();for(let e of this._formats)if(await e._canReadInput(this))return this._format=e,e._createDemuxer(this);throw new Error("Input has an unsupported or unrecognizable format.")})()}get source(){return this._source}async getFormat(){return await this._getDemuxer(),h(this._format),this._format}async computeDuration(){return(await this._getDemuxer()).computeDuration()}async getTracks(){return(await this._getDemuxer()).getTracks()}async getVideoTracks(){return(await this.getTracks()).filter(t=>t.isVideoTrack())}async getAudioTracks(){return(await this.getTracks()).filter(t=>t.isAudioTrack())}async getPrimaryVideoTrack(){return(await this.getTracks()).find(t=>t.isVideoTrack())??null}async getPrimaryAudioTrack(){return(await this.getTracks()).find(t=>t.isAudioTrack())??null}async getMimeType(){return(await this._getDemuxer()).getMimeType()}async getMetadataTags(){return(await this._getDemuxer()).getMetadataTags()}dispose(){this._disposed||(this._disposed=!0,this._source._disposed=!0,this._source._dispose())}[Symbol.dispose](){this.dispose()}},q=class extends Error{constructor(e="Input has been disposed."){super(e),this.name="InputDisposedError"}};var Ln=class{constructor(e){this.source=e}requestSlice(e,t){if(this.source._disposed)throw new q;if(this.fileSize!==null&&e+t>this.fileSize)return null;let n=e+t,o=this.source._read(e,n);return o instanceof Promise?o.then(i=>i?new Dt(i.bytes,i.view,i.offset,e,n):null):o?new Dt(o.bytes,o.view,o.offset,e,n):null}requestSliceRange(e,t,n){if(this.source._disposed)throw new q;if(this.fileSize!==null)return this.requestSlice(e,Ye(this.fileSize-e,t,n));{let o=this.requestSlice(e,n),i=s=>{if(s)return s;let a=l=>(h(l!==null),this.requestSlice(e,Ye(l-e,t,n))),c=this.source._retrieveSize();return c instanceof Promise?c.then(a):a(c)};return o instanceof Promise?o.then(i):i(o)}}},Dt=class r{constructor(e,t,n,o,i){this.bytes=e,this.view=t,this.offset=n,this.start=o,this.end=i,this.bufferPos=o-n}static tempFromBytes(e){return new r(e,z(e),0,0,e.length)}get length(){return this.end-this.start}get filePos(){return this.offset+this.bufferPos}set filePos(e){this.bufferPos=e-this.offset}get remainingLength(){return Math.max(this.end-this.filePos,0)}skip(e){this.bufferPos+=e}slice(e,t=this.end-e){if(e<this.start||e+t>this.end)throw new RangeError("Slicing outside of original slice.");return new r(this.bytes,this.view,this.offset,e,e+t)}},re=(r,e)=>{if(r.filePos<r.start||r.filePos+e>r.end)throw new RangeError(`Tried reading [${r.filePos}, ${r.filePos+e}), but slice is [${r.start}, ${r.end}). This is likely an internal error, please report it alongside the file that caused it.`)},E=(r,e)=>{re(r,e);let t=r.bytes.subarray(r.bufferPos,r.bufferPos+e);return r.bufferPos+=e,t},A=r=>(re(r,1),r.view.getUint8(r.bufferPos++)),Vt=(r,e)=>{re(r,2);let t=r.view.getUint16(r.bufferPos,e);return r.bufferPos+=2,t},W=r=>{re(r,2);let e=r.view.getUint16(r.bufferPos,!1);return r.bufferPos+=2,e},Le=r=>{re(r,3);let e=Qe(r.view,r.bufferPos,!1);return r.bufferPos+=3,e},pr=r=>{re(r,2);let e=r.view.getInt16(r.bufferPos,!1);return r.bufferPos+=2,e},Re=(r,e)=>{re(r,4);let t=r.view.getUint32(r.bufferPos,e);return r.bufferPos+=4,t},v=r=>{re(r,4);let e=r.view.getUint32(r.bufferPos,!1);return r.bufferPos+=4,e},lt=r=>{re(r,4);let e=r.view.getUint32(r.bufferPos,!0);return r.bufferPos+=4,e},_e=r=>{re(r,4);let e=r.view.getInt32(r.bufferPos,!1);return r.bufferPos+=4,e},jc=r=>{re(r,4);let e=r.view.getInt32(r.bufferPos,!0);return r.bufferPos+=4,e},gi=(r,e)=>{let t,n;return e?(t=Re(r,!0),n=Re(r,!0)):(n=Re(r,!1),t=Re(r,!1)),n*4294967296+t},ne=r=>{let e=v(r),t=v(r);return e*4294967296+t},Fs=r=>{let e=_e(r),t=v(r);return e*4294967296+t},Ks=r=>{let e=lt(r);return jc(r)*4294967296+e},Rs=r=>{re(r,4);let e=r.view.getFloat32(r.bufferPos,!1);return r.bufferPos+=4,e},bn=r=>{re(r,8);let e=r.view.getFloat64(r.bufferPos,!1);return r.bufferPos+=8,e},L=(r,e)=>{re(r,e);let t="";for(let n=0;n<e;n++)t+=String.fromCharCode(r.bytes[r.bufferPos++]);return t};var Hn=class{count=0};var pa={extension:{type:Cr.Environment,name:"browser",priority:-1},test:()=>!0,load:async()=>{await import("./browserAll-5AZHDDG6.js")}};var ha={extension:{type:Cr.Environment,name:"webworker",priority:0},test:()=>typeof self<"u"&&self.WorkerGlobalScope!==void 0,load:async()=>{await import("./webworkerAll-QKIC5O27.js")}};var qn;function ga(r){return qn!==void 0||(qn=(()=>{let e={stencil:!0,failIfMajorPerformanceCaveat:r??Ar.defaultOptions.failIfMajorPerformanceCaveat};try{if(!Kt.get().getWebGLRenderingContext())return!1;let n=Kt.get().createCanvas().getContext("webgl",e),o=!!n?.getContextAttributes()?.stencil;if(n){let i=n.getExtension("WEBGL_lose_context");i&&i.loseContext()}return n=null,o}catch{return!1}})()),qn}var Gn;async function xa(r={}){return Gn!==void 0||(Gn=await(async()=>{let e=Kt.get().getNavigator().gpu;if(!e)return!1;try{return await(await e.requestAdapter(r)).requestDevice(),!0}catch{return!1}})()),Gn}var ba=["webgl","webgpu","canvas"];async function Ti(r){let e=[];r.preference?(e.push(r.preference),ba.forEach(i=>{i!==r.preference&&e.push(i)})):e=ba.slice();let t,n={};for(let i=0;i<e.length;i++){let s=e[i];if(s==="webgpu"&&await xa()){let{WebGPURenderer:a}=await import("./WebGPURenderer-RBOFXPL5.js");t=a,n={...r,...r.webgpu};break}else if(s==="webgl"&&ga(r.failIfMajorPerformanceCaveat??Ar.defaultOptions.failIfMajorPerformanceCaveat)){let{WebGLRenderer:a}=await import("./WebGLRenderer-NLGJGAXK.js");t=a,n={...r,...r.webgl};break}else if(s==="canvas")throw n={...r},new Error("CanvasRenderer is not yet implemented")}if(delete n.webgpu,delete n.webgl,!t)throw new Error("No available renderer for the current environment");let o=new t;return await o.init(n),o}var Wn=class extends Ei{constructor(e,t){let{text:n,resolution:o,style:i,anchor:s,width:a,height:c,roundPixels:l,...d}=e;super({...d}),this.batched=!0,this._resolution=null,this._autoResolution=!0,this._didTextUpdate=!0,this._styleClass=t,this.text=n??"",this.style=i,this.resolution=o??null,this.allowChildren=!1,this._anchor=new Ii({_onUpdate:()=>{this.onViewUpdate()}}),s&&(this.anchor=s),this.roundPixels=l??!1,a!==void 0&&(this.width=a),c!==void 0&&(this.height=c)}get anchor(){return this._anchor}set anchor(e){typeof e=="number"?this._anchor.set(e):this._anchor.copyFrom(e)}set text(e){e=e.toString(),this._text!==e&&(this._text=e,this.onViewUpdate())}get text(){return this._text}set resolution(e){this._autoResolution=e===null,this._resolution=e,this.onViewUpdate()}get resolution(){return this._resolution}get style(){return this._style}set style(e){e||(e={}),this._style?.off("update",this.onViewUpdate,this),e instanceof this._styleClass?this._style=e:this._style=new this._styleClass(e),this._style.on("update",this.onViewUpdate,this),this.onViewUpdate()}get width(){return Math.abs(this.scale.x)*this.bounds.width}set width(e){this._setWidth(e,this.bounds.width)}get height(){return Math.abs(this.scale.y)*this.bounds.height}set height(e){this._setHeight(e,this.bounds.height)}getSize(e){return e||(e={}),e.width=Math.abs(this.scale.x)*this.bounds.width,e.height=Math.abs(this.scale.y)*this.bounds.height,e}setSize(e,t){typeof e=="object"?(t=e.height??e.width,e=e.width):t??(t=e),e!==void 0&&this._setWidth(e,this.bounds.width),t!==void 0&&this._setHeight(t,this.bounds.height)}containsPoint(e){let t=this.bounds.width,n=this.bounds.height,o=-t*this.anchor.x,i=0;return e.x>=o&&e.x<=o+t&&(i=-n*this.anchor.y,e.y>=i&&e.y<=i+n)}onViewUpdate(){this.didViewUpdate||(this._didTextUpdate=!0),super.onViewUpdate()}destroy(e=!1){super.destroy(e),this.owner=null,this._bounds=null,this._anchor=null,(typeof e=="boolean"?e:e?.style)&&this._style.destroy(e),this._style=null,this._text=null}get styleKey(){return`${this._text}:${this._style.styleKey}:${this._resolution}`}};function ya(r,e){let t=r[0]??{};return(typeof t=="string"||r[1])&&(_i(Ai,`use new ${e}({ text: "hi!", style }) instead`),t={text:t,style:r[1]}),t}var vr=class extends Wn{constructor(...e){let t=ya(e,"Text");super(t,Fi),this.renderPipeId="text",t.textureStyle&&(this.textureStyle=t.textureStyle instanceof fo?t.textureStyle:new fo(t.textureStyle))}updateBounds(){let e=this._bounds,t=this._anchor,n=0,o=0;if(this._style.trim){let{frame:i,canvasAndContext:s}=ho.getCanvasAndContext({text:this.text,style:this._style,resolution:1});ho.returnCanvasAndContext(s),n=i.width,o=i.height}else{let i=Di.measureText(this._text,this._style);n=i.width,o=i.height}e.minX=-t._x*n,e.maxX=e.minX+n,e.minY=-t._y*o,e.maxY=e.minY+o}};Ci.add(pa,ha);var Ta=r=>{let[e,t,n]=r,[o,i]=e,[s,a]=t,c=n*Math.PI/180,l=Math.cos(c),d=Math.sin(c);return[l*s,d*s,-d*a,l*a,o,i]},wa=([r,e,t,n,o,i])=>new uo(r,e,t,n,o,i);var ka=(r,e)=>{let[t,n,o,i,s,a]=r,[c,l,d,u,f,m]=e;return[t*c+o*l,n*c+i*l,t*d+o*u,n*d+i*u,t*f+o*m+s,n*f+i*m+a]},Sa=[1,0,0,1,0,0];var Aa=ic(Pa(),1);var Ca=`
|
|
2363
|
+
in vec2 aPosition;
|
|
2364
|
+
varying vec2 _uv; // gl-transition
|
|
2365
|
+
uniform mat3 projectionMatrix;
|
|
2366
|
+
uniform vec4 uInputSize;
|
|
2367
|
+
uniform vec4 uOutputFrame;
|
|
2368
|
+
out vec2 vTextureCoord;
|
|
2369
|
+
uniform vec4 uOutputTexture;
|
|
2370
|
+
|
|
2371
|
+
vec4 filterVertexPosition( void )
|
|
2372
|
+
{
|
|
2373
|
+
vec2 position = aPosition * uOutputFrame.zw + uOutputFrame.xy;
|
|
2374
|
+
|
|
2375
|
+
position.x = position.x * (2.0 / uOutputTexture.x) - 1.0;
|
|
2376
|
+
position.y = position.y * (2.0*uOutputTexture.z / uOutputTexture.y) - uOutputTexture.z;
|
|
2377
|
+
|
|
2378
|
+
return vec4(position, 0.0, 1.0);
|
|
2379
|
+
}
|
|
2380
|
+
|
|
2381
|
+
vec2 filterTextureCoord( void )
|
|
2382
|
+
{
|
|
2383
|
+
return aPosition * (uOutputFrame.zw * uInputSize.zw);
|
|
2384
|
+
}
|
|
2385
|
+
|
|
2386
|
+
void main(void)
|
|
2387
|
+
{
|
|
2388
|
+
gl_Position = filterVertexPosition();
|
|
2389
|
+
vTextureCoord = filterTextureCoord();
|
|
2390
|
+
_uv = vec2(0.5, 0.5) * (aPosition +vec2(1.0, 1.0)); // gl-transition
|
|
2391
|
+
}
|
|
2392
|
+
`;var wi={custom:r=>Object.fromEntries(Object.entries(r.defaultParams).map(([e,t])=>[e,{value:t,type:$c(r.paramsTypes[e])}])),basics:{_fromR:{value:1,type:"f32"},_toR:{value:1,type:"f32"},ratio:{value:1,type:"f32"},progress:{value:0,type:"f32"},customUniform:{value:0,type:"f32"}}},$c=r=>r==="f32"||r==="i32"?r:r==="float"?"f32":`${r}<f32>`;var Ia=r=>`
|
|
2393
|
+
precision highp float;
|
|
2394
|
+
varying vec2 vTextureCoord;
|
|
2395
|
+
varying vec2 _uv;
|
|
2396
|
+
uniform sampler2D from, to;
|
|
2397
|
+
uniform float progress, ratio, _fromR, _toR;
|
|
2398
|
+
uniform float customUniform;
|
|
2399
|
+
|
|
2400
|
+
vec4 getFromColor(vec2 uv){
|
|
2401
|
+
return texture2D(from, .5+(uv-.5)*vec2(max(ratio/_fromR,1.), max(_fromR/ratio,1.)));
|
|
2402
|
+
}
|
|
2403
|
+
vec4 getToColor(vec2 uv){
|
|
2404
|
+
return texture2D(to, .5+(uv-.5)*vec2(max(ratio/_toR,1.), max(_toR/ratio,1.)));
|
|
2405
|
+
}
|
|
2406
|
+
|
|
2407
|
+
// gl-transition code here
|
|
2408
|
+
${r}
|
|
2409
|
+
// gl-transition code end
|
|
2410
|
+
|
|
2411
|
+
void main(){
|
|
2412
|
+
vec2 uv = vTextureCoord.xy;
|
|
2413
|
+
gl_FragColor = transition(vTextureCoord);
|
|
2414
|
+
}
|
|
2415
|
+
`;function _a({name:r,renderer:e}){let t=Aa.default.find(c=>c.name===r),n=new ht,o=new $t,i=new Ir({}),s=new Ir({}),a=new go({glProgram:new po({vertex:Ca,fragment:Ia(t.glsl)}),resources:{from:i,to:s,uniforms:{...wi.basics,...wi.custom(t)}}});return n.filters=[a],{render({width:c,height:l,from:d,to:u,progress:f}){return(n.width!==c||n.height!==l)&&(n.setSize({width:c,height:l}),o.source.resize(c,l)),i.resource=d,s.resource=u,i.update(),s.update(),a.resources.uniforms.uniforms.progress=f,e.render({container:n,target:o,clear:!1,width:c,height:l}),o}}}var jn=class{pixi;static async setup(){let e=await Ti({width:1920,height:1080,preference:"webgl",background:"black",preferWebGLVersion:2}),t=new mo;return t.interactive=!0,new this({renderer:e,stage:t})}constructor(e){this.pixi=e}#e=new Map;#t=new Map;async composite(e){let{stage:t,renderer:n}=this.pixi;this.#l(this.#c(e));let{dispose:o}=await this.#r(e,t);n.render(t);let i=new VideoFrame(n.canvas,{timestamp:0,duration:0});return o(),i}getActiveObject(e){return this.#t.get(e)}async#r(e,t){if(Array.isArray(e)){e.reverse();let n=[];for(let o of e){let i=await this.#r(o,t);n.push(i.dispose)}return{dispose:()=>n.forEach(o=>o())}}switch(e.kind){case"text":return this.#n(e,t);case"image":return this.#i(e,t);case"transition":return this.#s(e,t);case"gap":return this.pixi?.renderer.clear(),{dispose:()=>{}};default:return console.warn("Unknown layer kind",e.kind),{dispose:()=>{}}}}#n(e,t){let n=this.#a(e);return this.#o(n,e.matrix),t.addChild(n),{dispose:()=>{}}}#i(e,t){let n=$t.from(e.frame),o=this.#a(e);return o.texture=n,this.#o(o,e.matrix),t.addChild(o),{dispose:()=>{n.destroy(!0),e.frame.close()}}}#s({from:e,to:t,progress:n,name:o},i){let a=(this.#e.get(o)??(this.#e.set(o,_a({name:"circle",renderer:this.pixi.renderer})),this.#e.get(o))).render({from:e,to:t,progress:n,width:e.displayWidth,height:e.displayHeight}),c=new ht(a);return i.addChild(c),{dispose:()=>c.destroy(!1)}}#o(e,t){if(!t)return;let n=wa(t);e.setFromMatrix(n)}#a(e){let t=this.#t.get(e.id);if(t)return t;switch(e.kind){case"text":{let n=new vr({text:e.content,style:e.style});return n.onmouseenter=()=>console.log("enter text"),this.#t.set(e.id,n).get(e.id)}case"image":{let n=new ht;return n.onmouseenter=()=>console.log("enter"),this.#t.set(e.id,n).get(e.id)}}}#c(e){let t=new Set,n=o=>{if(Array.isArray(o))for(let i of o)n(i);else t.add(o.id)};return n(e),t}#l(e){for(let t of this.#t.keys())e.has(t)||(this.#t.get(t).destroy(!0),this.#t.delete(t))}};var Ea=r=>jr.host(e=>({async world(){r.count++}}));async function ce(r){return r instanceof Blob?new kr(r):new Sr(r)}var $n=class{machina;thread;compositor;static async setup(e){let t=new Hn,n=await jr.thread({label:"OmnitoolDriver",workerUrl:e?.workerUrl??"/node_modules/@omnimedia/omnitool/x/driver/driver.worker.bundle.min.js",setupHost:Ea(t)}),o=await jn.setup();return new this(t,n,o)}constructor(e,t,n){this.machina=e,this.thread=t,this.compositor=n}async hello(){return this.thread.work.hello()}async getAudioDuration(e){let n=await new ee({source:await ce(e),formats:ie}).getPrimaryAudioTrack();if(!n)throw new Error("primary audio track not found");return await n.computeDuration()}async getVideoDuration(e){return await(await new ee({source:await ce(e),formats:ie}).getPrimaryVideoTrack())?.computeDuration()}decodeVideo(e){let t=null,{port1:n,port2:o}=new MessageChannel,i=new TransformStream({async transform(s,a){let c=await e.onFrame?.(s)??s;t?.close(),a.enqueue(c),t=c}});return this.thread.work.decodeVideo[yt]({transfer:[i.writable,o]})({source:e.source,cancel:o,video:i.writable,start:e.start,end:e.end}),{readable:i.readable,cancel(){n.postMessage("close"),n.close()}}}decodeAudio(e){let t=new TransformStream,{port1:n,port2:o}=new MessageChannel;return this.thread.work.decodeAudio[yt]({transfer:[t.writable,o]})({source:e.source,cancel:o,audio:t.writable,start:e.start,end:e.end}),{readable:t.readable,cancel(){n.postMessage("close"),n.close()}}}encode({audio:e,video:t,config:n}){let{readable:o,writable:i}=new TransformStream,s=[e,t,i].filter(Er.happy),a=this.thread.work.encode[yt]({transfer:s})({audio:e,video:t,config:n,writable:i});return{readable:o,done:a}}async composite(e){return await this.compositor.composite(e)}};var M;(function(r){r[r.Sequence=0]="Sequence",r[r.Stack=1]="Stack",r[r.Video=2]="Video",r[r.Audio=3]="Audio",r[r.Text=4]="Text",r[r.Gap=5]="Gap",r[r.Spatial=6]="Spatial",r[r.Transition=7]="Transition",r[r.TextStyle=8]="TextStyle"})(M||(M={}));var Kn;(function(r){r[r.Crossfade=0]="Crossfade"})(Kn||(Kn={}));var Xn=class{datafile;duration=0;hasVideo=!1;hasAudio=!1;constructor(e){this.datafile=e}static async analyze(e){let t=new this(e),n=await this.duration(e.url)*1e3;t.duration=n;let{video:o,audio:i}=await this.#e(e.url);return t.hasAudio=i,t.hasVideo=o,t}static async duration(e){let n=await new ee({formats:ie,source:await ce(e)}).computeDuration();return Number(n.toFixed(5))}static async#e(e){let t=new ee({formats:ie,source:await ce(e)});return{audio:!!await t.getPrimaryAudioTrack(),video:!!await t.getPrimaryVideoTrack()}}};var Qn=class{#e=new Fr;async store(e){let t=await Xn.analyze(e),{hash:n}=t.datafile.checksum,{filename:o,bytes:i,url:s,blob:a}=t.datafile;if(this.#e.has(n)){let c=this.#e.require(n);c.filename=o}else this.#e.set(n,{kind:"media",filename:o,bytes:i,url:s,blob:a,duration:t.duration});return t}require(e){return this.#e.require(e)}};var Yn=class r{videoTrack;options;#e;#t=new Map;#r=[0,0];constructor(e,t){this.videoTrack=e,this.options=t,this.#e=new fr(e,t.canvasSinkOptions)}static async init(e,t){let o=await new ee({formats:ie,source:await ce(e)}).getPrimaryVideoTrack();if(o)return new r(o,{frequency:t.frequency??1,canvasSinkOptions:t.canvasSinkOptions??{width:80,height:50,fit:"fill"},onChange:t.onChange,onPlaceholders:t.onPlaceholders});throw new Error("Source has no video track")}set frequency(e){e!==this.options.frequency&&(this.options.frequency=e,this.#c())}get frequency(){return this.options.frequency}#n([e,t],n=1){let o=t-e;return[e-o*n,t+o*n]}async#i(){let[e,t]=this.#r,n=new Set,o=await this.videoTrack.computeDuration();for(let i=Math.max(0,e);i<=t;i+=this.options.frequency)i>=0&&i<=o&&n.add(i);this.options.onPlaceholders?.([...n])}async#s(){let[e,t]=this.#r,n=new Set,o=await this.videoTrack.computeDuration();for(let c=Math.max(0,e);c<=t;c+=this.options.frequency)c>=0&&c<=o&&n.add(c);let i=[...n].filter(c=>!this.#t.has(c)),s=0;for await(let c of this.#e.canvasesAtTimestamps(i))if(c){let l=i[s++];this.#t.set(l,c)}for(let c of this.#t.keys())n.has(c)||this.#t.delete(c);let a=[...this.#t.entries()].map(([c,l])=>({time:c,canvas:l}));this.options.onChange(a)}set range(e){let[t,n]=e,o=n-t,[i,s]=this.#r,a=i+o,c=s-o,l=t<a,d=n>c;!l&&!d||(this.#r=this.#n(e,2),this.#c())}#o=null;#a=!1;async#c(){if(this.#i(),this.#o){this.#a=!0;return}this.#o=this.#s(),await this.#o,this.#o=null,this.#a&&(this.#a=!1,await this.#c())}getThumbnail(e){return this.#t.get(e)}};function Fa(r,e){let t=typeof window<"u"&&window.devicePixelRatio||1,n=document.createElement("canvas");n.width=e.width*t,n.height=e.height*t,n.style.width=`${e.width}px`,n.style.height=`${e.height}px`;let o=n.getContext("2d");if(!o)return n;o.scale(t,t),o.fillStyle=e.color;let i=e.height/2,s=Math.max(1,e.width),a=r.length/s;for(let c=0;c<s;c++){let l=Math.floor(c*a),d=Math.max(l+1,Math.floor((c+1)*a)),u=0;for(let m=l;m<d&&m<r.length;m++)r[m]>u&&(u=r[m]);let f=u*e.height;o.fillRect(c,i-f/2,1,f)}return n}var ki=[2048,1024,512,256,128,64,32];async function Da(r,e){let t=await r.getAudioDuration(e)??0,n=r.decodeAudio({source:e}).readable,o=ki[ki.length-1],i=[],s=0,a=0,c=0;for await(let u of n){c||=u.sampleRate;let f=u.numberOfFrames,m=new Float32Array(f);u.copyTo(m,{planeIndex:0});for(let p=0;p<m.length;p++){let g=Math.abs(m[p]);g>s&&(s=g),a++,a>=o&&(i.push(s),s=0,a=0)}u.close()}a>0&&i.push(s);let l=new Float32Array(i),d=ki.map(u=>{let f=Math.max(1,Math.round(u/o)),m=f===1?l:Kc(l,f);return{samplesPerPeak:u,peaks:m,peaksPerSecond:c>0?c/u:0}});return{duration:t,levels:d}}function Kc(r,e){let t=new Float32Array(Math.ceil(r.length/e));for(let n=0;n<t.length;n++){let o=0,i=n*e,s=Math.min(i+e,r.length);for(let a=i;a<s;a++)r[a]>o&&(o=r[a]);t[n]=o}return t}var Xc=4096,Zn=class r{#e=new Map;#t=[0,0];#r=[0,0];#n;#i;#s;#o=!1;color;duration;tileSize;tileHeight;preloadMargin;constructor(e,t,n){this.#i=e,this.duration=t,this.tileSize=n.tileSize??1,this.#n=n.zoom??(n.tileWidth??256)/this.tileSize,this.tileHeight=n.tileHeight??96,this.preloadMargin=n.preloadMargin??2,this.color=n.color??"rgb(3, 148, 129)",this.#s=n.onChange}static async init(e,t,n={}){let{duration:o,levels:i}=await Da(e,t);return new r(i,o,n)}set zoom(e){let t=Math.max(1,e);t!==this.#n&&(this.#n=t,this.#e.clear(),this.#c())}get zoom(){return this.#n}get range(){return this.#r}#a([e,t],n=1){let o=t-e;return[Math.max(0,e-o*n),Math.min(this.duration,t+o*n)]}set range(e){this.#r=e;let[t,n]=e,o=n-t,[i,s]=this.#t,a=i>0,c=s<this.duration,l=!a||t>=i+o,d=!c||n<=s-o;l&&d||(this.#t=this.#a(e,this.preloadMargin),this.#c())}#c(){this.#o||(this.#o=!0,queueMicrotask(()=>{this.#o=!1,this.#l()}))}#l(){let[e,t]=this.#t,n=new Set,o=this.#d(),i=Math.max(0,Math.floor(e/this.tileSize)*this.tileSize),s=Math.min(this.duration,t);for(let a=i;a<=s;a+=this.tileSize)n.add(a);for(let a of n)if(!this.#e.has(a)){let c=Math.min(a+this.tileSize,this.duration);this.#e.set(a,this.#u(a,c,o))}for(let a of this.#e.keys())n.has(a)||this.#e.delete(a);this.#p()}#u(e,t,n){let o=this.#f(n,e,t);return{startTime:e,endTime:t,peaks:o,canvas:Fa(o,{width:this.#m(e,t),height:this.tileHeight,color:this.color})}}#d(){return this.#i.find(e=>e.peaksPerSecond>=this.#n)??this.#i[this.#i.length-1]}#f(e,t,n){if(!e.peaksPerSecond)return new Float32Array;let o=Math.max(0,Math.floor(t*e.peaksPerSecond)),i=Math.max(o+1,Math.min(e.peaks.length,Math.ceil(n*e.peaksPerSecond)));return e.peaks.slice(o,i)}#m(e,t){return Math.min(Xc,Math.max(1,Math.ceil((t-e)*this.#n)))}#p(){this.#s&&this.#s([...this.#e.values()].sort((e,t)=>e.startTime-t.startTime))}getTiles(){return this.#e}};var U=r=>r;var qt=r=>r;var Ra=()=>{let r=!1,e=qt(60),t=1e3/e,n=0,o=0,i=xt(),s=null,a=l=>{if(requestAnimationFrame(a),!!r)for(n=l;l-o>=t;)o+=t,s?.(),s=null,i()};async function*c(){for(n=performance.now(),o=n,requestAnimationFrame(a);;)await new Promise(l=>s=l),yield}return{play(){r||(r=!0,n=performance.now(),o=n)},pause(){r=!1},setFPS(l){e=l,t=1e3/e},isPlaying(){return r},ticks:c,onTick:i}},Ma=async(r,e)=>{let t=U(1e3/r.fps),n=r.duration/1e3,o=Math.ceil(n*r.fps);for(let i=0;i<o;i++){let s=U(i*t);await e(s,i)}};function Oa(r){return"duration"in r}function za(r){let e=[],t=new Map(r.timeline.items.map(n=>[n.id,n]));return Si(r.timeline.rootId,t,r.from,{sequence:()=>{},stack:()=>{},video:(n,o,i)=>e.push({item:n,localTime:o,ancestors:i}),text:(n,o,i)=>e.push({item:n,localTime:o,ancestors:i}),audio:(n,o,i)=>e.push({item:n,localTime:o,ancestors:i})}),e}function Ua(r,e,t){let n=Sa;for(let o of e)n=Ba(r,o,n);return Ba(r,t,n)}function Ba(r,e,t){if("spatialId"in e&&e.spatialId){let n=r.get(e.spatialId);if(n?.enabled){let o=Ta(n.transform);return ka(o,t)}}return t}function Si(r,e,t,n,o=[]){let i=e.get(r);if(i)switch(i.kind){case M.Stack:n.stack(i,t,o);for(let s of i.childrenIds)Si(s,e,t,n,[...o,i]);break;case M.Sequence:{n.sequence(i,t,o);let s=U(0);for(let a of i.childrenIds){let c=e.get(a);if(!c||!Oa(c))continue;let l=U(s+c.duration);if(t>=l){s=l;continue}let d=U(Math.max(0,t-s));Si(a,e,d,n,[...o,i]),s=l}break}case M.Video:n.video(i,t,o);break;case M.Text:n.text(i,t,o);break;case M.Audio:n.audio(i,t,o);break}}function pe(r,e){let t=e.items.find(n=>n.id===r);if(!t)return U(0);switch(t.kind){case M.Sequence:{let n=t.childrenIds.map(i=>e.items.find(s=>s.id===i)).filter(Boolean),o=U(0);for(let i=0;i<n.length;i++){let s=n[i];if(s.kind===M.Transition){let a=n[i-1],c=n[i+1];if(a&&c&&a.kind!==M.Transition&&c.kind!==M.Transition){let l=pe(a.id,e),d=pe(c.id,e),u=Math.max(0,Math.min(s.duration,l,d));o=U(o-u)}continue}o=U(o+pe(s.id,e))}return o}case M.Stack:{let n=U(0);for(let o of t.childrenIds){let i=pe(o,e);i>n&&(n=i)}return n}default:return Oa(t)?t.duration:U(0)}}var Pr=r=>r;var Jn=class{resolveMedia;#e=new Map;constructor(e){this.resolveMedia=e}async getSink(e){let t=this.#e.get(e);if(t)return t.sink;let n=new ee({formats:ie,source:await ce(this.resolveMedia(e))}),o=await n.getPrimaryVideoTrack(),s=!!o&&await o.canDecode()&&o?new Ct(o):null;return this.#e.set(e,{input:n,sink:s}),s}};async function Na(r,e,t,n){let[o,i]=await Promise.all([t,n]),s=o.find(l=>l.kind==="image")?.frame,a=i.find(l=>l.kind==="image")?.frame,c=[...o.filter(l=>l.kind!=="image"),...i.filter(l=>l.kind!=="image")];return s&&a?[{id:r.id,kind:"transition",name:"circle",progress:e,from:s,to:a},...c]:c}async function Va(r,e,t,n){let o=Qc(r,e,t);if(!o)return[];let i=[...n,e];return o.isTransitioning?Na(o.transition,o.progress,ft(r,o.outgoing,o.outgoingTime,i),ft(r,o.incoming,o.incomingTime,i)):ft(r,o.item,o.localTime,i)}function Qc(r,e,t){let n=e.childrenIds.map(i=>r.items.get(i)).filter(i=>!!i),o=U(0);for(let i=0;i<n.length;i++){let s=n[i];if(s.kind===M.Transition)continue;let a=o,c=pe(s.id,r.timeline),l=U(a+c),d=n[i+1];if(!(d?.kind===M.Transition)){if(t<l)return{isTransitioning:!1,item:s,localTime:U(t-a)};o=l;continue}let f=d,m=n[i+2];if(!m||m.kind===M.Transition){o=l;continue}let p=pe(m.id,r.timeline),g=Math.max(0,Math.min(f.duration,c,p)),x=U(l-g);if(t<x)return{isTransitioning:!1,item:s,localTime:U(t-a)};if(t<l){let y=U(t-x),b=U(t-a);return{isTransitioning:!0,incoming:m,outgoing:s,outgoingTime:b,incomingTime:y,progress:g>0?y/g:1,transition:f}}o=x,i++}return null}async function ft(r,e,t,n){let o=Ua(r.items,n,e);switch(e.kind){case M.Stack:{let i=[...n,e];return(await Promise.all(e.childrenIds.map(a=>r.items.get(a)).filter(a=>!!a).map(a=>ft(r,a,t,i)))).flat()}case M.Sequence:return Va(r,e,t,n);case M.Video:{if(t<0||t>=e.duration)return[];let i=await r.videoSampler(e,t);return i?[{kind:"image",frame:i,matrix:o,id:e.id}]:[]}case M.Text:{if(t<0||t>=e.duration)return[];let i=e.styleId?r.items.get(e.styleId)?.style:void 0;return[{id:e.id,kind:"text",content:e.content,style:i,matrix:o}]}case M.Gap:return[{id:e.id,kind:"gap"}];default:return[]}}function La(r){return async(e,t)=>{let o=await(await r.getSink(e.mediaHash))?.getSample(t/1e3),i=o?.toVideoFrame();return o?.close(),i??void 0}}function eo(r,e){let t=new Jn(r),n=e??La(t);return{async sample(o,i){let s=new Map(o.items.map(c=>[c.id,c])),a=s.get(o.rootId);return a?ft({videoSampler:n,timeline:o,items:s},a,i,[]):[]}}}var Gt=class{driver;resolveMedia;timeline;#e=-1/0;#t=new Map;#r;constructor(e,t,n){this.driver=e,this.resolveMedia=t,this.timeline=n,this.#r=eo(this.resolveMedia,(o,i)=>{let s=Ha(i),a=this.#t.get(o.id);if(!a){let c=this.resolveMedia(o.mediaHash),l=Ha(U(o.start+o.duration));a=this.#n(c,s,l),this.#t.set(o.id,a)}return a.next(s)})}next(e){if(e<this.#e)throw new Error(`Forward-only cursor regression: ${e}ms < ${this.#e}ms`);return this.#e=e,this.#r.sample(this.timeline,e)}async cancel(){await Promise.all([...this.#t.values()].map(e=>e.cancel())),this.#t.clear()}#n(e,t,n){let o=this.driver.decodeVideo({source:e,start:t/1e6,end:n/1e6}),i=o.readable.getReader(),s=null,a=null,c=!1,l=async()=>{if(c)return null;let{done:d,value:u}=await i.read();if(d)return c=!0,null;let f=new VideoFrame(u);return u.close(),f};return{async next(d){if(s??=await l(),!!s)for(;;){a??=l();let u=await a;if(!u)return new VideoFrame(s);let f=s.timestamp??-1/0,m=u.timestamp??f;if(m<d){s.close(),s=u,a=null;continue}if(Math.abs(m-d)<Math.abs(f-d)){s.close(),s=u,a=null;continue}return new VideoFrame(s)}},async cancel(){let d=a;a=null,c=!0,(await d?.catch(()=>null))?.close(),s?.close(),s=null,o.cancel()}}}},Ha=r=>Math.round(r*1e3);async function qa(r,e,t){return(await Promise.all(e.map(async({item:o,localTime:i})=>{if(o.kind!==M.Audio)return;let s=await r.getSink(o.mediaHash);if(!s)return;let a=o.start+i,c=Pr((t-a)/1e3),l=s.samples(a/1e3),d=await l.next();if(d.done)return;let u=d.value,f=l.next();return{offset:c,gain:o.gain??1,get currentSample(){return u},timelineTime:()=>Pr(c+u.timestamp),output:()=>({sample:u,timestamp:c+u.timestamp,gain:o.gain??1}),advance:async()=>{let m=await f;return m.done?!1:(u=m.value,f=l.next(),!0)}}}))).filter(o=>!!o)}var to=class{resolveMedia;#e=new Map;constructor(e){this.resolveMedia=e}async getSink(e){let t=this.#e.get(e);if(t)return t.sink;let n=new ee({formats:ie,source:await ce(this.resolveMedia(e))}),o=await n.getPrimaryAudioTrack(),s=!!o&&await o.canDecode()&&o?new mr(o):null;return this.#e.set(e,{input:n,sink:s}),s}};function Ga(r){let e={index:0,stream:r[0],time:r[0].timelineTime()};for(let[t,n]of r.entries()){let o=n.timelineTime();o<e.time&&(e={time:o,stream:n,index:t})}return e}function ro(r){let e=new to(r);return{async*sampleAudio(t,n){let o=za({timeline:t,from:n}),i=await qa(e,o,n);for(;i.length>0;){let{stream:s,index:a}=Ga(i);yield s.output(),await s.advance()||i.splice(a,1)}}}}var no=class{driver;timeline;resolveMedia;audioSampler;seekVisualSampler;playVisualSampler=null;#e=U(0);#t=null;#r=Ra();onTick=this.#r.onTick;audioContext=new AudioContext({sampleRate:48e3});audioGain=this.audioContext.createGain();audioNodes=new Set;#n=null;constructor(e,t,n){this.driver=e,this.timeline=t,this.resolveMedia=n,this.audioGain.connect(this.audioContext.destination),this.audioGain.gain.value=.7**2,this.seekVisualSampler=eo(this.resolveMedia),this.audioSampler=ro(this.resolveMedia),this.#i()}update(e){this.timeline=e}get isPlaying(){return this.#r.isPlaying()}async#i(){for await(let e of this.#r.ticks()){let t=await this.playVisualSampler?.next(this.currentTime)??[];(await this.driver.composite(t)).close(),this.currentTime>=this.duration&&this.pause()}}async seek(e){return this.pause(),this.#e=e,await this.seekVisualSampler.sample(this.timeline,e)}async start(){if(!this.#r.isPlaying()){await this.audioContext.resume(),this.#e=this.currentTime,this.#t=this.audioContext.currentTime,this.#n?.abort(),this.#n=new AbortController;for(let e of this.audioNodes)e.stop();this.audioNodes.clear(),this.playVisualSampler=new Gt(this.driver,this.resolveMedia,this.timeline),this.#r.play(),this.#s(this.#n.signal,Pr(this.#e/1e3))}}pause(){this.#e=this.currentTime,this.#r.pause(),this.#n?.abort();for(let e of this.audioNodes)e.stop();this.audioNodes.clear(),this.playVisualSampler&&(this.playVisualSampler.cancel(),this.playVisualSampler=null)}get duration(){return pe(this.timeline.rootId,this.timeline)}get currentTime(){if(!this.#r.isPlaying()||this.#t===null)return this.#e;let e=(this.audioContext.currentTime-this.#t)*1e3;return U(this.#e+e)}setFps(e){this.#r.setFPS(e)}async#s(e,t){let n=this.audioContext;if(this.#t!==null)for await(let{sample:o,timestamp:i}of this.audioSampler.sampleAudio(this.timeline,U(t*1e3))){if(e.aborted||!this.#r.isPlaying())return;for(;i-(n.currentTime-this.#t+t)>.75;)await new Promise(c=>setTimeout(c,25));let s=n.createBufferSource();s.buffer=o.toAudioBuffer(),s.connect(this.audioGain),s.onended=()=>this.audioNodes.delete(s),this.audioNodes.add(s);let a=this.#t+i-t;a>=n.currentTime?s.start(a):s.start(n.currentTime,n.currentTime-a)}}};var oo=class{driver;canvas;playback;#e=null;#t=null;constructor(e,t,n){this.driver=e,this.playback=new no(e,n,t),this.canvas=e.compositor.pixi.renderer.canvas}async play(){await this.playback.start()}pause(){this.playback.pause()}seek(e){return this.#e=e,this.#t??=this.#r().finally(()=>this.#t=null)}setFPS(e){this.playback.setFps(qt(e))}get isSeeking(){return this.#t!==null}get isPlaying(){return this.playback.isPlaying}get duration(){return this.playback.duration}get currentTime(){return this.playback.currentTime}update(e){this.playback.update(e)}async#r(){for(;this.#e!==null;){let e=this.#e;this.#e=null;let t=await this.playback.seek(U(e));(await this.driver.composite(t)).close()}}};var mt=class{state;constructor(e){this.state=e}require(e){return e===void 0?void 0:this.state.timeline.items.find(n=>n.id===e)}get timeline(){return this.state.timeline}getId(){return he.toInteger(he.random())}#e(e){this.state.timeline=e(this.state.timeline)}register(e){this.#e(t=>({...t,items:[...t.items,e]}))}textStyle=e=>{let t={id:this.getId(),kind:M.TextStyle,style:e};return this.register(t),t};spatial=e=>{let t={id:this.getId(),kind:M.Spatial,transform:e,enabled:!0};return this.register(t),t};sequence=(...e)=>{let t={id:this.getId(),kind:M.Sequence,childrenIds:e.map(n=>n.id)};return this.register(t),t};stack=(...e)=>{let t={kind:M.Stack,id:this.getId(),childrenIds:e.map(n=>n.id)};return this.register(t),t};video=(e,t)=>{if(!e.hasVideo)throw new Error(`Video clip error: media "${e.datafile.filename}" has no video track.`);let n={kind:M.Video,id:this.getId(),mediaHash:e.datafile.checksum.hash,start:t?.start??0,duration:t?.duration??e.duration};return this.register(n),n};audio=(e,t)=>{if(!e.hasAudio)throw new Error(`Audio clip error: media "${e.datafile.filename}" has no audio track.`);let n={kind:M.Audio,id:this.getId(),mediaHash:e.datafile.checksum.hash,start:t?.start??0,duration:t?.duration??e.duration,gain:t?.gain??1};return this.register(n),n};text=(e,t)=>{let n={id:this.getId(),content:e,kind:M.Text,duration:t?.duration??2e3};return t?.styles&&(n.styleId=this.textStyle(t.styles).id),this.register(n),n};gap=e=>{let t={id:this.getId(),kind:M.Gap,duration:e};return this.register(t),t};transition={crossfade:e=>{let t={id:this.getId(),kind:M.Transition,effect:Kn.Crossfade,duration:e};return this.register(t),t}};transform=e=>{let t=[e?.position?.[0]??0,e?.position?.[1]??0],n=[e?.scale?.[0]??1,e?.scale?.[1]??1],o=e?.rotation??0;return[t,n,o]};addChildren(e,...t){this.#e(n=>(n.items.find(({id:i})=>i===e.id).childrenIds.push(...t.map(i=>i.id)),n))}set=(e,t)=>{this.#e(n=>({...n,items:n.items.map(o=>o.id===e?{...o,...t}:o)}))}};var io=class{#e;#t;constructor(e={}){this.#e=e.chunkFrames??1024,this.#t=e.clamp??!0}async*mix(e){let t=this.#e,n=null,o=null,i=[],s=0,a=0;for await(let c of e){if(o===null)o=c.planes.length,n=c.sampleRate;else{if(c.planes.length!==o)throw new Error("Channel count changed");if(c.sampleRate!==n)throw new Error("Sample rate changed")}let l=Math.round(c.timestamp*n),d=c.planes[0]?.length??0;for(;s+t<=l;)yield this.#r(i,s,o,n),s+=t;i.push({startFrame:l,endFrame:l+d,data:c.planes}),a=Math.max(a,l+d)}if(o!==null&&n!==null)for(;s<a;)yield this.#r(i,s,o,n),s+=t}#r(e,t,n,o){let i=this.#e,s=new Float32Array(n*i),a=t+i;for(let c=0;c<n;c++){let l=c*i,d=s.subarray(l,l+i);for(let u of e){let f=u.data[c];if(!f)continue;let m=Math.max(t,u.startFrame),p=Math.min(a,u.endFrame);if(m>=p)continue;let g=m-t,x=m-u.startFrame,y=p-m;for(let b=0;b<y;b++)d[g+b]+=f[x+b]}if(this.#t)for(let u=0;u<i;u++){let f=d[u];d[u]=f<-1?-1:f>1?1:f}}for(let c=e.length-1;c>=0;c--)e[c].endFrame<=a&&e.splice(c,1);return{planar:s,sampleRate:o,channels:n,frames:i,startFrame:t}}};var Yc=(r,e,t)=>{if(e===t)return r;let n=t/e,o=Math.max(1,Math.round(r.length*n)),i=new Float32Array(o);for(let s=0;s<o;s++){let a=s/n,c=Math.floor(a),l=Math.min(c+1,r.length-1),d=a-c;i[s]=r[c]*(1-d)+r[l]*d}return i},Wa=(r,e)=>{let t=r.numberOfChannels,n=new Array(t),o=0;for(let i=0;i<t;i++){let s=new Float32Array(r.numberOfFrames);r.copyTo(s,{planeIndex:i,format:"f32-planar"});let a=Yc(s,r.sampleRate,e);n[i]=a,o=a.length}return{data:n,frames:o}};var ja=(r,e)=>{if(e!==1)for(let t of r)for(let n=0;n<t.length;n++)t[n]*=e};function $a({timeline:r,resolveMedia:e}){let t=new io,n=Zc(r,e),o=new TransformStream,i=o.writable.getWriter();async function s(){for await(let a of t.mix(n)){let c=new AudioData({format:"f32-planar",sampleRate:a.sampleRate,numberOfFrames:a.frames,numberOfChannels:a.channels,timestamp:Math.round(a.startFrame/a.sampleRate*1e6),data:new Float32Array(a.planar)});await i.write(c)}await i.close()}return s(),o.readable}async function*Zc(r,e){let t=ro(e);for await(let{sample:n,timestamp:o,gain:i}of t.sampleAudio(r,U(0))){let{data:s}=Wa(n,48e3);ja(s,i),yield{planes:s,sampleRate:48e3,timestamp:o},n.close()}}function Ka({timeline:r,fps:e,driver:t,resolveMedia:n}){let o=new TransformStream,i=o.writable.getWriter(),s=new Gt(t,n,r),a=1/e,c=pe(r.rootId,r);async function l(){await Ma({fps:e,duration:c},async(d,u)=>{let f=await s.next(d),m=await t.composite(f),p=new VideoFrame(m,{timestamp:Math.round(u*a*1e6),duration:Math.round(a*1e6)});await i.write(p),m.close()}),await i.close()}return l(),o.readable}function Xa(r){let e=$a({...r}),t=Ka({...r});return r.driver.encode({video:t,audio:e,config:{audio:{codec:"opus",bitrate:128e3},video:{codec:"vp9",bitrate:1e6}}})}var so=class{driver;resources=new Qn;constructor(e){this.driver=e}load=async e=>Object.fromEntries(await Promise.all(Object.entries(e).map(async([t,n])=>[t,await this.resources.store(await n)])));timeline=e=>{let t=new mt({timeline:{format:"timeline",info:"https://omniclip.app/",version:0,items:[],rootId:0}}),n=e(t);return t.timeline.rootId=n.id,t.timeline};playback=async e=>new oo(this.driver,t=>this.resources.require(t).url,e);render=async(e,t=30)=>Xa({timeline:e,fps:qt(t),driver:this.driver,resolveMedia:n=>this.resources.require(n).url})};var ao=class{data;bytes;hash;nickname;constructor(e,t,n,o){this.data=e,this.bytes=t,this.hash=n,this.nickname=o}static async make(e){let t=new Uint8Array(e),n=new Uint8Array(await crypto.subtle.digest("SHA-256",t)),o=_r.fromBytes(n),i=Ri.sigil.fromBytes(n);return new this(e,n,o,i)}};var co=class{url;bytes;blob;filename;checksum;constructor(e,t,n,o,i){this.url=e,this.bytes=t,this.blob=n,this.filename=o,this.checksum=i}static async make(e,t){let n=await e.arrayBuffer(),o=new Uint8Array(n),i=await ao.make(o),s=t??i.nickname,a=URL.createObjectURL(e);return new this(a,o,e,s,i)}static async load(e){}};async function Ya(r,e,t){let n=t.querySelector(".play"),o=t.querySelector(".stop"),i=t.querySelector(".scrub"),s=t.querySelector(".playhead"),a=t.querySelector(".timecode"),c=t.querySelector(".player-canvas"),l=new mt({timeline:r}),d=await e.playback(r);c.replaceChildren(d.canvas),n.disabled=!1,o.disabled=!1,n.addEventListener("click",()=>d.play()),o.addEventListener("click",()=>d.pause()),i.max=String(Math.ceil(d.duration));let u=!1;d.playback.onTick.on(()=>m(d.currentTime,d.duration));let f=(p,g)=>{a.textContent=`${Qa(p)} / ${Qa(g)}`};i.addEventListener("input",async()=>{u=!0;let p=Math.max(0,Math.min(+i.value,d.duration));f(p,d.duration),await d.seek(p)}),i.addEventListener("change",async()=>{u=!1;let p=Math.max(0,Math.min(+i.value,d.duration));await d.seek(p)});let m=(p,g)=>{let x=Math.max(0,Math.min(p,g));u||(i.value=String(Math.round(x)));let y=g?x/g*100:0;s.style.left=`${y}%`,f(x,g)};d.update(l.timeline)}function Qa(r){let e=Math.max(0,r),t=Math.floor(e/1e3),n=Math.floor(t/60),o=t%60,i=Math.floor(e%1e3);return`${n}:${String(o).padStart(2,"0")}.${String(i).padStart(3,"0")}`}async function Ja(r,e,t){let n=t.querySelector(".waveform-canvas"),o=t.querySelector(".width");n.replaceChildren(),n.style.position="relative",n.style.height="96px",n.style.overflow="hidden";let i=await Zn.init(r,e,{tileHeight:96,onChange:()=>s()}),s=()=>{let a=+o.value,c=Za(a,i.duration);i.zoom=c,n.style.width=`${a}px`,n.replaceChildren(...[...i.getTiles().values()].map(l=>(l.canvas.style.position="absolute",l.canvas.style.top="0",l.canvas.style.left=`${l.startTime*Za(a,i.duration)}px`,l.canvas.style.height="100%",l.canvas)))};o.oninput=s,i.range=[0,i.duration]}function Za(r,e){return e>0?r/e:0}async function vi(r,e){let t=new so(r),{videoA:n}=await t.load({videoA:co.make(e)});return{timeline:t.timeline(i=>{let s=i.text("content",{duration:1e3}),a=i.textStyle({fill:"green",fontSize:100});return i.set(s.id,{styleId:a.id}),i.sequence(i.stack(s,i.video(n,{duration:3e3,start:1e3}),i.audio(n,{duration:1e3})),i.gap(500),i.video(n,{duration:7e3,start:5e3}))}),omni:t}}async function ec(r,e){let t=e.querySelector(".range"),n=e.querySelector(".range-view"),o=e.querySelector(".range-size"),i=e.querySelector(".frequency"),s=e.querySelector(".frequency-view"),a=e.querySelector(".filmstrip"),c=1/10,l=.5;a.replaceChildren();let d=await Yn.init(r,{onChange(u){let f=u.sort((m,p)=>m.time-p.time);a.replaceChildren(...f.map(({time:m,canvas:p})=>Jc(m,p.canvas)))},frequency:c,canvasSinkOptions:{width:80,height:50,fit:"fill"}});o.oninput=()=>{l=+o.value;let u=+t.value,f=u+l;d.range=[u,f],n.textContent=`visible time range: [${u}, ${f}]`},t.oninput=()=>{let u=+t.value,f=u+l;d.range=[u,f],n.textContent=`visible time range: [${u}, ${f}]`},i.oninput=()=>{d.frequency=1/+i.value,s.textContent=`frame every ${d.frequency.toFixed(3)} second (${i.value} frames per second)`},d.range=[10,10.5]}function Jc(r,e){let t=document.createElement("div");t.style.position="relative",t.style.display="inline-block",t.style.marginRight="4px",t.appendChild(e);let n=document.createElement("div");return n.textContent=`${r.toFixed(2)}s`,n.style.position="absolute",n.style.top="2px",n.style.right="4px",n.style.fontSize="10px",n.style.color="white",n.style.background="rgba(0,0,0,0.6)",n.style.padding="2px 4px",n.style.borderRadius="4px",n.style.pointerEvents="none",t.appendChild(n),t}function tc(r,e){let t={width:1920,height:1080},n=document.createElement("canvas");n.width=t.width,n.height=t.height;let o=n.getContext("2d");async function i(){let s=r.decodeVideo({source:e,async onFrame(f){let m=await r.composite([{id:0,kind:"image",frame:f},{id:1,kind:"text",content:"omnitool",style:{fontSize:50,fill:"green"}}]);return f.close(),o?.drawImage(m,0,0),m}}),a=r.decodeAudio({source:e}),{readable:c,done:l}=r.encode({video:s.readable,audio:a.readable,config:{audio:{codec:"opus",bitrate:128e3},video:{codec:"vp9",bitrate:1e6}}}),u=await(await window.showSaveFilePicker()).createWritable();await Promise.all([c.pipeTo(u),l])}return{canvas:n,run:i}}var Wt=await $n.setup({workerUrl:new URL("../driver/driver.worker.bundle.min.js",import.meta.url)}),el=document.querySelector("[data-demo='transcode']"),tl=document.querySelector("[data-demo='filmstrip']"),rl=document.querySelector("[data-demo='waveform']"),rc=document.querySelector("[data-demo='playback']"),pt=document.querySelector("[data-demo='export']"),nc=pt.querySelector("[data-action='export']"),lo=null;await Wt.thread.work.hello(),Wt.machina.count===1?console.log("\u2705 driver works"):console.error("\u274C FAIL driver call didn't work");var jt=(r,e)=>{let t=r.querySelector(".progress"),n=r.querySelector(".status");!t||!n||(e==="running"?(t.removeAttribute("value"),n.textContent="running"):e==="done"?(t.value=1,n.textContent="done"):(t.value=0,n.textContent="idle"))},Pi=(r,e)=>{let t=r.querySelector("input[type='file']"),n=r.querySelector("[data-action='run']");n.disabled=!0,t.addEventListener("input",()=>{n.disabled=!t.files?.length}),n.addEventListener("click",async()=>{let o=t.files?.[0];if(o){n.disabled=!0,jt(r,"running");try{await e(o,r),jt(r,"done")}finally{n.disabled=!1}}})};Pi(el,async(r,e)=>{let t=e.querySelector(".demo-preview"),n=tc(Wt,r);t.replaceChildren(n.canvas),await n.run()});Pi(tl,async(r,e)=>{await ec(r,e)});Pi(rl,async(r,e)=>{await Ja(Wt,r,e)});{let r=rc.querySelector("input[type='file']");r.addEventListener("input",async()=>{let e=r.files?.[0];if(!e)return;let{timeline:t,omni:n}=await vi(Wt,e);await Ya(t,n,rc)})}{let r=pt.querySelector("input[type='file']");r.addEventListener("input",async()=>{let e=r.files?.[0];if(!e)return;jt(pt,"running");let{timeline:t,omni:n}=await vi(Wt,e);lo={timeline:t,omni:n},nc.disabled=!1;let o=pt.querySelector(".demo-preview"),i=await n.playback(t);await i.seek(0),o.replaceChildren(i.canvas),jt(pt,"done")})}nc.addEventListener("click",async()=>{lo&&(jt(pt,"running"),await lo.omni.render(lo.timeline),jt(pt,"done"))});
|
|
80
2416
|
/*! Bundled license information:
|
|
81
2417
|
|
|
82
2418
|
mediabunny/dist/modules/src/misc.js:
|
|
83
|
-
mediabunny/dist/modules/src/
|
|
2419
|
+
mediabunny/dist/modules/src/metadata.js:
|
|
84
2420
|
mediabunny/dist/modules/src/codec.js:
|
|
85
2421
|
mediabunny/dist/modules/src/codec-data.js:
|
|
86
|
-
mediabunny/dist/modules/src/isobmff/isobmff-misc.js:
|
|
87
|
-
mediabunny/dist/modules/src/reader.js:
|
|
88
|
-
mediabunny/dist/modules/src/isobmff/isobmff-reader.js:
|
|
89
|
-
mediabunny/dist/modules/src/matroska/ebml.js:
|
|
90
|
-
mediabunny/dist/modules/src/matroska/matroska-misc.js:
|
|
91
|
-
mediabunny/dist/modules/shared/mp3-misc.js:
|
|
92
|
-
mediabunny/dist/modules/src/mp3/mp3-reader.js:
|
|
93
|
-
mediabunny/dist/modules/src/ogg/ogg-misc.js:
|
|
94
|
-
mediabunny/dist/modules/src/ogg/ogg-reader.js:
|
|
95
2422
|
mediabunny/dist/modules/src/demuxer.js:
|
|
96
2423
|
mediabunny/dist/modules/src/custom-coder.js:
|
|
97
2424
|
mediabunny/dist/modules/src/packet.js:
|
|
2425
|
+
mediabunny/dist/modules/src/pcm.js:
|
|
98
2426
|
mediabunny/dist/modules/src/sample.js:
|
|
99
2427
|
mediabunny/dist/modules/src/media-sink.js:
|
|
100
2428
|
mediabunny/dist/modules/src/input-track.js:
|
|
101
|
-
mediabunny/dist/modules/src/
|
|
102
|
-
mediabunny/dist/modules/src/
|
|
2429
|
+
mediabunny/dist/modules/src/isobmff/isobmff-misc.js:
|
|
2430
|
+
mediabunny/dist/modules/src/isobmff/isobmff-reader.js:
|
|
103
2431
|
mediabunny/dist/modules/src/isobmff/isobmff-demuxer.js:
|
|
2432
|
+
mediabunny/dist/modules/src/matroska/ebml.js:
|
|
2433
|
+
mediabunny/dist/modules/src/matroska/matroska-misc.js:
|
|
104
2434
|
mediabunny/dist/modules/src/matroska/matroska-demuxer.js:
|
|
2435
|
+
mediabunny/dist/modules/shared/mp3-misc.js:
|
|
2436
|
+
mediabunny/dist/modules/src/id3.js:
|
|
2437
|
+
mediabunny/dist/modules/src/mp3/mp3-reader.js:
|
|
105
2438
|
mediabunny/dist/modules/src/mp3/mp3-demuxer.js:
|
|
2439
|
+
mediabunny/dist/modules/src/ogg/ogg-misc.js:
|
|
2440
|
+
mediabunny/dist/modules/src/ogg/ogg-reader.js:
|
|
106
2441
|
mediabunny/dist/modules/src/ogg/ogg-demuxer.js:
|
|
2442
|
+
mediabunny/dist/modules/src/wave/wave-demuxer.js:
|
|
107
2443
|
mediabunny/dist/modules/src/adts/adts-reader.js:
|
|
108
2444
|
mediabunny/dist/modules/src/adts/adts-demuxer.js:
|
|
2445
|
+
mediabunny/dist/modules/src/flac/flac-misc.js:
|
|
2446
|
+
mediabunny/dist/modules/src/flac/flac-demuxer.js:
|
|
109
2447
|
mediabunny/dist/modules/src/input-format.js:
|
|
2448
|
+
mediabunny/dist/modules/src/source.js:
|
|
110
2449
|
mediabunny/dist/modules/src/input.js:
|
|
2450
|
+
mediabunny/dist/modules/src/reader.js:
|
|
111
2451
|
mediabunny/dist/modules/src/index.js:
|
|
112
2452
|
(*!
|
|
113
2453
|
* Copyright (c) 2025-present, Vanilagy and contributors
|