@omnimedia/omnitool 1.1.0-8 → 1.1.0-81

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.
Files changed (436) hide show
  1. package/README.md +293 -76
  2. package/package.json +19 -17
  3. package/s/context.ts +0 -7
  4. package/s/demo/demo.bundle.ts +104 -43
  5. package/s/demo/demo.css +244 -14
  6. package/s/demo/routines/export-test.ts +16 -0
  7. package/s/demo/routines/filmstrip-test.ts +22 -18
  8. package/s/demo/routines/load-video.ts +2 -3
  9. package/s/demo/routines/playback-test.ts +61 -0
  10. package/s/demo/routines/timeline-setup.ts +50 -0
  11. package/s/demo/routines/transcode-test.ts +19 -5
  12. package/s/demo/routines/transitions-test.ts +2 -2
  13. package/s/demo/routines/waveform-test.ts +35 -8
  14. package/s/driver/driver-worker.ts +9 -0
  15. package/s/driver/driver.test.ts +1 -1
  16. package/s/driver/driver.ts +43 -42
  17. package/s/driver/fns/schematic.ts +26 -6
  18. package/s/driver/fns/work.ts +65 -189
  19. package/s/driver/parts/compositor.ts +316 -0
  20. package/s/driver/parts/machina.ts +19 -20
  21. package/s/driver/utils/find-pixi-filter.ts +24 -0
  22. package/s/index.html.ts +103 -25
  23. package/s/index.ts +1 -0
  24. package/s/tests.bundle.ts +11 -0
  25. package/s/tests.html.ts +28 -0
  26. package/s/timeline/index.ts +8 -2
  27. package/s/timeline/parts/animations.ts +56 -0
  28. package/s/timeline/parts/filmstrip.ts +43 -16
  29. package/s/timeline/parts/filters.ts +453 -0
  30. package/s/timeline/parts/item.ts +70 -7
  31. package/s/timeline/parts/media.ts +12 -2
  32. package/s/timeline/parts/resource-pool.ts +8 -5
  33. package/s/timeline/parts/resource.ts +3 -0
  34. package/s/timeline/parts/waveform/parts/collect.ts +72 -0
  35. package/s/timeline/parts/waveform/parts/render.ts +45 -0
  36. package/s/timeline/parts/waveform/parts/types.ts +24 -0
  37. package/s/timeline/parts/waveform/waveform.ts +161 -0
  38. package/s/timeline/renderers/export/parts/audio-gain.ts +17 -0
  39. package/s/timeline/renderers/export/parts/audio-mix.ts +133 -0
  40. package/s/timeline/renderers/export/parts/cursor.ts +129 -0
  41. package/s/timeline/renderers/export/parts/produce-audio.ts +64 -0
  42. package/s/timeline/renderers/export/parts/produce-video.ts +49 -0
  43. package/s/timeline/renderers/export/parts/resamplers.ts +48 -0
  44. package/s/timeline/renderers/export/produce.ts +28 -0
  45. package/s/timeline/renderers/parts/handy.ts +377 -0
  46. package/s/timeline/renderers/parts/samplers/audio/parts/find.ts +19 -0
  47. package/s/timeline/renderers/parts/samplers/audio/parts/init.ts +60 -0
  48. package/s/timeline/renderers/parts/samplers/audio/parts/sink.ts +38 -0
  49. package/s/timeline/renderers/parts/samplers/audio/parts/types.ts +16 -0
  50. package/s/timeline/renderers/parts/samplers/audio/sampler.ts +35 -0
  51. package/s/timeline/renderers/parts/samplers/visual/parts/defaults.ts +16 -0
  52. package/s/timeline/renderers/parts/samplers/visual/parts/sample.ts +69 -0
  53. package/s/timeline/renderers/parts/samplers/visual/parts/sequence.ts +111 -0
  54. package/s/timeline/renderers/parts/samplers/visual/parts/sink.ts +38 -0
  55. package/s/timeline/renderers/parts/samplers/visual/parts/transition.ts +28 -0
  56. package/s/timeline/renderers/parts/samplers/visual/parts/types.ts +10 -0
  57. package/s/timeline/renderers/parts/samplers/visual/sampler.ts +28 -0
  58. package/s/timeline/renderers/parts/schedulers.ts +96 -0
  59. package/s/timeline/renderers/player/parts/playback.ts +159 -0
  60. package/s/timeline/renderers/player/player.ts +77 -0
  61. package/s/timeline/renderers/renderers.test.ts +403 -0
  62. package/s/timeline/sugar/helpers.ts +190 -0
  63. package/s/timeline/sugar/o.ts +271 -59
  64. package/s/timeline/sugar/omni.test.ts +210 -0
  65. package/s/timeline/sugar/omni.ts +35 -12
  66. package/s/timeline/types.ts +28 -3
  67. package/s/timeline/utils/anim.ts +72 -0
  68. package/s/timeline/utils/checksum.ts +3 -1
  69. package/s/timeline/utils/datafile.ts +15 -4
  70. package/s/timeline/utils/dummy-data.ts +3 -3
  71. package/s/timeline/utils/matrix.ts +21 -0
  72. package/s/timeline/utils/terps.ts +81 -0
  73. package/s/units/fps.ts +8 -0
  74. package/s/units/ms.ts +8 -0
  75. package/s/units/seconds.ts +8 -0
  76. package/x/WebGLRenderer-4CHIZDHY.js +2 -0
  77. package/x/WebGLRenderer-4CHIZDHY.js.map +7 -0
  78. package/x/WebGPURenderer-O6WXU2QR.js +2 -0
  79. package/x/WebGPURenderer-O6WXU2QR.js.map +7 -0
  80. package/x/browserAll-WNIOTNNP.js +2 -0
  81. package/x/browserAll-WNIOTNNP.js.map +7 -0
  82. package/x/chunk-23FOBGX6.js +2 -0
  83. package/x/chunk-23FOBGX6.js.map +7 -0
  84. package/x/chunk-73XOWA4F.js +393 -0
  85. package/x/chunk-73XOWA4F.js.map +7 -0
  86. package/x/chunk-IAWJKNX5.js +42 -0
  87. package/x/chunk-IAWJKNX5.js.map +7 -0
  88. package/x/chunk-KCMVLWBS.js +157 -0
  89. package/x/chunk-KCMVLWBS.js.map +7 -0
  90. package/x/chunk-MR32SQ27.js +2 -0
  91. package/x/chunk-MR32SQ27.js.map +7 -0
  92. package/x/chunk-VCUJJYRJ.js +327 -0
  93. package/x/chunk-VCUJJYRJ.js.map +7 -0
  94. package/x/chunk-XNIZ4L5W.js +269 -0
  95. package/x/chunk-XNIZ4L5W.js.map +7 -0
  96. package/x/chunk-ZLGNQFUI.js +15 -0
  97. package/x/chunk-ZLGNQFUI.js.map +7 -0
  98. package/x/context.d.ts +1 -4
  99. package/x/context.js +1 -5
  100. package/x/context.js.map +1 -1
  101. package/x/demo/WebGLRenderer-RSJAHIG2.js +2 -0
  102. package/x/demo/WebGLRenderer-RSJAHIG2.js.map +7 -0
  103. package/x/demo/WebGPURenderer-MGFAJCYY.js +2 -0
  104. package/x/demo/WebGPURenderer-MGFAJCYY.js.map +7 -0
  105. package/x/demo/browserAll-PTRBXBRP.js +2 -0
  106. package/x/demo/browserAll-PTRBXBRP.js.map +7 -0
  107. package/x/demo/chunk-CUYOGHWU.js +42 -0
  108. package/x/demo/chunk-CUYOGHWU.js.map +7 -0
  109. package/x/demo/chunk-DGTDNJ7W.js +2 -0
  110. package/x/demo/chunk-DGTDNJ7W.js.map +7 -0
  111. package/x/demo/chunk-FZ5BYF63.js +15 -0
  112. package/x/demo/chunk-FZ5BYF63.js.map +7 -0
  113. package/x/demo/chunk-KWN4NNES.js +269 -0
  114. package/x/demo/chunk-KWN4NNES.js.map +7 -0
  115. package/x/demo/chunk-OJ3FPXW7.js +157 -0
  116. package/x/demo/chunk-OJ3FPXW7.js.map +7 -0
  117. package/x/demo/chunk-PSLUOGTZ.js +393 -0
  118. package/x/demo/chunk-PSLUOGTZ.js.map +7 -0
  119. package/x/demo/chunk-VLCVEIFU.js +327 -0
  120. package/x/demo/chunk-VLCVEIFU.js.map +7 -0
  121. package/x/demo/chunk-ZWCPT5FR.js +2 -0
  122. package/x/demo/chunk-ZWCPT5FR.js.map +7 -0
  123. package/x/demo/demo.bundle.js +94 -40
  124. package/x/demo/demo.bundle.js.map +1 -1
  125. package/x/demo/demo.bundle.min.js +7340 -90
  126. package/x/demo/demo.bundle.min.js.map +4 -4
  127. package/x/demo/demo.css +244 -14
  128. package/x/demo/routines/export-test.d.ts +2 -0
  129. package/x/demo/routines/export-test.js +10 -0
  130. package/x/demo/routines/export-test.js.map +1 -0
  131. package/x/demo/routines/filmstrip-test.d.ts +1 -1
  132. package/x/demo/routines/filmstrip-test.js +20 -17
  133. package/x/demo/routines/filmstrip-test.js.map +1 -1
  134. package/x/demo/routines/load-video.d.ts +1 -1
  135. package/x/demo/routines/load-video.js +1 -2
  136. package/x/demo/routines/load-video.js.map +1 -1
  137. package/x/demo/routines/playback-test.d.ts +2 -0
  138. package/x/demo/routines/playback-test.js +51 -0
  139. package/x/demo/routines/playback-test.js.map +1 -0
  140. package/x/demo/routines/timeline-setup.d.ts +6 -0
  141. package/x/demo/routines/timeline-setup.js +32 -0
  142. package/x/demo/routines/timeline-setup.js.map +1 -0
  143. package/x/demo/routines/transcode-test.js +15 -5
  144. package/x/demo/routines/transcode-test.js.map +1 -1
  145. package/x/demo/routines/transitions-test.js +2 -2
  146. package/x/demo/routines/transitions-test.js.map +1 -1
  147. package/x/demo/routines/waveform-test.d.ts +2 -1
  148. package/x/demo/routines/waveform-test.js +29 -8
  149. package/x/demo/routines/waveform-test.js.map +1 -1
  150. package/x/demo/webworkerAll-JENRT6BT.js +2 -0
  151. package/x/demo/webworkerAll-JENRT6BT.js.map +7 -0
  152. package/x/driver/driver-worker.d.ts +1 -0
  153. package/x/driver/driver-worker.js +6 -0
  154. package/x/driver/driver-worker.js.map +1 -0
  155. package/x/driver/driver.d.ts +25 -8
  156. package/x/driver/driver.js +43 -39
  157. package/x/driver/driver.js.map +1 -1
  158. package/x/driver/driver.test.js +1 -1
  159. package/x/driver/driver.test.js.map +1 -1
  160. package/x/driver/driver.worker.bundle.min.js +117 -3506
  161. package/x/driver/driver.worker.bundle.min.js.map +4 -4
  162. package/x/driver/fns/host.d.ts +3 -2
  163. package/x/driver/fns/schematic.d.ts +25 -4
  164. package/x/driver/fns/work.d.ts +4 -4
  165. package/x/driver/fns/work.js +55 -155
  166. package/x/driver/fns/work.js.map +1 -1
  167. package/x/driver/parts/compositor.d.ts +39 -0
  168. package/x/driver/parts/compositor.js +261 -0
  169. package/x/driver/parts/compositor.js.map +1 -0
  170. package/x/driver/parts/machina.d.ts +0 -20
  171. package/x/driver/parts/machina.js +6 -10
  172. package/x/driver/parts/machina.js.map +1 -1
  173. package/x/driver/utils/find-pixi-filter.d.ts +5 -0
  174. package/x/driver/utils/find-pixi-filter.js +13 -0
  175. package/x/driver/utils/find-pixi-filter.js.map +1 -0
  176. package/x/features/speech/transcribe/parts/prep-audio.d.ts +1 -1
  177. package/x/features/speech/transcribe/worker.bundle.min.js +899 -899
  178. package/x/features/speech/transcribe/worker.bundle.min.js.map +4 -4
  179. package/x/index.d.ts +1 -0
  180. package/x/index.html +347 -38
  181. package/x/index.html.js +103 -24
  182. package/x/index.html.js.map +1 -1
  183. package/x/index.js +1 -0
  184. package/x/index.js.map +1 -1
  185. package/x/tests.bundle.js +8 -0
  186. package/x/tests.bundle.js.map +1 -0
  187. package/x/tests.bundle.min.js +7374 -0
  188. package/x/tests.bundle.min.js.map +7 -0
  189. package/x/tests.html +316 -0
  190. package/x/tests.html.d.ts +2 -0
  191. package/x/tests.html.js +22 -0
  192. package/x/tests.html.js.map +1 -0
  193. package/x/timeline/index.d.ts +7 -1
  194. package/x/timeline/index.js +7 -1
  195. package/x/timeline/index.js.map +1 -1
  196. package/x/timeline/parts/animations.d.ts +105 -0
  197. package/x/timeline/parts/animations.js +28 -0
  198. package/x/timeline/parts/animations.js.map +1 -0
  199. package/x/timeline/parts/filmstrip.d.ts +4 -3
  200. package/x/timeline/parts/filmstrip.js +29 -10
  201. package/x/timeline/parts/filmstrip.js.map +1 -1
  202. package/x/timeline/parts/filters.d.ts +108 -0
  203. package/x/timeline/parts/filters.js +340 -0
  204. package/x/timeline/parts/filters.js.map +1 -0
  205. package/x/timeline/parts/item.d.ts +56 -4
  206. package/x/timeline/parts/item.js +5 -1
  207. package/x/timeline/parts/item.js.map +1 -1
  208. package/x/timeline/parts/media.d.ts +2 -0
  209. package/x/timeline/parts/media.js +11 -2
  210. package/x/timeline/parts/media.js.map +1 -1
  211. package/x/timeline/parts/resource-pool.d.ts +3 -0
  212. package/x/timeline/parts/resource-pool.js +7 -4
  213. package/x/timeline/parts/resource-pool.js.map +1 -1
  214. package/x/timeline/parts/resource.d.ts +3 -0
  215. package/x/timeline/parts/waveform/parts/collect.d.ts +11 -0
  216. package/x/timeline/parts/waveform/parts/collect.js +56 -0
  217. package/x/timeline/parts/waveform/parts/collect.js.map +1 -0
  218. package/x/timeline/parts/waveform/parts/render.d.ts +5 -0
  219. package/x/timeline/parts/waveform/parts/render.js +29 -0
  220. package/x/timeline/parts/waveform/parts/render.js.map +1 -0
  221. package/x/timeline/parts/waveform/parts/types.d.ts +21 -0
  222. package/x/timeline/parts/waveform/parts/types.js.map +1 -0
  223. package/x/timeline/parts/waveform/waveform.d.ts +19 -0
  224. package/x/timeline/parts/waveform/waveform.js +133 -0
  225. package/x/timeline/parts/waveform/waveform.js.map +1 -0
  226. package/x/timeline/renderers/export/parts/audio-gain.d.ts +1 -0
  227. package/x/timeline/renderers/export/parts/audio-gain.js +13 -0
  228. package/x/timeline/renderers/export/parts/audio-gain.js.map +1 -0
  229. package/x/timeline/renderers/export/parts/audio-mix.d.ts +21 -0
  230. package/x/timeline/renderers/export/parts/audio-mix.js +89 -0
  231. package/x/timeline/renderers/export/parts/audio-mix.js.map +1 -0
  232. package/x/timeline/renderers/export/parts/cursor.d.ts +18 -0
  233. package/x/timeline/renderers/export/parts/cursor.js +99 -0
  234. package/x/timeline/renderers/export/parts/cursor.js.map +1 -0
  235. package/x/timeline/renderers/export/parts/produce-audio.d.ts +6 -0
  236. package/x/timeline/renderers/export/parts/produce-audio.js +41 -0
  237. package/x/timeline/renderers/export/parts/produce-audio.js.map +1 -0
  238. package/x/timeline/renderers/export/parts/produce-video.d.ts +10 -0
  239. package/x/timeline/renderers/export/parts/produce-video.js +26 -0
  240. package/x/timeline/renderers/export/parts/produce-video.js.map +1 -0
  241. package/x/timeline/renderers/export/parts/resamplers.d.ts +12 -0
  242. package/x/timeline/renderers/export/parts/resamplers.js +29 -0
  243. package/x/timeline/renderers/export/parts/resamplers.js.map +1 -0
  244. package/x/timeline/renderers/export/produce.d.ts +13 -0
  245. package/x/timeline/renderers/export/produce.js +15 -0
  246. package/x/timeline/renderers/export/produce.js.map +1 -0
  247. package/x/timeline/renderers/parts/handy.d.ts +36 -0
  248. package/x/timeline/renderers/parts/handy.js +221 -0
  249. package/x/timeline/renderers/parts/handy.js.map +1 -0
  250. package/x/timeline/renderers/parts/samplers/audio/parts/find.d.ts +6 -0
  251. package/x/timeline/renderers/parts/samplers/audio/parts/find.js +15 -0
  252. package/x/timeline/renderers/parts/samplers/audio/parts/find.js.map +1 -0
  253. package/x/timeline/renderers/parts/samplers/audio/parts/init.d.ts +5 -0
  254. package/x/timeline/renderers/parts/samplers/audio/parts/init.js +40 -0
  255. package/x/timeline/renderers/parts/samplers/audio/parts/init.js.map +1 -0
  256. package/x/timeline/renderers/parts/samplers/audio/parts/sink.d.ts +8 -0
  257. package/x/timeline/renderers/parts/samplers/audio/parts/sink.js +24 -0
  258. package/x/timeline/renderers/parts/samplers/audio/parts/sink.js.map +1 -0
  259. package/x/timeline/renderers/parts/samplers/audio/parts/types.d.ts +14 -0
  260. package/x/timeline/renderers/parts/samplers/audio/parts/types.js +2 -0
  261. package/x/timeline/renderers/parts/samplers/audio/parts/types.js.map +1 -0
  262. package/x/timeline/renderers/parts/samplers/audio/sampler.d.ts +11 -0
  263. package/x/timeline/renderers/parts/samplers/audio/sampler.js +22 -0
  264. package/x/timeline/renderers/parts/samplers/audio/sampler.js.map +1 -0
  265. package/x/timeline/renderers/parts/samplers/visual/parts/defaults.d.ts +5 -0
  266. package/x/timeline/renderers/parts/samplers/visual/parts/defaults.js +10 -0
  267. package/x/timeline/renderers/parts/samplers/visual/parts/defaults.js.map +1 -0
  268. package/x/timeline/renderers/parts/samplers/visual/parts/sample.d.ts +6 -0
  269. package/x/timeline/renderers/parts/samplers/visual/parts/sample.js +48 -0
  270. package/x/timeline/renderers/parts/samplers/visual/parts/sample.js.map +1 -0
  271. package/x/timeline/renderers/parts/samplers/visual/parts/sequence.d.ts +6 -0
  272. package/x/timeline/renderers/parts/samplers/visual/parts/sequence.js +75 -0
  273. package/x/timeline/renderers/parts/samplers/visual/parts/sequence.js.map +1 -0
  274. package/x/timeline/renderers/parts/samplers/visual/parts/sink.d.ts +8 -0
  275. package/x/timeline/renderers/parts/samplers/visual/parts/sink.js +24 -0
  276. package/x/timeline/renderers/parts/samplers/visual/parts/sink.js.map +1 -0
  277. package/x/timeline/renderers/parts/samplers/visual/parts/transition.d.ts +3 -0
  278. package/x/timeline/renderers/parts/samplers/visual/parts/transition.js +18 -0
  279. package/x/timeline/renderers/parts/samplers/visual/parts/transition.js.map +1 -0
  280. package/x/timeline/renderers/parts/samplers/visual/parts/types.d.ts +8 -0
  281. package/x/timeline/renderers/parts/samplers/visual/parts/types.js +2 -0
  282. package/x/timeline/renderers/parts/samplers/visual/parts/types.js.map +1 -0
  283. package/x/timeline/renderers/parts/samplers/visual/sampler.d.ts +7 -0
  284. package/x/timeline/renderers/parts/samplers/visual/sampler.js +17 -0
  285. package/x/timeline/renderers/parts/samplers/visual/sampler.js.map +1 -0
  286. package/x/timeline/renderers/parts/schedulers.d.ts +17 -0
  287. package/x/timeline/renderers/parts/schedulers.js +64 -0
  288. package/x/timeline/renderers/parts/schedulers.js.map +1 -0
  289. package/x/timeline/renderers/player/parts/playback.d.ts +36 -0
  290. package/x/timeline/renderers/player/parts/playback.js +113 -0
  291. package/x/timeline/renderers/player/parts/playback.js.map +1 -0
  292. package/x/timeline/renderers/player/player.d.ts +25 -0
  293. package/x/timeline/renderers/player/player.js +56 -0
  294. package/x/timeline/renderers/player/player.js.map +1 -0
  295. package/x/timeline/renderers/renderers.test.d.ts +33 -0
  296. package/x/timeline/renderers/renderers.test.js +321 -0
  297. package/x/timeline/renderers/renderers.test.js.map +1 -0
  298. package/x/timeline/sugar/helpers.d.ts +56 -0
  299. package/x/timeline/sugar/helpers.js +104 -0
  300. package/x/timeline/sugar/helpers.js.map +1 -0
  301. package/x/timeline/sugar/o.d.ts +48 -14
  302. package/x/timeline/sugar/o.js +213 -54
  303. package/x/timeline/sugar/o.js.map +1 -1
  304. package/x/timeline/sugar/omni.d.ts +11 -6
  305. package/x/timeline/sugar/omni.js +28 -8
  306. package/x/timeline/sugar/omni.js.map +1 -1
  307. package/x/timeline/sugar/omni.test.d.ts +27 -0
  308. package/x/timeline/sugar/omni.test.js +128 -0
  309. package/x/timeline/sugar/omni.test.js.map +1 -0
  310. package/x/timeline/types.d.ts +12 -2
  311. package/x/timeline/utils/anim.d.ts +5 -0
  312. package/x/timeline/utils/anim.js +44 -0
  313. package/x/timeline/utils/anim.js.map +1 -0
  314. package/x/timeline/utils/checksum.d.ts +3 -2
  315. package/x/timeline/utils/checksum.js.map +1 -1
  316. package/x/timeline/utils/datafile.d.ts +5 -3
  317. package/x/timeline/utils/datafile.js +18 -5
  318. package/x/timeline/utils/datafile.js.map +1 -1
  319. package/x/timeline/utils/dummy-data.d.ts +1 -2
  320. package/x/timeline/utils/dummy-data.js +4 -2
  321. package/x/timeline/utils/dummy-data.js.map +1 -1
  322. package/x/timeline/utils/matrix.d.ts +9 -0
  323. package/x/timeline/utils/matrix.js +10 -0
  324. package/x/timeline/utils/matrix.js.map +1 -1
  325. package/x/timeline/utils/terps.d.ts +11 -0
  326. package/x/timeline/utils/terps.js +57 -0
  327. package/x/timeline/utils/terps.js.map +1 -0
  328. package/x/units/fps.d.ts +6 -0
  329. package/x/units/fps.js +2 -0
  330. package/x/units/fps.js.map +1 -0
  331. package/x/units/ms.d.ts +6 -0
  332. package/x/units/ms.js +2 -0
  333. package/x/units/ms.js.map +1 -0
  334. package/x/units/seconds.d.ts +6 -0
  335. package/x/units/seconds.js +2 -0
  336. package/x/units/seconds.js.map +1 -0
  337. package/x/webworkerAll-RLCTMSDD.js +2 -0
  338. package/x/webworkerAll-RLCTMSDD.js.map +7 -0
  339. package/s/tests.test.ts +0 -8
  340. package/s/timeline/parts/compositor/export.ts +0 -77
  341. package/s/timeline/parts/compositor/parts/html-tree.ts +0 -37
  342. package/s/timeline/parts/compositor/parts/schedulers.ts +0 -85
  343. package/s/timeline/parts/compositor/parts/tree-builder.ts +0 -184
  344. package/s/timeline/parts/compositor/parts/webcodecs-tree.ts +0 -30
  345. package/s/timeline/parts/compositor/playback.ts +0 -81
  346. package/s/timeline/parts/compositor/samplers/html.ts +0 -115
  347. package/s/timeline/parts/compositor/samplers/webcodecs.ts +0 -60
  348. package/s/timeline/parts/waveform.ts +0 -62
  349. package/s/timeline/sugar/builders.ts +0 -102
  350. package/s/timeline/sugar/omni-test.ts +0 -38
  351. package/s/timeline/timeline.ts +0 -22
  352. package/s/timeline/utils/audio-stream.ts +0 -15
  353. package/s/timeline/utils/video-cursor.ts +0 -40
  354. package/s/tools/common/loader.ts +0 -26
  355. package/s/tools/common/transformer-pipeline.ts +0 -26
  356. package/s/tools/speech-recognition/common/model.ts +0 -26
  357. package/s/tools/speech-recognition/whisper/fns/host.ts +0 -25
  358. package/s/tools/speech-recognition/whisper/fns/schematic.ts +0 -23
  359. package/s/tools/speech-recognition/whisper/fns/work.ts +0 -91
  360. package/s/tools/speech-recognition/whisper/parts/types.ts +0 -38
  361. package/s/tools/speech-recognition/whisper/parts/worker.bundle.ts +0 -7
  362. package/s/tools/speech-recognition/whisper/tool.ts +0 -70
  363. package/x/tests.test.js +0 -6
  364. package/x/tests.test.js.map +0 -1
  365. package/x/timeline/parts/compositor/export.d.ts +0 -9
  366. package/x/timeline/parts/compositor/export.js +0 -64
  367. package/x/timeline/parts/compositor/export.js.map +0 -1
  368. package/x/timeline/parts/compositor/parts/html-tree.d.ts +0 -3
  369. package/x/timeline/parts/compositor/parts/html-tree.js +0 -40
  370. package/x/timeline/parts/compositor/parts/html-tree.js.map +0 -1
  371. package/x/timeline/parts/compositor/parts/schedulers.d.ts +0 -15
  372. package/x/timeline/parts/compositor/parts/schedulers.js +0 -64
  373. package/x/timeline/parts/compositor/parts/schedulers.js.map +0 -1
  374. package/x/timeline/parts/compositor/parts/tree-builder.d.ts +0 -37
  375. package/x/timeline/parts/compositor/parts/tree-builder.js +0 -147
  376. package/x/timeline/parts/compositor/parts/tree-builder.js.map +0 -1
  377. package/x/timeline/parts/compositor/parts/webcodecs-tree.d.ts +0 -3
  378. package/x/timeline/parts/compositor/parts/webcodecs-tree.js +0 -28
  379. package/x/timeline/parts/compositor/parts/webcodecs-tree.js.map +0 -1
  380. package/x/timeline/parts/compositor/playback.d.ts +0 -19
  381. package/x/timeline/parts/compositor/playback.js +0 -71
  382. package/x/timeline/parts/compositor/playback.js.map +0 -1
  383. package/x/timeline/parts/compositor/samplers/html.d.ts +0 -3
  384. package/x/timeline/parts/compositor/samplers/html.js +0 -106
  385. package/x/timeline/parts/compositor/samplers/html.js.map +0 -1
  386. package/x/timeline/parts/compositor/samplers/webcodecs.d.ts +0 -2
  387. package/x/timeline/parts/compositor/samplers/webcodecs.js +0 -55
  388. package/x/timeline/parts/compositor/samplers/webcodecs.js.map +0 -1
  389. package/x/timeline/parts/waveform.d.ts +0 -8
  390. package/x/timeline/parts/waveform.js +0 -51
  391. package/x/timeline/parts/waveform.js.map +0 -1
  392. package/x/timeline/sugar/builders.d.ts +0 -96
  393. package/x/timeline/sugar/builders.js +0 -108
  394. package/x/timeline/sugar/builders.js.map +0 -1
  395. package/x/timeline/sugar/omni-test.d.ts +0 -1
  396. package/x/timeline/sugar/omni-test.js +0 -22
  397. package/x/timeline/sugar/omni-test.js.map +0 -1
  398. package/x/timeline/timeline.d.ts +0 -9
  399. package/x/timeline/timeline.js +0 -22
  400. package/x/timeline/timeline.js.map +0 -1
  401. package/x/timeline/utils/audio-stream.d.ts +0 -6
  402. package/x/timeline/utils/audio-stream.js +0 -17
  403. package/x/timeline/utils/audio-stream.js.map +0 -1
  404. package/x/timeline/utils/video-cursor.d.ts +0 -10
  405. package/x/timeline/utils/video-cursor.js +0 -36
  406. package/x/timeline/utils/video-cursor.js.map +0 -1
  407. package/x/tools/common/loader.d.ts +0 -19
  408. package/x/tools/common/loader.js +0 -18
  409. package/x/tools/common/loader.js.map +0 -1
  410. package/x/tools/common/transformer-pipeline.d.ts +0 -8
  411. package/x/tools/common/transformer-pipeline.js +0 -24
  412. package/x/tools/common/transformer-pipeline.js.map +0 -1
  413. package/x/tools/speech-recognition/common/model.d.ts +0 -14
  414. package/x/tools/speech-recognition/common/model.js +0 -16
  415. package/x/tools/speech-recognition/common/model.js.map +0 -1
  416. package/x/tools/speech-recognition/whisper/fns/host.d.ts +0 -13
  417. package/x/tools/speech-recognition/whisper/fns/host.js +0 -19
  418. package/x/tools/speech-recognition/whisper/fns/host.js.map +0 -1
  419. package/x/tools/speech-recognition/whisper/fns/schematic.d.ts +0 -19
  420. package/x/tools/speech-recognition/whisper/fns/schematic.js +0 -2
  421. package/x/tools/speech-recognition/whisper/fns/schematic.js.map +0 -1
  422. package/x/tools/speech-recognition/whisper/fns/work.d.ts +0 -12
  423. package/x/tools/speech-recognition/whisper/fns/work.js +0 -74
  424. package/x/tools/speech-recognition/whisper/fns/work.js.map +0 -1
  425. package/x/tools/speech-recognition/whisper/parts/types.d.ts +0 -31
  426. package/x/tools/speech-recognition/whisper/parts/types.js.map +0 -1
  427. package/x/tools/speech-recognition/whisper/parts/worker.bundle.d.ts +0 -1
  428. package/x/tools/speech-recognition/whisper/parts/worker.bundle.js +0 -4
  429. package/x/tools/speech-recognition/whisper/parts/worker.bundle.js.map +0 -1
  430. package/x/tools/speech-recognition/whisper/parts/worker.bundle.min.js +0 -8
  431. package/x/tools/speech-recognition/whisper/parts/worker.bundle.min.js.map +0 -7
  432. package/x/tools/speech-recognition/whisper/tool.d.ts +0 -12
  433. package/x/tools/speech-recognition/whisper/tool.js +0 -63
  434. package/x/tools/speech-recognition/whisper/tool.js.map +0 -1
  435. /package/x/{tests.test.d.ts → tests.bundle.d.ts} +0 -0
  436. /package/x/{tools/speech-recognition/whisper → timeline/parts/waveform}/parts/types.js +0 -0
@@ -1,106 +1,296 @@
1
+ import {hex} from "@e280/stz"
2
+ import {TextStyleOptions} from "pixi.js"
1
3
 
2
- import {MapG} from "@e280/stz"
3
- import {Id} from "../parts/basics.js"
4
4
  import {Media} from "../parts/media.js"
5
- import {Effect, Item, Kind} from "../parts/item.js"
6
- import {Transform, TransformOptions, Vec2} from "../types.js"
7
- import {Video, Gap, Sequence, Stack, Text, TimelineItem, Spatial, Audio, Transition} from "./builders.js"
5
+ import {Id, TimelineFile} from "../parts/basics.js"
6
+ import {FilterAction, FilterActions} from "../parts/filters.js"
7
+ import {filters, FilterParams, FilterType} from "../parts/filters.js"
8
+ import {visualAnimations} from "../parts/animations.js"
9
+ import {Crop, Effect, FilterableItem, Item, Kind, VisualAnimatableItem} from "../parts/item.js"
10
+ import {Anim, AnimateAction, Interpolation, Keyframes, TrackTransform, Transform, TransformOptions, Vec2, VisualAnimations} from "../types.js"
11
+
12
+ type VisualAnimateActions = {
13
+ [TKey in keyof VisualAnimations]-?: AnimateAction
14
+ }
8
15
 
9
16
  export class O {
10
- #nextId = 0
11
- #items = new MapG<Id, TimelineItem>()
17
+ constructor(public state: {timeline: TimelineFile}) {}
12
18
 
13
- #getId() {
14
- return this.#nextId++
19
+ require<T extends Item.Any>(id: Id | undefined) {
20
+ if (id === undefined)
21
+ return undefined
22
+ const item = this.state.timeline.items.find(item => item.id === id)
23
+ return item as T | undefined
15
24
  }
16
25
 
17
- register(item: TimelineItem) {
18
- if (!this.#items.has(item.id))
19
- this.#items.set(item.id, item)
20
- return item.id
26
+ get timeline() {
27
+ return this.state.timeline
21
28
  }
22
29
 
23
- get items() {
24
- return [...this.#items.values()]
30
+ getId() {
31
+ return hex.toInteger(hex.random())
25
32
  }
26
33
 
27
- get itemsMap() {
28
- return this.#items
34
+ #mutate(fn: (project: TimelineFile) => TimelineFile) {
35
+ this.state.timeline = fn(this.state.timeline)
36
+ }
37
+
38
+ register(item: Item.Any) {
39
+ this.#mutate(state => ({
40
+ ...state,
41
+ items: [...state.items, item]
42
+ }))
29
43
  }
30
44
 
31
- spatial = (transform: Transform) => {
45
+ textStyle = (style: TextStyleOptions): Item.TextStyle => {
46
+ const item = {
47
+ id: this.getId(),
48
+ kind: Kind.TextStyle,
49
+ style
50
+ } as Item.TextStyle
51
+ this.register(item)
52
+ return item
53
+ }
54
+
55
+ spatial = (transform?: Transform, crop?: Crop): Item.Spatial => {
32
56
  const item: Item.Spatial = {
33
- id: this.#getId(),
57
+ id: this.getId(),
34
58
  kind: Kind.Spatial,
35
- transform
59
+ transform: transform ?? this.transform(),
60
+ crop,
61
+ enabled: true
36
62
  }
37
- const spatial = new Spatial(item)
38
- this.register(spatial)
39
- return spatial
63
+ this.register(item)
64
+ return item
40
65
  }
41
66
 
42
- sequence = (...items: TimelineItem[]) => new Sequence(this, {
43
- id: this.#getId(),
44
- kind: Kind.Sequence,
45
- childrenIds: items.map((item) => this.register(item))
46
- })
67
+ animatedSpatial = (anim: Anim<TrackTransform>, crop?: Crop): Item.AnimatedSpatial => {
68
+ const item: Item.AnimatedSpatial = {
69
+ id: this.getId(),
70
+ kind: Kind.AnimatedSpatial,
71
+ anim,
72
+ crop,
73
+ enabled: true
74
+ }
75
+ this.register(item)
76
+ return item
77
+ }
78
+
79
+ #registerAnimation = (anims: VisualAnimations): Item.Animation => {
80
+ const item: Item.Animation = {
81
+ id: this.getId(),
82
+ kind: Kind.Animation,
83
+ anims,
84
+ enabled: true
85
+ }
86
+ this.register(item)
87
+ return item
88
+ }
89
+
90
+ anim = {
91
+ scalar: (terp: Interpolation, track: Keyframes): Anim<Keyframes> => ({terp, track}),
92
+
93
+ vec2: (terp: Interpolation, source: Keyframes<Vec2>) => {
94
+ const track = {x: [] as Keyframes, y: [] as Keyframes}
95
+
96
+ for (const [time, [x, y]] of source) {
97
+ track.x.push([time, x])
98
+ track.y.push([time, y])
99
+ }
100
+
101
+ return {terp, track}
102
+ },
103
+
104
+ transform: (terp: Interpolation, source: Keyframes<Transform>): Anim<TrackTransform> => {
105
+ const track: TrackTransform = {
106
+ position: {x: [], y: []},
107
+ scale: {x: [], y: []},
108
+ rotation: [],
109
+ }
110
+
111
+ for (const [time, [position, scale, rotation]] of source) {
112
+ track.position.x.push([time, position[0]])
113
+ track.position.y.push([time, position[1]])
114
+ track.scale.x.push([time, scale[0]])
115
+ track.scale.y.push([time, scale[1]])
116
+ track.rotation.push([time, rotation])
117
+ }
118
+
119
+ return {terp, track}
120
+ },
121
+ }
122
+
123
+ #makeFilter = <TFilter extends FilterType>(type: TFilter) => {
124
+ const make = (params?: FilterParams<TFilter>) => {
125
+ const item: Item.Filter<TFilter> = {
126
+ id: this.getId(),
127
+ kind: Kind.Filter,
128
+ type,
129
+ params,
130
+ enabled: true
131
+ }
132
+ this.register(item)
133
+ return item
134
+ }
135
+
136
+ const action = (<T extends FilterableItem>(item: T, params?: FilterParams<TFilter>): T => {
137
+ const filter = make(params)
138
+ const next = {
139
+ ...item,
140
+ filterIds: [...(item.filterIds ?? []), filter.id]
141
+ }
142
+ this.set<T>(item.id, next as Partial<T>)
143
+ return next
144
+ }) as FilterAction<TFilter>
145
+
146
+ action.make = make
147
+ return action
148
+ }
149
+
150
+ #makeFilters = (): FilterActions => {
151
+ const entries = Object.entries(filters)
152
+ .map(([name, filter]) => [name, this.#makeFilter(filter.type)])
153
+ return Object.fromEntries(entries) as FilterActions
154
+ }
47
155
 
48
- stack = (...items: TimelineItem[]) => new Stack(this, {
49
- kind: Kind.Stack,
50
- id: this.#getId(),
51
- childrenIds: items.map(item => this.register(item))
52
- })
156
+ filter = this.#makeFilters()
157
+
158
+ #makeAnimate = <TKey extends keyof VisualAnimations>(key: TKey): AnimateAction => {
159
+ const make = (terp: Interpolation, track: Keyframes) =>
160
+ this.#registerAnimation({
161
+ [key]: this.anim.scalar(terp, track)
162
+ } as Pick<VisualAnimations, TKey>)
163
+
164
+ const action = (<T extends VisualAnimatableItem>(
165
+ item: T,
166
+ terp: Interpolation,
167
+ track: Keyframes
168
+ ): T => {
169
+ const animation = make(terp, track)
170
+ const next = {
171
+ ...item,
172
+ animationId: animation.id
173
+ }
174
+ this.set<T>(item.id, next as Partial<T>)
175
+ return next
176
+ }) as AnimateAction
177
+
178
+ action.make = make
179
+ return action
180
+ }
181
+
182
+ #makeAnimateActions = (): VisualAnimateActions => {
183
+ const entries = Object.keys(visualAnimations)
184
+ .map(key => [key, this.#makeAnimate(key as keyof VisualAnimations)])
185
+ return Object.fromEntries(entries) as VisualAnimateActions
186
+ }
187
+
188
+ animate = this.#makeAnimateActions()
189
+
190
+ sequence = (...items: Item.Any[]): Item.Sequence => {
191
+ const item = {
192
+ id: this.getId(),
193
+ kind: Kind.Sequence,
194
+ childrenIds: items.map(item => item.id)
195
+ } as Item.Sequence
196
+ this.register(item)
197
+ return item
198
+ }
199
+
200
+ stack = (...items: Item.Any[]): Item.Stack => {
201
+ const item = {
202
+ kind: Kind.Stack,
203
+ id: this.getId(),
204
+ childrenIds: items.map(item => item.id)
205
+ } as Item.Stack
206
+ this.register(item)
207
+ return item
208
+ }
209
+
210
+ video = (
211
+ media: Media,
212
+ options?: {
213
+ start?: number,
214
+ duration?: number
215
+ }): Item.Video => {
53
216
 
54
- video = (media: Media, options?: {start?: number, duration?: number}) => {
55
217
  if(!media.hasVideo)
56
218
  throw new Error(`Video clip error: media "${media.datafile.filename}" has no video track.`)
57
219
 
58
220
  const item: Item.Video = {
59
221
  kind: Kind.Video,
60
- id: this.#getId(),
222
+ id: this.getId(),
61
223
  mediaHash: media.datafile.checksum.hash,
62
224
  start: options?.start ?? 0,
63
225
  duration: options?.duration ?? media.duration
64
226
  }
65
-
66
- return new Video(item)
227
+ this.register(item)
228
+ return item
67
229
  }
68
230
 
69
- audio = (media: Media, options?: {start?: number, duration?: number}) => {
231
+ audio = (
232
+ media: Media,
233
+ options?: {
234
+ start?: number,
235
+ duration?: number,
236
+ gain?: number
237
+ }): Item.Audio => {
238
+
70
239
  if(!media.hasAudio)
71
240
  throw new Error(`Audio clip error: media "${media.datafile.filename}" has no audio track.`)
72
241
 
73
242
  const item: Item.Audio = {
74
243
  kind: Kind.Audio,
75
- id: this.#getId(),
244
+ id: this.getId(),
76
245
  mediaHash: media.datafile.checksum.hash,
77
246
  start: options?.start ?? 0,
78
- duration: options?.duration ?? media.duration
247
+ duration: options?.duration ?? media.duration,
248
+ gain: options?.gain ?? 1
79
249
  }
80
-
81
- return new Audio(item)
250
+ this.register(item)
251
+ return item
82
252
  }
83
253
 
84
- text = (content: string) => new Text({
85
- id: this.#getId(),
86
- content,
87
- kind: Kind.Text,
88
- color: "#FFFFF"
89
- })
254
+ text = (content: string, options?: {
255
+ duration?: number,
256
+ styles?: TextStyleOptions
257
+ }): Item.Text => {
258
+
259
+ const item = {
260
+ id: this.getId(),
261
+ content,
262
+ kind: Kind.Text,
263
+ duration: options?.duration ?? 2000
264
+ } as Item.Text
265
+
266
+ if(options?.styles)
267
+ item.styleId = this.textStyle(options.styles).id
268
+
269
+ this.register(item)
270
+ return item
271
+ }
90
272
 
91
- gap = (duration: number) => new Gap({
92
- id: this.#getId(),
93
- kind: Kind.Gap,
94
- duration
95
- })
273
+ gap = (duration: number): Item.Gap => {
274
+ const item = {
275
+ id: this.getId(),
276
+ kind: Kind.Gap,
277
+ duration
278
+ } as Item.Gap
279
+ this.register(item)
280
+ return item
281
+ }
96
282
 
97
283
  transition = {
98
- crossfade: (duration: number) => new Transition({
99
- id: this.#getId(),
100
- kind: Kind.Transition,
101
- effect: Effect.Crossfade,
102
- duration,
103
- }),
284
+ crossfade: (duration: number): Item.Transition => {
285
+ const item = {
286
+ id: this.getId(),
287
+ kind: Kind.Transition,
288
+ effect: Effect.Crossfade,
289
+ duration,
290
+ } as Item.Transition
291
+ this.register(item)
292
+ return item
293
+ },
104
294
  }
105
295
 
106
296
  transform = (options?: TransformOptions): Transform => {
@@ -115,5 +305,27 @@ export class O {
115
305
  const rotation = options?.rotation ?? 0
116
306
  return [position, scale, rotation]
117
307
  }
308
+
309
+ addChildren(parent: Item.Stack | Item.Sequence, ...items: Item.Any[]) {
310
+ this.#mutate(state => {
311
+ const parentItem = state.items.find(({id}) => id === parent.id) as Item.Stack
312
+ parentItem.childrenIds.push(...items.map(item => item.id))
313
+ return state
314
+ })
315
+ }
316
+
317
+ set = <K extends Item.Any>(
318
+ id: Id,
319
+ partial: Partial<K>
320
+ ) => {
321
+ this.#mutate(project => ({
322
+ ...project,
323
+ items: project.items.map(item =>
324
+ item.id === id
325
+ ? { ...item, ...partial }
326
+ : item
327
+ )
328
+ }))
329
+ }
118
330
  }
119
331
 
@@ -0,0 +1,210 @@
1
+
2
+ import {expect, Science, test} from "@e280/science"
3
+
4
+ import {O} from "./o.js"
5
+ import {Omni} from "./omni.js"
6
+ import {Item} from "../parts/item.js"
7
+ import {Driver} from "../../driver/driver.js"
8
+ import {Datafile} from "../utils/datafile.js"
9
+ import {loadVideo} from "../../demo/routines/load-video.js"
10
+ import {computeItemDuration} from "../renderers/parts/handy.js"
11
+
12
+ const workerUrl = new URL("../driver/driver.worker.bundle.min.js", import.meta.url)
13
+ export async function setupTest() {
14
+ const driver = await Driver.setup({workerUrl})
15
+ const omni = new Omni(driver)
16
+
17
+ const testVideo = await loadVideo("/assets/temp/test.mp4")
18
+ const {videoA} = await omni.load({videoA: Datafile.make(testVideo, "test.mp4")})
19
+
20
+ return {driver, omni, testVideo, videoA}
21
+ }
22
+
23
+ export default Science.suite({
24
+ "basic demo": test(async () => {
25
+ const driver = await Driver.setup({workerUrl: new URL("../driver/driver.worker.bundle.min.js", import.meta.url)})
26
+ const omni = new Omni(driver)
27
+
28
+ const testVideo = await loadVideo("/assets/temp/test.mp4")
29
+ const {videoA} = await omni.load({videoA: Datafile.make(testVideo, "test.mp4")})
30
+
31
+ const o = new O({timeline: omni.timeline(o => o.sequence())})
32
+ const rootItem = o.require<Item.Sequence>(o.timeline.rootId)!
33
+
34
+ const video = o.video(videoA)
35
+ o.addChildren(rootItem, video)
36
+
37
+ const videoDuration = computeItemDuration(video.id, o.timeline)
38
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
39
+
40
+ expect(videoDuration).is(timelineDuration)
41
+ }),
42
+
43
+ "sequence duration is 3x": test(async () => {
44
+ const {omni, videoA} = await setupTest()
45
+ const o = new O({timeline: omni.timeline(o => o.sequence(
46
+ o.video(videoA),
47
+ o.video(videoA),
48
+ o.video(videoA),
49
+ ))})
50
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
51
+ expect(timelineDuration).is(videoA.duration * 3)
52
+ }),
53
+
54
+ "stack duration is 1x": test(async () => {
55
+ const {omni, videoA} = await setupTest()
56
+ const o = new O({timeline: omni.timeline(o => o.stack(
57
+ o.video(videoA),
58
+ o.video(videoA),
59
+ o.video(videoA),
60
+ ))})
61
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
62
+ expect(timelineDuration).is(videoA.duration)
63
+ }),
64
+
65
+ "nested stack inside sequence": test(async () => {
66
+ const {omni, videoA} = await setupTest()
67
+ const o = new O({timeline: omni.timeline(o => o.sequence(
68
+ o.video(videoA),
69
+ o.stack(
70
+ o.video(videoA),
71
+ o.video(videoA)
72
+ ),
73
+ o.video(videoA),
74
+ ))})
75
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
76
+ expect(timelineDuration).is(videoA.duration * 3)
77
+ }),
78
+
79
+ "nested sequence inside stack": test(async () => {
80
+ const {omni, videoA} = await setupTest()
81
+ const o = new O({timeline: omni.timeline(o => o.stack(
82
+ o.video(videoA),
83
+ o.sequence(
84
+ o.video(videoA),
85
+ o.video(videoA)
86
+ )
87
+ ))})
88
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
89
+ expect(timelineDuration).is(videoA.duration * 2)
90
+ }),
91
+
92
+ "empty timeline duration is 0": test(async () => {
93
+ const {omni} = await setupTest()
94
+ const o1 = new O({timeline: omni.timeline(o => o.sequence())})
95
+ const o2 = new O({timeline: omni.timeline(o => o.stack())})
96
+ const duration1 = computeItemDuration(o1.timeline.rootId, o1.timeline)
97
+ const duration2 = computeItemDuration(o2.timeline.rootId, o2.timeline)
98
+ expect(duration1).is(0)
99
+ expect(duration2).is(0)
100
+ }),
101
+
102
+ "transition in a sequence": test(async () => {
103
+ const {omni, videoA} = await setupTest()
104
+ const transitionDuration = 1000
105
+ const o = new O({timeline: omni.timeline(o => o.sequence(
106
+ o.video(videoA),
107
+ o.transition.crossfade(transitionDuration),
108
+ o.video(videoA)
109
+ ))})
110
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
111
+ const expectedDuration = (videoA.duration * 2) - transitionDuration
112
+ expect(timelineDuration).is(expectedDuration)
113
+ }),
114
+
115
+ "transition in a stack": test(async () => {
116
+ const {omni, videoA} = await setupTest()
117
+ const transitionDuration = 1000
118
+ const o = new O({timeline: omni.timeline(o => o.stack(
119
+ o.video(videoA),
120
+ o.transition.crossfade(transitionDuration),
121
+ o.video(videoA)
122
+ ))})
123
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
124
+ expect(timelineDuration).is(videoA.duration)
125
+ }),
126
+
127
+ "ignore invalid transition": test(async () => {
128
+ const {omni, videoA} = await setupTest()
129
+ const o = new O({timeline: omni.timeline(o => o.sequence(
130
+ o.transition.crossfade(1000),
131
+ o.video(videoA),
132
+ o.video(videoA),
133
+ o.transition.crossfade(1000),
134
+ ))})
135
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
136
+ expect(timelineDuration).is(videoA.duration * 2)
137
+ }),
138
+
139
+ "clamp transition duration on overflow": test(async () => {
140
+ const {omni, videoA} = await setupTest()
141
+ const duration = 3000
142
+ const o = new O({timeline: omni.timeline(o => o.sequence(
143
+ o.video(videoA, {duration}),
144
+ o.transition.crossfade(duration * 2),
145
+ o.video(videoA, {duration})
146
+ ))})
147
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
148
+ expect(timelineDuration).is(duration)
149
+ }),
150
+
151
+ "multiple transitions": test(async () => {
152
+ const {omni, videoA} = await setupTest()
153
+ const transitionDuration = 1000
154
+ const o = new O({timeline: omni.timeline(o => o.sequence(
155
+ o.video(videoA),
156
+ o.transition.crossfade(transitionDuration),
157
+ o.video(videoA),
158
+ o.transition.crossfade(transitionDuration),
159
+ o.video(videoA)
160
+ ))})
161
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
162
+ const expected = (videoA.duration * 3) - (transitionDuration * 2)
163
+ expect(timelineDuration).is(expected)
164
+ }),
165
+
166
+ "gap item in a sequence": test(async () => {
167
+ const {omni, videoA} = await setupTest()
168
+ const gapDuration = 1000
169
+ const o = new O({timeline: omni.timeline(o => o.sequence(
170
+ o.video(videoA),
171
+ o.gap(gapDuration),
172
+ o.video(videoA)
173
+ ))})
174
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
175
+ const expected = videoA.duration * 2 + gapDuration
176
+ expect(timelineDuration).is(expected)
177
+ }),
178
+
179
+ "gap item in a stack": test(async () => {
180
+ const {omni, videoA} = await setupTest()
181
+ const o = new O({timeline: omni.timeline(o => o.stack(
182
+ o.video(videoA),
183
+ o.gap(1000),
184
+ o.video(videoA)
185
+ ))})
186
+ const timelineDuration = computeItemDuration(o.timeline.rootId, o.timeline)
187
+ expect(timelineDuration).is(videoA.duration)
188
+ }),
189
+
190
+ "load media into Omni": test(async () => {
191
+ const driver = await Driver.setup({workerUrl})
192
+ const omni = new Omni(driver)
193
+ const testVideo = await loadVideo("/assets/temp/test.mp4")
194
+ const {videoA} = await omni.load({videoA: Datafile.make(testVideo, "test.mp4")})
195
+ expect(omni.resources.require(videoA.datafile.checksum.hash)).happy()
196
+ }),
197
+
198
+ "playback seeks to correct time": test(async () => {
199
+ const {omni, videoA} = await setupTest()
200
+ const o = new O({timeline: omni.timeline(o => o.sequence(
201
+ o.video(videoA, {duration: 2000}),
202
+ o.gap(500),
203
+ o.video(videoA, {duration: 2500})
204
+ ))})
205
+ const playback = await omni.playback(o.timeline)
206
+ await playback.seek(1000)
207
+ expect(playback.currentTime).is(1000)
208
+ })
209
+ })
210
+
@@ -1,33 +1,56 @@
1
1
 
2
2
  import {O} from "./o.js"
3
- import {Timeline} from "../timeline.js"
3
+ import {Item} from "../parts/item.js"
4
+ import {fps} from "../../units/fps.js"
4
5
  import {Media} from "../parts/media.js"
5
- import {TimelineItem} from "./builders.js"
6
+ import {Driver} from "../../driver/driver.js"
6
7
  import {Datafile} from "../utils/datafile.js"
7
8
  import {TimelineFile} from "../parts/basics.js"
8
- import {Export} from "../parts/compositor/export.js"
9
9
  import {ResourcePool} from "../parts/resource-pool.js"
10
- import {RenderConfig} from "../../driver/fns/schematic.js"
10
+ import {VideoPlayer} from "../renderers/player/player.js"
11
+ import {produce} from "../renderers/export/produce.js"
11
12
 
12
13
  export class Omni {
13
14
  resources = new ResourcePool()
14
- #export = new Export()
15
+
16
+ constructor(private driver: Driver) {}
15
17
 
16
18
  load = async<S extends Record<string, Promise<Datafile>>>(spec: S) => {
17
19
  return Object.fromEntries(await Promise.all(Object.entries(spec).map(
18
- async([key, value]) => [key, await this.resources.store(await value)]
20
+ async ([key, value]) => [key, await this.resources.store(await value)]
19
21
  ))) as {[K in keyof S]: Media}
20
22
  }
21
23
 
22
- timeline = (fn: (o: O) => TimelineItem): Timeline => {
23
- const o = new O()
24
+ timeline = (fn: (o: O) => Item.Any): TimelineFile => {
25
+ const o = new O({
26
+ timeline: {
27
+ format: "timeline",
28
+ info: "https://omniclip.app/",
29
+ version: 0,
30
+ items: [],
31
+ rootId: 0
32
+ }
33
+ })
24
34
  const root = fn(o)
25
- o.register(root)
26
- return new Timeline(root, o.itemsMap)
35
+ o.timeline.rootId = root.id
36
+ return o.timeline
37
+ }
38
+
39
+ playback = async (timeline: TimelineFile) => {
40
+ return new VideoPlayer(
41
+ this.driver,
42
+ (hash) => this.resources.require(hash).url,
43
+ timeline
44
+ )
27
45
  }
28
46
 
29
- render = async (timeline: TimelineFile, config: RenderConfig) => {
30
- await this.#export.render(timeline)
47
+ render = async (timeline: TimelineFile, framerate: number = 30) => {
48
+ return produce({
49
+ timeline,
50
+ fps: fps(framerate),
51
+ driver: this.driver,
52
+ resolveMedia: (hash) => this.resources.require(hash).url
53
+ })
31
54
  }
32
55
  }
33
56