@omnimedia/omnitool 1.1.0-9 → 1.1.0-90

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