@remotion/player 4.0.0-lambda.3 → 4.0.0-newpathfunctions.13

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 (311) hide show
  1. package/LICENSE.md +8 -8
  2. package/README.md +1 -1
  3. package/dist/MediaVolumeSlider.d.ts +4 -1
  4. package/dist/MediaVolumeSlider.js +80 -55
  5. package/dist/Player.d.ts +20 -15
  6. package/dist/Player.js +24 -70
  7. package/dist/PlayerControls.d.ts +29 -2
  8. package/dist/PlayerControls.js +66 -15
  9. package/dist/PlayerSeekBar.d.ts +4 -0
  10. package/dist/PlayerSeekBar.js +35 -11
  11. package/dist/PlayerUI.d.ts +18 -9
  12. package/dist/PlayerUI.js +118 -76
  13. package/dist/SharedPlayerContext.d.ts +14 -0
  14. package/dist/SharedPlayerContext.js +72 -0
  15. package/dist/Thumbnail.d.ts +20 -0
  16. package/dist/Thumbnail.js +42 -0
  17. package/dist/ThumbnailUI.d.ts +11 -0
  18. package/dist/ThumbnailUI.js +107 -0
  19. package/dist/calculate-next-frame.d.ts +0 -0
  20. package/dist/calculate-next-frame.js +0 -0
  21. package/dist/calculate-scale.d.ts +30 -5
  22. package/dist/calculate-scale.js +65 -4
  23. package/dist/cjs/MediaVolumeSlider.d.ts +5 -0
  24. package/dist/cjs/MediaVolumeSlider.js +118 -0
  25. package/dist/cjs/Player.d.ts +43 -0
  26. package/dist/cjs/Player.js +143 -0
  27. package/dist/cjs/PlayerControls.d.ts +41 -0
  28. package/dist/cjs/PlayerControls.js +152 -0
  29. package/dist/cjs/PlayerSeekBar.d.ts +8 -0
  30. package/dist/cjs/PlayerSeekBar.js +146 -0
  31. package/dist/cjs/PlayerUI.d.ts +38 -0
  32. package/dist/cjs/PlayerUI.js +308 -0
  33. package/dist/cjs/SharedPlayerContext.d.ts +14 -0
  34. package/dist/cjs/SharedPlayerContext.js +72 -0
  35. package/dist/cjs/Thumbnail.d.ts +20 -0
  36. package/dist/cjs/Thumbnail.js +42 -0
  37. package/dist/cjs/ThumbnailUI.d.ts +11 -0
  38. package/dist/cjs/ThumbnailUI.js +107 -0
  39. package/dist/cjs/calculate-next-frame.d.ts +14 -0
  40. package/dist/cjs/calculate-next-frame.js +28 -0
  41. package/dist/cjs/calculate-scale.d.ts +39 -0
  42. package/dist/cjs/calculate-scale.js +85 -0
  43. package/dist/cjs/emitter-context.d.ts +4 -0
  44. package/dist/cjs/emitter-context.js +9 -0
  45. package/dist/cjs/error-boundary.d.ts +19 -0
  46. package/dist/cjs/error-boundary.js +39 -0
  47. package/dist/cjs/event-emitter.d.ts +66 -0
  48. package/dist/cjs/event-emitter.js +87 -0
  49. package/dist/cjs/format-time.d.ts +1 -0
  50. package/dist/cjs/format-time.js +9 -0
  51. package/dist/cjs/icons.d.ts +10 -0
  52. package/dist/cjs/icons.js +50 -0
  53. package/dist/cjs/index.d.ts +60 -0
  54. package/dist/cjs/index.js +25 -0
  55. package/dist/cjs/player-css-classname.d.ts +1 -0
  56. package/dist/cjs/player-css-classname.js +4 -0
  57. package/dist/cjs/player-methods.d.ts +24 -0
  58. package/dist/cjs/player-methods.js +2 -0
  59. package/dist/cjs/test/index.test.d.ts +1 -0
  60. package/dist/cjs/test/index.test.js +9 -0
  61. package/dist/cjs/test/test-utils.d.ts +6 -0
  62. package/dist/cjs/test/test-utils.js +32 -0
  63. package/dist/cjs/test/validate-in-out-frames.test.d.ts +1 -0
  64. package/dist/cjs/test/validate-in-out-frames.test.js +56 -0
  65. package/dist/cjs/test/validate-prop.test.d.ts +1 -0
  66. package/dist/cjs/test/validate-prop.test.js +131 -0
  67. package/dist/cjs/use-hover-state.d.ts +1 -0
  68. package/dist/cjs/use-hover-state.js +27 -0
  69. package/dist/cjs/use-playback.d.ts +7 -0
  70. package/dist/cjs/use-playback.js +92 -0
  71. package/dist/cjs/use-player.d.ts +19 -0
  72. package/dist/cjs/use-player.js +132 -0
  73. package/dist/cjs/use-thumbnail.d.ts +6 -0
  74. package/dist/cjs/use-thumbnail.js +18 -0
  75. package/dist/cjs/use-video-controls-resize.d.ts +7 -0
  76. package/dist/cjs/use-video-controls-resize.js +36 -0
  77. package/dist/cjs/utils/calculate-player-size.d.ts +9 -0
  78. package/dist/cjs/utils/calculate-player-size.js +29 -0
  79. package/dist/cjs/utils/cancellable-promise.d.ts +5 -0
  80. package/dist/cjs/utils/cancellable-promise.js +26 -0
  81. package/dist/cjs/utils/delay.d.ts +1 -0
  82. package/dist/cjs/utils/delay.js +6 -0
  83. package/dist/cjs/utils/is-node.d.ts +1 -0
  84. package/dist/cjs/utils/is-node.js +4 -0
  85. package/dist/cjs/utils/preview-size.d.ts +8 -0
  86. package/dist/cjs/utils/preview-size.js +2 -0
  87. package/dist/cjs/utils/props-if-has-props.d.ts +5 -0
  88. package/dist/cjs/utils/props-if-has-props.js +2 -0
  89. package/dist/cjs/utils/use-cancellable-promises.d.ts +7 -0
  90. package/dist/cjs/utils/use-cancellable-promises.js +21 -0
  91. package/dist/cjs/utils/use-click-prevention-on-double-click.d.ts +3 -0
  92. package/dist/cjs/utils/use-click-prevention-on-double-click.js +45 -0
  93. package/dist/cjs/utils/use-element-size.d.ts +16 -0
  94. package/dist/cjs/utils/use-element-size.js +98 -0
  95. package/dist/cjs/utils/validate-in-out-frame.d.ts +6 -0
  96. package/dist/cjs/utils/validate-in-out-frame.js +54 -0
  97. package/dist/cjs/utils/validate-initial-frame.d.ts +4 -0
  98. package/dist/cjs/utils/validate-initial-frame.js +27 -0
  99. package/dist/cjs/utils/validate-playbackrate.d.ts +1 -0
  100. package/dist/cjs/utils/validate-playbackrate.js +18 -0
  101. package/dist/cjs/volume-persistance.d.ts +2 -0
  102. package/dist/cjs/volume-persistance.js +19 -0
  103. package/dist/emitter-context.d.ts +2 -1
  104. package/dist/emitter-context.js +2 -1
  105. package/dist/error-boundary.d.ts +0 -0
  106. package/dist/error-boundary.js +0 -0
  107. package/dist/esm/MediaVolumeSlider.d.ts +5 -0
  108. package/dist/esm/MediaVolumeSlider.js +114 -0
  109. package/dist/esm/Player.d.ts +43 -0
  110. package/dist/esm/Player.js +136 -0
  111. package/dist/esm/PlayerControls.d.ts +41 -0
  112. package/dist/esm/PlayerControls.js +148 -0
  113. package/dist/esm/PlayerSeekBar.d.ts +8 -0
  114. package/dist/esm/PlayerSeekBar.js +142 -0
  115. package/dist/esm/PlayerUI.d.ts +38 -0
  116. package/dist/esm/PlayerUI.js +283 -0
  117. package/dist/esm/SharedPlayerContext.d.ts +14 -0
  118. package/dist/esm/SharedPlayerContext.js +68 -0
  119. package/dist/esm/Thumbnail.d.ts +20 -0
  120. package/dist/esm/Thumbnail.js +35 -0
  121. package/dist/esm/ThumbnailUI.d.ts +11 -0
  122. package/dist/esm/ThumbnailUI.js +82 -0
  123. package/dist/esm/calculate-next-frame.d.ts +14 -0
  124. package/dist/esm/calculate-next-frame.js +24 -0
  125. package/dist/esm/calculate-scale.d.ts +39 -0
  126. package/dist/esm/calculate-scale.js +77 -0
  127. package/dist/esm/emitter-context.d.ts +4 -0
  128. package/dist/esm/emitter-context.js +3 -0
  129. package/dist/esm/error-boundary.d.ts +19 -0
  130. package/dist/esm/error-boundary.js +32 -0
  131. package/dist/esm/event-emitter.d.ts +66 -0
  132. package/dist/esm/event-emitter.js +82 -0
  133. package/dist/esm/format-time.d.ts +1 -0
  134. package/dist/esm/format-time.js +5 -0
  135. package/dist/esm/icons.d.ts +10 -0
  136. package/dist/esm/icons.js +42 -0
  137. package/dist/esm/index.d.ts +60 -0
  138. package/dist/esm/index.js +20 -0
  139. package/dist/esm/player-css-classname.d.ts +1 -0
  140. package/dist/esm/player-css-classname.js +1 -0
  141. package/dist/esm/player-methods.d.ts +24 -0
  142. package/dist/esm/player-methods.js +1 -0
  143. package/dist/esm/test/index.test.d.ts +1 -0
  144. package/dist/esm/test/index.test.js +7 -0
  145. package/dist/esm/test/test-utils.d.ts +6 -0
  146. package/dist/esm/test/test-utils.js +14 -0
  147. package/dist/esm/test/validate-in-out-frames.test.d.ts +1 -0
  148. package/dist/esm/test/validate-in-out-frames.test.js +54 -0
  149. package/dist/esm/test/validate-prop.test.d.ts +1 -0
  150. package/dist/esm/test/validate-prop.test.js +129 -0
  151. package/dist/esm/use-hover-state.d.ts +1 -0
  152. package/dist/esm/use-hover-state.js +23 -0
  153. package/dist/esm/use-playback.d.ts +7 -0
  154. package/dist/esm/use-playback.js +88 -0
  155. package/dist/esm/use-player.d.ts +19 -0
  156. package/dist/esm/use-player.js +128 -0
  157. package/dist/esm/use-thumbnail.d.ts +6 -0
  158. package/dist/esm/use-thumbnail.js +14 -0
  159. package/dist/esm/use-video-controls-resize.d.ts +7 -0
  160. package/dist/esm/use-video-controls-resize.js +32 -0
  161. package/dist/esm/utils/calculate-player-size.d.ts +9 -0
  162. package/dist/esm/utils/calculate-player-size.js +25 -0
  163. package/dist/esm/utils/cancellable-promise.d.ts +5 -0
  164. package/dist/esm/utils/cancellable-promise.js +22 -0
  165. package/dist/esm/utils/delay.d.ts +1 -0
  166. package/dist/esm/utils/delay.js +2 -0
  167. package/dist/esm/utils/is-node.d.ts +1 -0
  168. package/dist/esm/utils/is-node.js +1 -0
  169. package/dist/esm/utils/preview-size.d.ts +8 -0
  170. package/dist/esm/utils/preview-size.js +1 -0
  171. package/dist/esm/utils/props-if-has-props.d.ts +5 -0
  172. package/dist/esm/utils/props-if-has-props.js +1 -0
  173. package/dist/esm/utils/use-cancellable-promises.d.ts +7 -0
  174. package/dist/esm/utils/use-cancellable-promises.js +18 -0
  175. package/dist/esm/utils/use-click-prevention-on-double-click.d.ts +3 -0
  176. package/dist/esm/utils/use-click-prevention-on-double-click.js +42 -0
  177. package/dist/esm/utils/use-element-size.d.ts +16 -0
  178. package/dist/esm/utils/use-element-size.js +93 -0
  179. package/dist/esm/utils/validate-in-out-frame.d.ts +6 -0
  180. package/dist/esm/utils/validate-in-out-frame.js +49 -0
  181. package/dist/esm/utils/validate-initial-frame.d.ts +4 -0
  182. package/dist/esm/utils/validate-initial-frame.js +23 -0
  183. package/dist/esm/utils/validate-playbackrate.d.ts +1 -0
  184. package/dist/esm/utils/validate-playbackrate.js +14 -0
  185. package/dist/esm/volume-persistance.d.ts +2 -0
  186. package/dist/esm/volume-persistance.js +14 -0
  187. package/dist/event-emitter.d.ts +33 -9
  188. package/dist/event-emitter.js +33 -1
  189. package/dist/format-time.d.ts +0 -0
  190. package/dist/format-time.js +0 -0
  191. package/dist/icons.d.ts +2 -1
  192. package/dist/icons.js +7 -7
  193. package/dist/index.d.ts +25 -9
  194. package/dist/index.js +5 -2
  195. package/dist/player-css-classname.d.ts +0 -1
  196. package/dist/player-css-classname.js +1 -2
  197. package/dist/player-methods.d.ts +8 -4
  198. package/dist/player-methods.js +0 -0
  199. package/dist/test/index.test.d.ts +0 -0
  200. package/dist/test/index.test.js +3 -2
  201. package/dist/test/test-utils.d.ts +2 -2
  202. package/dist/test/test-utils.js +0 -0
  203. package/dist/test/validate-in-out-frames.test.d.ts +1 -0
  204. package/dist/test/validate-in-out-frames.test.js +56 -0
  205. package/dist/test/validate-prop.test.d.ts +0 -0
  206. package/dist/test/validate-prop.test.js +24 -23
  207. package/dist/tsconfig-cjs.tsbuildinfo +1 -0
  208. package/dist/tsconfig.tsbuildinfo +1 -0
  209. package/dist/use-hover-state.d.ts +0 -0
  210. package/dist/use-hover-state.js +0 -0
  211. package/dist/use-playback.d.ts +4 -1
  212. package/dist/use-playback.js +7 -3
  213. package/dist/use-player.d.ts +8 -3
  214. package/dist/use-player.js +23 -4
  215. package/dist/use-thumbnail.d.ts +6 -0
  216. package/dist/use-thumbnail.js +18 -0
  217. package/dist/use-video-controls-resize.d.ts +7 -0
  218. package/dist/use-video-controls-resize.js +36 -0
  219. package/dist/utils/calculate-player-size.d.ts +2 -2
  220. package/dist/utils/calculate-player-size.js +0 -0
  221. package/dist/utils/cancellable-promise.d.ts +0 -0
  222. package/dist/utils/cancellable-promise.js +0 -0
  223. package/dist/utils/delay.d.ts +0 -0
  224. package/dist/utils/delay.js +0 -0
  225. package/dist/utils/is-node.d.ts +0 -0
  226. package/dist/utils/is-node.js +0 -0
  227. package/dist/utils/preview-size.d.ts +8 -1
  228. package/dist/utils/preview-size.js +0 -0
  229. package/dist/utils/props-if-has-props.d.ts +5 -0
  230. package/dist/utils/props-if-has-props.js +2 -0
  231. package/dist/utils/use-cancellable-promises.d.ts +1 -1
  232. package/dist/utils/use-cancellable-promises.js +0 -0
  233. package/dist/utils/use-click-prevention-on-double-click.d.ts +1 -1
  234. package/dist/utils/use-click-prevention-on-double-click.js +0 -0
  235. package/dist/utils/use-element-size.d.ts +4 -0
  236. package/dist/utils/use-element-size.js +8 -0
  237. package/dist/utils/validate-in-out-frame.d.ts +6 -0
  238. package/dist/utils/validate-in-out-frame.js +54 -0
  239. package/dist/utils/validate-initial-frame.d.ts +4 -0
  240. package/dist/utils/validate-initial-frame.js +27 -0
  241. package/dist/utils/validate-playbackrate.d.ts +0 -0
  242. package/dist/utils/validate-playbackrate.js +0 -0
  243. package/dist/volume-persistance.d.ts +0 -0
  244. package/dist/volume-persistance.js +0 -0
  245. package/package.json +26 -17
  246. package/dist/MediaVolumeSlider.d.ts.map +0 -1
  247. package/dist/MediaVolumeSlider.js.map +0 -1
  248. package/dist/Player.d.ts.map +0 -1
  249. package/dist/Player.js.map +0 -1
  250. package/dist/PlayerControls.d.ts.map +0 -1
  251. package/dist/PlayerControls.js.map +0 -1
  252. package/dist/PlayerSeekBar.d.ts.map +0 -1
  253. package/dist/PlayerSeekBar.js.map +0 -1
  254. package/dist/PlayerUI.d.ts.map +0 -1
  255. package/dist/PlayerUI.js.map +0 -1
  256. package/dist/calculate-next-frame.d.ts.map +0 -1
  257. package/dist/calculate-next-frame.js.map +0 -1
  258. package/dist/calculate-scale.d.ts.map +0 -1
  259. package/dist/calculate-scale.js.map +0 -1
  260. package/dist/emitter-context.d.ts.map +0 -1
  261. package/dist/emitter-context.js.map +0 -1
  262. package/dist/error-boundary.d.ts.map +0 -1
  263. package/dist/error-boundary.js.map +0 -1
  264. package/dist/event-emitter.d.ts.map +0 -1
  265. package/dist/event-emitter.js.map +0 -1
  266. package/dist/format-time.d.ts.map +0 -1
  267. package/dist/format-time.js.map +0 -1
  268. package/dist/icons.d.ts.map +0 -1
  269. package/dist/icons.js.map +0 -1
  270. package/dist/index.d.ts.map +0 -1
  271. package/dist/index.js.map +0 -1
  272. package/dist/player-css-classname.d.ts.map +0 -1
  273. package/dist/player-css-classname.js.map +0 -1
  274. package/dist/player-methods.d.ts.map +0 -1
  275. package/dist/player-methods.js.map +0 -1
  276. package/dist/test/index.test.d.ts.map +0 -1
  277. package/dist/test/index.test.js.map +0 -1
  278. package/dist/test/test-utils.d.ts.map +0 -1
  279. package/dist/test/test-utils.js.map +0 -1
  280. package/dist/test/validate-prop.test.d.ts.map +0 -1
  281. package/dist/test/validate-prop.test.js.map +0 -1
  282. package/dist/use-hover-state.d.ts.map +0 -1
  283. package/dist/use-hover-state.js.map +0 -1
  284. package/dist/use-playback.d.ts.map +0 -1
  285. package/dist/use-playback.js.map +0 -1
  286. package/dist/use-player.d.ts.map +0 -1
  287. package/dist/use-player.js.map +0 -1
  288. package/dist/utils/browser-supports-fullscreen.d.ts +0 -11
  289. package/dist/utils/browser-supports-fullscreen.d.ts.map +0 -1
  290. package/dist/utils/browser-supports-fullscreen.js +0 -5
  291. package/dist/utils/browser-supports-fullscreen.js.map +0 -1
  292. package/dist/utils/calculate-player-size.d.ts.map +0 -1
  293. package/dist/utils/calculate-player-size.js.map +0 -1
  294. package/dist/utils/cancellable-promise.d.ts.map +0 -1
  295. package/dist/utils/cancellable-promise.js.map +0 -1
  296. package/dist/utils/delay.d.ts.map +0 -1
  297. package/dist/utils/delay.js.map +0 -1
  298. package/dist/utils/is-node.d.ts.map +0 -1
  299. package/dist/utils/is-node.js.map +0 -1
  300. package/dist/utils/preview-size.d.ts.map +0 -1
  301. package/dist/utils/preview-size.js.map +0 -1
  302. package/dist/utils/use-cancellable-promises.d.ts.map +0 -1
  303. package/dist/utils/use-cancellable-promises.js.map +0 -1
  304. package/dist/utils/use-click-prevention-on-double-click.d.ts.map +0 -1
  305. package/dist/utils/use-click-prevention-on-double-click.js.map +0 -1
  306. package/dist/utils/use-element-size.d.ts.map +0 -1
  307. package/dist/utils/use-element-size.js.map +0 -1
  308. package/dist/utils/validate-playbackrate.d.ts.map +0 -1
  309. package/dist/utils/validate-playbackrate.js.map +0 -1
  310. package/dist/volume-persistance.d.ts.map +0 -1
  311. package/dist/volume-persistance.js.map +0 -1
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SharedPlayerContexts = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const remotion_1 = require("remotion");
7
+ const volume_persistance_1 = require("./volume-persistance");
8
+ const SharedPlayerContexts = ({ children, timelineContext, inputProps, fps, compositionHeight, compositionWidth, durationInFrames, component, numberOfSharedAudioTags, }) => {
9
+ const compositionManagerContext = (0, react_1.useMemo)(() => {
10
+ return {
11
+ compositions: [
12
+ {
13
+ component: component,
14
+ durationInFrames,
15
+ height: compositionHeight,
16
+ width: compositionWidth,
17
+ fps,
18
+ id: 'player-comp',
19
+ props: inputProps,
20
+ nonce: 777,
21
+ scale: 1,
22
+ folderName: null,
23
+ defaultProps: undefined,
24
+ parentFolderName: null,
25
+ },
26
+ ],
27
+ folders: [],
28
+ registerFolder: () => undefined,
29
+ unregisterFolder: () => undefined,
30
+ currentComposition: 'player-comp',
31
+ registerComposition: () => undefined,
32
+ registerSequence: () => undefined,
33
+ sequences: [],
34
+ setCurrentComposition: () => undefined,
35
+ unregisterComposition: () => undefined,
36
+ unregisterSequence: () => undefined,
37
+ registerAsset: () => undefined,
38
+ unregisterAsset: () => undefined,
39
+ currentCompositionMetadata: null,
40
+ setCurrentCompositionMetadata: () => undefined,
41
+ assets: [],
42
+ setClipRegion: () => undefined,
43
+ };
44
+ }, [
45
+ component,
46
+ durationInFrames,
47
+ compositionHeight,
48
+ compositionWidth,
49
+ fps,
50
+ inputProps,
51
+ ]);
52
+ const [mediaMuted, setMediaMuted] = (0, react_1.useState)(false);
53
+ const [mediaVolume, setMediaVolume] = (0, react_1.useState)((0, volume_persistance_1.getPreferredVolume)());
54
+ const mediaVolumeContextValue = (0, react_1.useMemo)(() => {
55
+ return {
56
+ mediaMuted,
57
+ mediaVolume,
58
+ };
59
+ }, [mediaMuted, mediaVolume]);
60
+ const setMediaVolumeAndPersist = (0, react_1.useCallback)((vol) => {
61
+ setMediaVolume(vol);
62
+ (0, volume_persistance_1.persistVolume)(vol);
63
+ }, []);
64
+ const setMediaVolumeContextValue = (0, react_1.useMemo)(() => {
65
+ return {
66
+ setMediaMuted,
67
+ setMediaVolume: setMediaVolumeAndPersist,
68
+ };
69
+ }, [setMediaVolumeAndPersist]);
70
+ return ((0, jsx_runtime_1.jsx)(remotion_1.Internals.CanUseRemotionHooksProvider, { children: (0, jsx_runtime_1.jsx)(remotion_1.Internals.Timeline.TimelineContext.Provider, { value: timelineContext, children: (0, jsx_runtime_1.jsx)(remotion_1.Internals.CompositionManager.Provider, { value: compositionManagerContext, children: (0, jsx_runtime_1.jsx)(remotion_1.Internals.PrefetchProvider, { children: (0, jsx_runtime_1.jsx)(remotion_1.Internals.DurationsContextProvider, { children: (0, jsx_runtime_1.jsx)(remotion_1.Internals.MediaVolumeContext.Provider, { value: mediaVolumeContextValue, children: (0, jsx_runtime_1.jsx)(remotion_1.Internals.SetMediaVolumeContext.Provider, { value: setMediaVolumeContextValue, children: (0, jsx_runtime_1.jsx)(remotion_1.Internals.SharedAudioContextProvider, { numberOfAudioTags: numberOfSharedAudioTags, children: children }) }) }) }) }) }) }) }));
71
+ };
72
+ exports.SharedPlayerContexts = SharedPlayerContexts;
@@ -0,0 +1,20 @@
1
+ import type { CSSProperties, MutableRefObject } from 'react';
2
+ import type { CompProps } from 'remotion';
3
+ import type { ThumbnailMethods } from './player-methods';
4
+ import type { ErrorFallback, RenderLoading } from './PlayerUI';
5
+ import type { PropsIfHasProps } from './utils/props-if-has-props';
6
+ declare type ThumbnailProps<T> = PropsIfHasProps<T> & CompProps<T> & {
7
+ frameToDisplay: number;
8
+ style?: CSSProperties;
9
+ durationInFrames: number;
10
+ compositionWidth: number;
11
+ compositionHeight: number;
12
+ inputProps?: unknown;
13
+ fps: number;
14
+ errorFallback?: ErrorFallback;
15
+ renderLoading?: RenderLoading;
16
+ className?: string;
17
+ };
18
+ export declare const ThumbnailFn: <T>({ frameToDisplay, style, inputProps, compositionHeight, compositionWidth, durationInFrames, fps, className, errorFallback, renderLoading, ...componentProps }: ThumbnailProps<T>, ref: MutableRefObject<ThumbnailMethods>) => JSX.Element;
19
+ export declare const Thumbnail: <T>(props: ThumbnailProps<T> & import("react").RefAttributes<ThumbnailMethods>) => React.ReactElement | null;
20
+ export {};
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Thumbnail = exports.ThumbnailFn = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const react_1 = require("react");
9
+ const remotion_1 = require("remotion");
10
+ const emitter_context_1 = require("./emitter-context");
11
+ const event_emitter_1 = require("./event-emitter");
12
+ const SharedPlayerContext_1 = require("./SharedPlayerContext");
13
+ const ThumbnailUI_1 = __importDefault(require("./ThumbnailUI"));
14
+ const ThumbnailFn = ({ frameToDisplay, style, inputProps, compositionHeight, compositionWidth, durationInFrames, fps, className, errorFallback = () => '⚠️', renderLoading, ...componentProps }, ref) => {
15
+ const [thumbnailId] = (0, react_1.useState)(() => String((0, remotion_1.random)(null)));
16
+ const rootRef = (0, react_1.useRef)(null);
17
+ const timelineState = (0, react_1.useMemo)(() => {
18
+ return {
19
+ playing: false,
20
+ frame: frameToDisplay,
21
+ rootId: thumbnailId,
22
+ imperativePlaying: {
23
+ current: false,
24
+ },
25
+ playbackRate: 1,
26
+ setPlaybackRate: () => {
27
+ throw new Error('thumbnail');
28
+ },
29
+ audioAndVideoTags: { current: [] },
30
+ };
31
+ }, [frameToDisplay, thumbnailId]);
32
+ (0, react_1.useImperativeHandle)(ref, () => rootRef.current, []);
33
+ const Component = remotion_1.Internals.useLazyComponent(componentProps);
34
+ const [emitter] = (0, react_1.useState)(() => new event_emitter_1.ThumbnailEmitter());
35
+ const passedInputProps = (0, react_1.useMemo)(() => {
36
+ return inputProps !== null && inputProps !== void 0 ? inputProps : {};
37
+ }, [inputProps]);
38
+ return ((0, jsx_runtime_1.jsx)(remotion_1.Internals.IsPlayerContextProvider, { children: (0, jsx_runtime_1.jsx)(SharedPlayerContext_1.SharedPlayerContexts, { timelineContext: timelineState, component: Component, compositionHeight: compositionHeight, compositionWidth: compositionWidth, durationInFrames: durationInFrames, fps: fps, inputProps: inputProps, numberOfSharedAudioTags: 0, children: (0, jsx_runtime_1.jsx)(emitter_context_1.ThumbnailEmitterContext.Provider, { value: emitter, children: (0, jsx_runtime_1.jsx)(ThumbnailUI_1.default, { className: className, errorFallback: errorFallback, inputProps: passedInputProps, renderLoading: renderLoading, style: style }) }) }) }));
39
+ };
40
+ exports.ThumbnailFn = ThumbnailFn;
41
+ const forward = react_1.forwardRef;
42
+ exports.Thumbnail = forward(exports.ThumbnailFn);
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ import type { ThumbnailMethods } from './player-methods';
3
+ import type { ErrorFallback, RenderLoading } from './PlayerUI';
4
+ declare const _default: React.ForwardRefExoticComponent<{
5
+ inputProps: unknown;
6
+ style?: React.CSSProperties | undefined;
7
+ errorFallback: ErrorFallback;
8
+ renderLoading: RenderLoading | undefined;
9
+ className: string | undefined;
10
+ } & React.RefAttributes<ThumbnailMethods>>;
11
+ export default _default;
@@ -0,0 +1,107 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ const jsx_runtime_1 = require("react/jsx-runtime");
27
+ const react_1 = __importStar(require("react"));
28
+ const remotion_1 = require("remotion");
29
+ const calculate_scale_1 = require("./calculate-scale");
30
+ const error_boundary_1 = require("./error-boundary");
31
+ const player_css_classname_1 = require("./player-css-classname");
32
+ const use_thumbnail_1 = require("./use-thumbnail");
33
+ const is_node_1 = require("./utils/is-node");
34
+ const use_element_size_1 = require("./utils/use-element-size");
35
+ const reactVersion = react_1.default.version.split('.')[0];
36
+ if (reactVersion === '0') {
37
+ throw new Error(`Version ${reactVersion} of "react" is not supported by Remotion`);
38
+ }
39
+ const doesReactVersionSupportSuspense = parseInt(reactVersion, 10) >= 18;
40
+ const ThumbnailUI = ({ style, inputProps, errorFallback, renderLoading, className }, ref) => {
41
+ var _a, _b, _c;
42
+ const config = remotion_1.Internals.useUnsafeVideoConfig();
43
+ const video = remotion_1.Internals.useVideo();
44
+ const container = (0, react_1.useRef)(null);
45
+ const canvasSize = (0, use_element_size_1.useElementSize)(container, {
46
+ triggerOnWindowResize: false,
47
+ shouldApplyCssTransforms: false,
48
+ });
49
+ const layout = (0, react_1.useMemo)(() => {
50
+ if (!config || !canvasSize) {
51
+ return null;
52
+ }
53
+ return (0, calculate_scale_1.calculateCanvasTransformation)({
54
+ canvasSize,
55
+ compositionHeight: config.height,
56
+ compositionWidth: config.width,
57
+ previewSize: 'auto',
58
+ });
59
+ }, [canvasSize, config]);
60
+ const scale = (_a = layout === null || layout === void 0 ? void 0 : layout.scale) !== null && _a !== void 0 ? _a : 1;
61
+ const thumbnail = (0, use_thumbnail_1.useThumbnail)();
62
+ (0, react_1.useImperativeHandle)(ref, () => {
63
+ const methods = {
64
+ getContainerNode: () => container.current,
65
+ getScale: () => scale,
66
+ };
67
+ return Object.assign(thumbnail.emitter, methods);
68
+ }, [scale, thumbnail.emitter]);
69
+ const VideoComponent = video ? video.component : null;
70
+ const outerStyle = (0, react_1.useMemo)(() => {
71
+ return (0, calculate_scale_1.calculateOuterStyle)({ config, style, canvasSize });
72
+ }, [canvasSize, config, style]);
73
+ const outer = (0, react_1.useMemo)(() => {
74
+ return (0, calculate_scale_1.calculateOuter)({ config, layout, scale });
75
+ }, [config, layout, scale]);
76
+ const containerStyle = (0, react_1.useMemo)(() => {
77
+ return (0, calculate_scale_1.calculateContainerStyle)({
78
+ canvasSize,
79
+ config,
80
+ layout,
81
+ scale,
82
+ });
83
+ }, [canvasSize, config, layout, scale]);
84
+ const onError = (0, react_1.useCallback)((error) => {
85
+ // Pay attention to `this context`
86
+ thumbnail.emitter.dispatchError(error);
87
+ }, [thumbnail.emitter]);
88
+ const rootRef = (0, react_1.useRef)(null);
89
+ (0, react_1.useImperativeHandle)(ref, () => rootRef.current, []);
90
+ const loadingMarkup = (0, react_1.useMemo)(() => {
91
+ return renderLoading
92
+ ? renderLoading({
93
+ height: outerStyle.height,
94
+ width: outerStyle.width,
95
+ })
96
+ : null;
97
+ }, [outerStyle.height, outerStyle.width, renderLoading]);
98
+ if (!config) {
99
+ return null;
100
+ }
101
+ const content = ((0, jsx_runtime_1.jsx)("div", { style: outer, children: (0, jsx_runtime_1.jsx)("div", { style: containerStyle, className: player_css_classname_1.PLAYER_CSS_CLASSNAME, children: VideoComponent ? ((0, jsx_runtime_1.jsx)(error_boundary_1.ErrorBoundary, { onError: onError, errorFallback: errorFallback, children: (0, jsx_runtime_1.jsx)(VideoComponent, { ...((_b = video === null || video === void 0 ? void 0 : video.defaultProps) !== null && _b !== void 0 ? _b : {}), ...((_c = inputProps) !== null && _c !== void 0 ? _c : {}) }) })) : null }) }));
102
+ if (is_node_1.IS_NODE && !doesReactVersionSupportSuspense) {
103
+ return ((0, jsx_runtime_1.jsx)("div", { ref: container, style: outerStyle, className: className, children: content }));
104
+ }
105
+ return ((0, jsx_runtime_1.jsx)("div", { ref: container, style: outerStyle, className: className, children: (0, jsx_runtime_1.jsx)(react_1.Suspense, { fallback: loadingMarkup, children: content }) }));
106
+ };
107
+ exports.default = (0, react_1.forwardRef)(ThumbnailUI);
@@ -0,0 +1,14 @@
1
+ export declare const calculateNextFrame: ({ time, currentFrame: startFrame, playbackSpeed, fps, actualLastFrame, actualFirstFrame, framesAdvanced, shouldLoop, }: {
2
+ time: number;
3
+ currentFrame: number;
4
+ playbackSpeed: number;
5
+ fps: number;
6
+ actualFirstFrame: number;
7
+ actualLastFrame: number;
8
+ framesAdvanced: number;
9
+ shouldLoop: boolean;
10
+ }) => {
11
+ nextFrame: number;
12
+ framesToAdvance: number;
13
+ hasEnded: boolean;
14
+ };
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.calculateNextFrame = void 0;
4
+ const calculateNextFrame = ({ time, currentFrame: startFrame, playbackSpeed, fps, actualLastFrame, actualFirstFrame, framesAdvanced, shouldLoop, }) => {
5
+ const op = playbackSpeed < 0 ? Math.ceil : Math.floor;
6
+ const framesToAdvance = op((time * playbackSpeed) / (1000 / fps)) - framesAdvanced;
7
+ const nextFrame = framesToAdvance + startFrame;
8
+ const isCurrentFrameOutside = startFrame > actualLastFrame || startFrame < actualFirstFrame;
9
+ const isNextFrameOutside = nextFrame > actualLastFrame || nextFrame < actualFirstFrame;
10
+ const hasEnded = !shouldLoop && isNextFrameOutside && !isCurrentFrameOutside;
11
+ if (playbackSpeed > 0) {
12
+ // Play forwards
13
+ if (isNextFrameOutside) {
14
+ return {
15
+ nextFrame: actualFirstFrame,
16
+ framesToAdvance,
17
+ hasEnded,
18
+ };
19
+ }
20
+ return { nextFrame, framesToAdvance, hasEnded };
21
+ }
22
+ // Reverse playback
23
+ if (isNextFrameOutside) {
24
+ return { nextFrame: actualLastFrame, framesToAdvance, hasEnded };
25
+ }
26
+ return { nextFrame, framesToAdvance, hasEnded };
27
+ };
28
+ exports.calculateNextFrame = calculateNextFrame;
@@ -0,0 +1,39 @@
1
+ import type { VideoConfig } from 'remotion';
2
+ import type { PreviewSize } from './utils/preview-size';
3
+ import type { Size } from './utils/use-element-size';
4
+ export declare const calculateScale: ({ canvasSize, compositionHeight, compositionWidth, previewSize, }: {
5
+ previewSize: PreviewSize['size'];
6
+ compositionWidth: number;
7
+ compositionHeight: number;
8
+ canvasSize: Size;
9
+ }) => number;
10
+ declare type Layout = {
11
+ centerX: number;
12
+ centerY: number;
13
+ xCorrection: number;
14
+ yCorrection: number;
15
+ scale: number;
16
+ };
17
+ export declare const calculateCanvasTransformation: ({ previewSize, compositionWidth, compositionHeight, canvasSize, }: {
18
+ previewSize: PreviewSize['size'];
19
+ compositionWidth: number;
20
+ compositionHeight: number;
21
+ canvasSize: Size;
22
+ }) => Layout;
23
+ export declare const calculateOuterStyle: ({ config, style, canvasSize, }: {
24
+ config: VideoConfig | null;
25
+ style: React.CSSProperties | undefined;
26
+ canvasSize: Size | null;
27
+ }) => React.CSSProperties;
28
+ export declare const calculateContainerStyle: ({ config, canvasSize, layout, scale, }: {
29
+ config: VideoConfig | null;
30
+ canvasSize: Size | null;
31
+ layout: Layout | null;
32
+ scale: number;
33
+ }) => React.CSSProperties;
34
+ export declare const calculateOuter: ({ layout, scale, config, }: {
35
+ layout: Layout | null;
36
+ scale: number;
37
+ config: VideoConfig | null;
38
+ }) => React.CSSProperties;
39
+ export {};
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.calculateOuter = exports.calculateContainerStyle = exports.calculateOuterStyle = exports.calculateCanvasTransformation = exports.calculateScale = void 0;
4
+ const calculate_player_size_1 = require("./utils/calculate-player-size");
5
+ const calculateScale = ({ canvasSize, compositionHeight, compositionWidth, previewSize, }) => {
6
+ const heightRatio = canvasSize.height / compositionHeight;
7
+ const widthRatio = canvasSize.width / compositionWidth;
8
+ const ratio = Math.min(heightRatio, widthRatio);
9
+ return previewSize === 'auto' ? ratio : Number(previewSize);
10
+ };
11
+ exports.calculateScale = calculateScale;
12
+ const calculateCanvasTransformation = ({ previewSize, compositionWidth, compositionHeight, canvasSize, }) => {
13
+ const scale = (0, exports.calculateScale)({
14
+ canvasSize,
15
+ compositionHeight,
16
+ compositionWidth,
17
+ previewSize,
18
+ });
19
+ const correction = 0 - (1 - scale) / 2;
20
+ const xCorrection = correction * compositionWidth;
21
+ const yCorrection = correction * compositionHeight;
22
+ const width = compositionWidth * scale;
23
+ const height = compositionHeight * scale;
24
+ const centerX = canvasSize.width / 2 - width / 2;
25
+ const centerY = canvasSize.height / 2 - height / 2;
26
+ return {
27
+ centerX,
28
+ centerY,
29
+ xCorrection,
30
+ yCorrection,
31
+ scale,
32
+ };
33
+ };
34
+ exports.calculateCanvasTransformation = calculateCanvasTransformation;
35
+ const calculateOuterStyle = ({ config, style, canvasSize, }) => {
36
+ if (!config) {
37
+ return {};
38
+ }
39
+ return {
40
+ position: 'relative',
41
+ overflow: 'hidden',
42
+ ...(0, calculate_player_size_1.calculatePlayerSize)({
43
+ compositionHeight: config.height,
44
+ compositionWidth: config.width,
45
+ currentSize: canvasSize,
46
+ height: style === null || style === void 0 ? void 0 : style.height,
47
+ width: style === null || style === void 0 ? void 0 : style.width,
48
+ }),
49
+ ...style,
50
+ };
51
+ };
52
+ exports.calculateOuterStyle = calculateOuterStyle;
53
+ const calculateContainerStyle = ({ config, canvasSize, layout, scale, }) => {
54
+ if (!config || !canvasSize || !layout) {
55
+ return {};
56
+ }
57
+ return {
58
+ position: 'absolute',
59
+ width: config.width,
60
+ height: config.height,
61
+ display: 'flex',
62
+ transform: `scale(${scale})`,
63
+ marginLeft: layout.xCorrection,
64
+ marginTop: layout.yCorrection,
65
+ overflow: 'hidden',
66
+ };
67
+ };
68
+ exports.calculateContainerStyle = calculateContainerStyle;
69
+ const calculateOuter = ({ layout, scale, config, }) => {
70
+ if (!layout || !config) {
71
+ return {};
72
+ }
73
+ const { centerX, centerY } = layout;
74
+ return {
75
+ width: config.width * scale,
76
+ height: config.height * scale,
77
+ display: 'flex',
78
+ flexDirection: 'column',
79
+ position: 'absolute',
80
+ left: centerX,
81
+ top: centerY,
82
+ overflow: 'hidden',
83
+ };
84
+ };
85
+ exports.calculateOuter = calculateOuter;
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import type { PlayerEmitter, ThumbnailEmitter } from './event-emitter';
3
+ export declare const PlayerEventEmitterContext: React.Context<PlayerEmitter | undefined>;
4
+ export declare const ThumbnailEmitterContext: React.Context<ThumbnailEmitter | undefined>;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.ThumbnailEmitterContext = exports.PlayerEventEmitterContext = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ exports.PlayerEventEmitterContext = react_1.default.createContext(undefined);
9
+ exports.ThumbnailEmitterContext = react_1.default.createContext(undefined);
@@ -0,0 +1,19 @@
1
+ import React from 'react';
2
+ export declare class ErrorBoundary extends React.Component<{
3
+ onError: (error: Error) => void;
4
+ children: React.ReactNode;
5
+ errorFallback: (info: {
6
+ error: Error;
7
+ }) => React.ReactNode;
8
+ }, {
9
+ hasError: Error | null;
10
+ }> {
11
+ state: {
12
+ hasError: null;
13
+ };
14
+ static getDerivedStateFromError(error: Error): {
15
+ hasError: Error;
16
+ };
17
+ componentDidCatch(error: Error): void;
18
+ render(): string | number | boolean | JSX.Element | React.ReactFragment | null | undefined;
19
+ }
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.ErrorBoundary = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const react_1 = __importDefault(require("react"));
9
+ const errorStyle = {
10
+ display: 'flex',
11
+ justifyContent: 'center',
12
+ alignItems: 'center',
13
+ flex: 1,
14
+ height: '100%',
15
+ width: '100%',
16
+ };
17
+ class ErrorBoundary extends react_1.default.Component {
18
+ constructor() {
19
+ super(...arguments);
20
+ this.state = { hasError: null };
21
+ }
22
+ static getDerivedStateFromError(error) {
23
+ // Update state so the next render will show the fallback UI.
24
+ return { hasError: error };
25
+ }
26
+ componentDidCatch(error) {
27
+ this.props.onError(error);
28
+ }
29
+ render() {
30
+ if (this.state.hasError) {
31
+ // You can render any custom fallback UI
32
+ return ((0, jsx_runtime_1.jsx)("div", { style: errorStyle, children: this.props.errorFallback({
33
+ error: this.state.hasError,
34
+ }) }));
35
+ }
36
+ return this.props.children;
37
+ }
38
+ }
39
+ exports.ErrorBoundary = ErrorBoundary;
@@ -0,0 +1,66 @@
1
+ declare type SeekPayload = {
2
+ frame: number;
3
+ };
4
+ declare type ErrorPayload = {
5
+ error: Error;
6
+ };
7
+ declare type TimeUpdateEventPayload = {
8
+ frame: number;
9
+ };
10
+ declare type FrameUpdateEventPayload = {
11
+ frame: number;
12
+ };
13
+ declare type RateChangeEventPayload = {
14
+ playbackRate: number;
15
+ };
16
+ declare type FullscreenChangeEventPayload = {
17
+ isFullscreen: boolean;
18
+ };
19
+ declare type PlayerStateEventMap = {
20
+ seeked: SeekPayload;
21
+ pause: undefined;
22
+ play: undefined;
23
+ ratechange: RateChangeEventPayload;
24
+ ended: undefined;
25
+ error: ErrorPayload;
26
+ timeupdate: TimeUpdateEventPayload;
27
+ frameupdate: FrameUpdateEventPayload;
28
+ fullscreenchange: FullscreenChangeEventPayload;
29
+ };
30
+ declare type ThumbnailStateEventMap = {
31
+ error: ErrorPayload;
32
+ };
33
+ export declare type PlayerEventTypes = keyof PlayerStateEventMap;
34
+ export declare type ThumbnailEventTypes = keyof ThumbnailStateEventMap;
35
+ export declare type CallbackListener<T extends PlayerEventTypes> = (data: {
36
+ detail: PlayerStateEventMap[T];
37
+ }) => void;
38
+ declare type PlayerListeners = {
39
+ [EventType in PlayerEventTypes]: CallbackListener<EventType>[];
40
+ };
41
+ declare type ThumbnailListeners = {
42
+ [EventType in ThumbnailEventTypes]: CallbackListener<EventType>[];
43
+ };
44
+ export declare class PlayerEmitter {
45
+ listeners: PlayerListeners;
46
+ addEventListener<Q extends PlayerEventTypes>(name: Q, callback: CallbackListener<Q>): void;
47
+ removeEventListener<Q extends PlayerEventTypes>(name: Q, callback: CallbackListener<Q>): void;
48
+ private dispatchEvent;
49
+ dispatchSeek(frame: number): void;
50
+ dispatchPause(): void;
51
+ dispatchPlay(): void;
52
+ dispatchEnded(): void;
53
+ dispatchRatechange(playbackRate: number): void;
54
+ dispatchError(error: Error): void;
55
+ dispatchTimeUpdate(event: TimeUpdateEventPayload): void;
56
+ dispatchFrameUpdate(event: FrameUpdateEventPayload): void;
57
+ dispatchFullscreenChangeUpdate(event: FullscreenChangeEventPayload): void;
58
+ }
59
+ export declare class ThumbnailEmitter {
60
+ listeners: ThumbnailListeners;
61
+ addEventListener<Q extends ThumbnailEventTypes>(name: Q, callback: CallbackListener<Q>): void;
62
+ removeEventListener<Q extends ThumbnailEventTypes>(name: Q, callback: CallbackListener<Q>): void;
63
+ private dispatchEvent;
64
+ dispatchError(error: Error): void;
65
+ }
66
+ export {};
@@ -0,0 +1,87 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ThumbnailEmitter = exports.PlayerEmitter = void 0;
4
+ class PlayerEmitter {
5
+ constructor() {
6
+ this.listeners = {
7
+ ended: [],
8
+ error: [],
9
+ pause: [],
10
+ play: [],
11
+ ratechange: [],
12
+ seeked: [],
13
+ timeupdate: [],
14
+ frameupdate: [],
15
+ fullscreenchange: [],
16
+ };
17
+ }
18
+ addEventListener(name, callback) {
19
+ this.listeners[name].push(callback);
20
+ }
21
+ removeEventListener(name, callback) {
22
+ this.listeners[name] = this.listeners[name].filter((l) => l !== callback);
23
+ }
24
+ dispatchEvent(dispatchName, context) {
25
+ this.listeners[dispatchName].forEach((callback) => {
26
+ callback({ detail: context });
27
+ });
28
+ }
29
+ dispatchSeek(frame) {
30
+ this.dispatchEvent('seeked', {
31
+ frame,
32
+ });
33
+ }
34
+ dispatchPause() {
35
+ this.dispatchEvent('pause', undefined);
36
+ }
37
+ dispatchPlay() {
38
+ this.dispatchEvent('play', undefined);
39
+ }
40
+ dispatchEnded() {
41
+ this.dispatchEvent('ended', undefined);
42
+ }
43
+ dispatchRatechange(playbackRate) {
44
+ this.dispatchEvent('ratechange', {
45
+ playbackRate,
46
+ });
47
+ }
48
+ dispatchError(error) {
49
+ this.dispatchEvent('error', {
50
+ error,
51
+ });
52
+ }
53
+ dispatchTimeUpdate(event) {
54
+ this.dispatchEvent('timeupdate', event);
55
+ }
56
+ dispatchFrameUpdate(event) {
57
+ this.dispatchEvent('frameupdate', event);
58
+ }
59
+ dispatchFullscreenChangeUpdate(event) {
60
+ this.dispatchEvent('fullscreenchange', event);
61
+ }
62
+ }
63
+ exports.PlayerEmitter = PlayerEmitter;
64
+ class ThumbnailEmitter {
65
+ constructor() {
66
+ this.listeners = {
67
+ error: [],
68
+ };
69
+ }
70
+ addEventListener(name, callback) {
71
+ this.listeners[name].push(callback);
72
+ }
73
+ removeEventListener(name, callback) {
74
+ this.listeners[name] = this.listeners[name].filter((l) => l !== callback);
75
+ }
76
+ dispatchEvent(dispatchName, context) {
77
+ this.listeners[dispatchName].forEach((callback) => {
78
+ callback({ detail: context });
79
+ });
80
+ }
81
+ dispatchError(error) {
82
+ this.dispatchEvent('error', {
83
+ error,
84
+ });
85
+ }
86
+ }
87
+ exports.ThumbnailEmitter = ThumbnailEmitter;
@@ -0,0 +1 @@
1
+ export declare const formatTime: (timeInSeconds: number) => string;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.formatTime = void 0;
4
+ const formatTime = (timeInSeconds) => {
5
+ const minutes = Math.floor(timeInSeconds / 60);
6
+ const seconds = Math.floor(timeInSeconds - minutes * 60);
7
+ return `${String(minutes)}:${String(seconds).padStart(2, '0')}`;
8
+ };
9
+ exports.formatTime = formatTime;