@remotion/cli 4.0.0-alpha4 → 4.0.0-alpha6

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 (489) hide show
  1. package/dist/ansi/ansi-diff.d.ts +2 -1
  2. package/dist/ansi/ansi-diff.js +14 -20
  3. package/dist/ansi/ansi-split.d.ts +1 -0
  4. package/dist/ansi/ansi-split.js +16 -3
  5. package/dist/benchmark.js +64 -23
  6. package/dist/better-opn/index.js +3 -3
  7. package/dist/cloudrun-command.d.ts +1 -0
  8. package/dist/cloudrun-command.js +27 -0
  9. package/dist/codemods/update-default-props.d.ts +5 -0
  10. package/dist/codemods/update-default-props.js +143 -0
  11. package/dist/color-math.d.ts +2 -0
  12. package/dist/color-math.js +13 -0
  13. package/dist/composition-prompts.d.ts +3 -4
  14. package/dist/composition-prompts.js +0 -1
  15. package/dist/compositions.js +10 -4
  16. package/dist/config/bitrate.d.ts +2 -2
  17. package/dist/config/bitrate.js +2 -2
  18. package/dist/config/browser.d.ts +1 -3
  19. package/dist/config/browser.js +2 -12
  20. package/dist/config/codec.d.ts +0 -4
  21. package/dist/config/codec.js +1 -21
  22. package/dist/config/image-format.d.ts +5 -3
  23. package/dist/config/image-format.js +32 -10
  24. package/dist/config/index.d.ts +255 -14
  25. package/dist/config/index.js +16 -49
  26. package/dist/config/jpeg-quality.d.ts +2 -0
  27. package/dist/config/jpeg-quality.js +17 -0
  28. package/dist/config/public-dir.d.ts +1 -1
  29. package/dist/config/scale.d.ts +2 -1
  30. package/dist/convert-entry-point-to-serve-url.d.ts +1 -0
  31. package/dist/convert-entry-point-to-serve-url.js +15 -0
  32. package/dist/determine-image-format.d.ts +5 -4
  33. package/dist/determine-image-format.js +17 -4
  34. package/dist/download-progress.d.ts +2 -2
  35. package/dist/download-progress.js +12 -3
  36. package/dist/editor/components/Canvas.js +3 -0
  37. package/dist/editor/components/Checkbox.d.ts +6 -0
  38. package/dist/editor/components/Checkbox.js +42 -0
  39. package/dist/editor/components/CheckerboardProvider.d.ts +4 -0
  40. package/dist/editor/components/CheckerboardProvider.js +24 -0
  41. package/dist/editor/components/CompositionSelector.js +2 -4
  42. package/dist/editor/components/CompositionSelectorItem.d.ts +3 -3
  43. package/dist/editor/components/CompositionSelectorItem.js +24 -6
  44. package/dist/editor/components/CurrentComposition.js +4 -19
  45. package/dist/editor/components/CurrentCompositionSideEffects.d.ts +3 -0
  46. package/dist/editor/components/CurrentCompositionSideEffects.js +51 -0
  47. package/dist/editor/components/Editor.js +2 -11
  48. package/dist/editor/components/EditorContent.js +1 -1
  49. package/dist/editor/components/EditorContexts.js +10 -86
  50. package/dist/editor/components/GlobalKeybindings.js +4 -0
  51. package/dist/editor/components/InitialCompositionLoader.d.ts +2 -2
  52. package/dist/editor/components/InlineAction.d.ts +7 -0
  53. package/dist/editor/components/InlineAction.js +31 -0
  54. package/dist/editor/components/KeyboardShortcutsExplainer.js +5 -4
  55. package/dist/editor/components/MediaVolumeProvider.d.ts +4 -0
  56. package/dist/editor/components/MediaVolumeProvider.js +25 -0
  57. package/dist/editor/components/Menu/MenuSubItem.d.ts +0 -1
  58. package/dist/editor/components/Menu/MenuSubItem.js +15 -3
  59. package/dist/editor/components/Menu/is-menu-item.d.ts +2 -0
  60. package/dist/editor/components/Menu/is-menu-item.js +3 -1
  61. package/dist/editor/components/Menu/styles.d.ts +4 -0
  62. package/dist/editor/components/Menu/styles.js +13 -4
  63. package/dist/editor/components/MenuToolbar.js +16 -3
  64. package/dist/editor/components/ModalContainer.d.ts +2 -0
  65. package/dist/editor/components/ModalContainer.js +12 -3
  66. package/dist/editor/components/ModalHeader.js +6 -2
  67. package/dist/editor/components/Modals.d.ts +2 -0
  68. package/dist/editor/components/Modals.js +23 -0
  69. package/dist/editor/components/ModalsProvider.d.ts +4 -0
  70. package/dist/editor/components/ModalsProvider.js +17 -0
  71. package/dist/editor/components/NewComposition/CancelButton.js +3 -0
  72. package/dist/editor/components/NewComposition/ComboBox.js +23 -15
  73. package/dist/editor/components/NewComposition/InputDragger.d.ts +4 -0
  74. package/dist/editor/components/NewComposition/InputDragger.js +12 -7
  75. package/dist/editor/components/NewComposition/MenuContent.js +14 -1
  76. package/dist/editor/components/NewComposition/NewCompDuration.js +2 -2
  77. package/dist/editor/components/NewComposition/NewComposition.js +8 -5
  78. package/dist/editor/components/NewComposition/RemInput.d.ts +14 -2
  79. package/dist/editor/components/NewComposition/RemInput.js +24 -9
  80. package/dist/editor/components/NewComposition/RemInputTypeColor.d.ts +7 -0
  81. package/dist/editor/components/NewComposition/RemInputTypeColor.js +53 -0
  82. package/dist/editor/components/NewComposition/RemTextarea.d.ts +7 -0
  83. package/dist/editor/components/NewComposition/RemTextarea.js +92 -0
  84. package/dist/editor/components/NewComposition/ValidationMessage.d.ts +2 -0
  85. package/dist/editor/components/NewComposition/ValidationMessage.js +18 -8
  86. package/dist/editor/components/Notifications/NotificationCenter.d.ts +1 -0
  87. package/dist/editor/components/Notifications/NotificationCenter.js +11 -1
  88. package/dist/editor/components/Notifications/ServerDisconnected.d.ts +0 -4
  89. package/dist/editor/components/Notifications/ServerDisconnected.js +4 -14
  90. package/dist/editor/components/PlayPause.js +6 -0
  91. package/dist/editor/components/PlaybackKeyboardShortcutsManager.js +3 -0
  92. package/dist/editor/components/PlaybackRateSelector.d.ts +0 -2
  93. package/dist/editor/components/PlaybackRateSelector.js +5 -6
  94. package/dist/editor/components/PlayerEmitterContext.d.ts +4 -0
  95. package/dist/editor/components/PlayerEmitterContext.js +11 -0
  96. package/dist/editor/components/Preview.d.ts +0 -1
  97. package/dist/editor/components/Preview.js +4 -4
  98. package/dist/editor/components/PreviewToolbar.js +2 -2
  99. package/dist/editor/components/QuickSwitcher/QuickSwitcherContent.js +8 -3
  100. package/dist/editor/components/QuickSwitcher/QuickSwitcherResult.js +4 -2
  101. package/dist/editor/components/QuickSwitcher/algolia-search.d.ts +0 -27
  102. package/dist/editor/components/QuickSwitcher/algolia-search.js +2 -3
  103. package/dist/editor/components/RenderButton.d.ts +2 -0
  104. package/dist/editor/components/RenderButton.js +103 -0
  105. package/dist/editor/components/RenderModal/CliCopyButton.d.ts +4 -0
  106. package/dist/editor/components/RenderModal/CliCopyButton.js +55 -0
  107. package/dist/editor/components/RenderModal/CrfSetting.d.ts +15 -0
  108. package/dist/editor/components/RenderModal/CrfSetting.js +42 -0
  109. package/dist/editor/components/RenderModal/EnforceAudioTrackSetting.d.ts +8 -0
  110. package/dist/editor/components/RenderModal/EnforceAudioTrackSetting.js +16 -0
  111. package/dist/editor/components/RenderModal/EnvInput.d.ts +11 -0
  112. package/dist/editor/components/RenderModal/EnvInput.js +74 -0
  113. package/dist/editor/components/RenderModal/FrameRangeSetting.d.ts +8 -0
  114. package/dist/editor/components/RenderModal/FrameRangeSetting.js +42 -0
  115. package/dist/editor/components/RenderModal/GuiRenderStatus.d.ts +5 -0
  116. package/dist/editor/components/RenderModal/GuiRenderStatus.js +78 -0
  117. package/dist/editor/components/RenderModal/InfoBubble.d.ts +5 -0
  118. package/dist/editor/components/RenderModal/InfoBubble.js +115 -0
  119. package/dist/editor/components/RenderModal/InfoTooltip.d.ts +5 -0
  120. package/dist/editor/components/RenderModal/InfoTooltip.js +41 -0
  121. package/dist/editor/components/RenderModal/InlineEyeIcon.d.ts +5 -0
  122. package/dist/editor/components/RenderModal/InlineEyeIcon.js +17 -0
  123. package/dist/editor/components/RenderModal/InlineRemoveButton.d.ts +4 -0
  124. package/dist/editor/components/RenderModal/InlineRemoveButton.js +17 -0
  125. package/dist/editor/components/RenderModal/JpegQualitySetting.d.ts +5 -0
  126. package/dist/editor/components/RenderModal/JpegQualitySetting.js +12 -0
  127. package/dist/editor/components/RenderModal/MutedSetting.d.ts +8 -0
  128. package/dist/editor/components/RenderModal/MutedSetting.js +16 -0
  129. package/dist/editor/components/RenderModal/NumberOfLoopsSetting.d.ts +5 -0
  130. package/dist/editor/components/RenderModal/NumberOfLoopsSetting.js +26 -0
  131. package/dist/editor/components/RenderModal/NumberSetting.d.ts +12 -0
  132. package/dist/editor/components/RenderModal/NumberSetting.js +29 -0
  133. package/dist/editor/components/RenderModal/OptionExplainer.d.ts +5 -0
  134. package/dist/editor/components/RenderModal/OptionExplainer.js +55 -0
  135. package/dist/editor/components/RenderModal/RenderModal.d.ts +35 -0
  136. package/dist/editor/components/RenderModal/RenderModal.js +597 -0
  137. package/dist/editor/components/RenderModal/RenderModalAdvanced.d.ts +26 -0
  138. package/dist/editor/components/RenderModal/RenderModalAdvanced.js +61 -0
  139. package/dist/editor/components/RenderModal/RenderModalAudio.d.ts +17 -0
  140. package/dist/editor/components/RenderModal/RenderModalAudio.js +46 -0
  141. package/dist/editor/components/RenderModal/RenderModalBasic.d.ts +23 -0
  142. package/dist/editor/components/RenderModal/RenderModalBasic.js +79 -0
  143. package/dist/editor/components/RenderModal/RenderModalData.d.ts +20 -0
  144. package/dist/editor/components/RenderModal/RenderModalData.js +249 -0
  145. package/dist/editor/components/RenderModal/RenderModalEnvironmentVariables.d.ts +5 -0
  146. package/dist/editor/components/RenderModal/RenderModalEnvironmentVariables.js +55 -0
  147. package/dist/editor/components/RenderModal/RenderModalGif.d.ts +9 -0
  148. package/dist/editor/components/RenderModal/RenderModalGif.js +19 -0
  149. package/dist/editor/components/RenderModal/RenderModalHr.d.ts +2 -0
  150. package/dist/editor/components/RenderModal/RenderModalHr.js +18 -0
  151. package/dist/editor/components/RenderModal/RenderModalInput.d.ts +10 -0
  152. package/dist/editor/components/RenderModal/RenderModalInput.js +13 -0
  153. package/dist/editor/components/RenderModal/RenderModalJSONPropsEditor.d.ts +15 -0
  154. package/dist/editor/components/RenderModal/RenderModalJSONPropsEditor.js +109 -0
  155. package/dist/editor/components/RenderModal/RenderModalPicture.d.ts +28 -0
  156. package/dist/editor/components/RenderModal/RenderModalPicture.js +54 -0
  157. package/dist/editor/components/RenderModal/RenderStatusModal.d.ts +4 -0
  158. package/dist/editor/components/RenderModal/RenderStatusModal.js +72 -0
  159. package/dist/editor/components/RenderModal/ScaleSetting.d.ts +5 -0
  160. package/dist/editor/components/RenderModal/ScaleSetting.js +17 -0
  161. package/dist/editor/components/RenderModal/SchemaEditor/SchemaEditor.d.ts +13 -0
  162. package/dist/editor/components/RenderModal/SchemaEditor/SchemaEditor.js +39 -0
  163. package/dist/editor/components/RenderModal/SchemaEditor/SchemaEmptyStateGraphic.d.ts +2 -0
  164. package/dist/editor/components/RenderModal/SchemaEditor/SchemaEmptyStateGraphic.js +15 -0
  165. package/dist/editor/components/RenderModal/SchemaEditor/SchemaErrorMessages.d.ts +12 -0
  166. package/dist/editor/components/RenderModal/SchemaEditor/SchemaErrorMessages.js +59 -0
  167. package/dist/editor/components/RenderModal/SchemaEditor/SchemaLabel.d.ts +16 -0
  168. package/dist/editor/components/RenderModal/SchemaEditor/SchemaLabel.js +40 -0
  169. package/dist/editor/components/RenderModal/SchemaEditor/SchemaResetButton.d.ts +4 -0
  170. package/dist/editor/components/RenderModal/SchemaEditor/SchemaResetButton.js +17 -0
  171. package/dist/editor/components/RenderModal/SchemaEditor/SchemaSaveButton.d.ts +5 -0
  172. package/dist/editor/components/RenderModal/SchemaEditor/SchemaSaveButton.js +17 -0
  173. package/dist/editor/components/RenderModal/SchemaEditor/ZodArrayEditor.d.ts +15 -0
  174. package/dist/editor/components/RenderModal/SchemaEditor/ZodArrayEditor.js +84 -0
  175. package/dist/editor/components/RenderModal/SchemaEditor/ZodArrayItemEditor.d.ts +14 -0
  176. package/dist/editor/components/RenderModal/SchemaEditor/ZodArrayItemEditor.js +28 -0
  177. package/dist/editor/components/RenderModal/SchemaEditor/ZodBooleanEditor.d.ts +13 -0
  178. package/dist/editor/components/RenderModal/SchemaEditor/ZodBooleanEditor.js +27 -0
  179. package/dist/editor/components/RenderModal/SchemaEditor/ZodColorEditor.d.ts +15 -0
  180. package/dist/editor/components/RenderModal/SchemaEditor/ZodColorEditor.js +116 -0
  181. package/dist/editor/components/RenderModal/SchemaEditor/ZodDateEditor.d.ts +15 -0
  182. package/dist/editor/components/RenderModal/SchemaEditor/ZodDateEditor.js +76 -0
  183. package/dist/editor/components/RenderModal/SchemaEditor/ZodEffectEditor.d.ts +15 -0
  184. package/dist/editor/components/RenderModal/SchemaEditor/ZodEffectEditor.js +55 -0
  185. package/dist/editor/components/RenderModal/SchemaEditor/ZodEnumEditor.d.ts +15 -0
  186. package/dist/editor/components/RenderModal/SchemaEditor/ZodEnumEditor.js +72 -0
  187. package/dist/editor/components/RenderModal/SchemaEditor/ZodErrorMessages.d.ts +5 -0
  188. package/dist/editor/components/RenderModal/SchemaEditor/ZodErrorMessages.js +23 -0
  189. package/dist/editor/components/RenderModal/SchemaEditor/ZodNonEditableValue.d.ts +9 -0
  190. package/dist/editor/components/RenderModal/SchemaEditor/ZodNonEditableValue.js +27 -0
  191. package/dist/editor/components/RenderModal/SchemaEditor/ZodNullableEditor.d.ts +15 -0
  192. package/dist/editor/components/RenderModal/SchemaEditor/ZodNullableEditor.js +10 -0
  193. package/dist/editor/components/RenderModal/SchemaEditor/ZodNumberEditor.d.ts +15 -0
  194. package/dist/editor/components/RenderModal/SchemaEditor/ZodNumberEditor.js +88 -0
  195. package/dist/editor/components/RenderModal/SchemaEditor/ZodObjectEditor.d.ts +15 -0
  196. package/dist/editor/components/RenderModal/SchemaEditor/ZodObjectEditor.js +64 -0
  197. package/dist/editor/components/RenderModal/SchemaEditor/ZodOptionalEditor.d.ts +15 -0
  198. package/dist/editor/components/RenderModal/SchemaEditor/ZodOptionalEditor.js +10 -0
  199. package/dist/editor/components/RenderModal/SchemaEditor/ZodOrNullishEditor.d.ts +16 -0
  200. package/dist/editor/components/RenderModal/SchemaEditor/ZodOrNullishEditor.js +52 -0
  201. package/dist/editor/components/RenderModal/SchemaEditor/ZodStringEditor.d.ts +15 -0
  202. package/dist/editor/components/RenderModal/SchemaEditor/ZodStringEditor.js +48 -0
  203. package/dist/editor/components/RenderModal/SchemaEditor/ZodSwitch.d.ts +15 -0
  204. package/dist/editor/components/RenderModal/SchemaEditor/ZodSwitch.js +84 -0
  205. package/dist/editor/components/RenderModal/SchemaEditor/ZodUnionEditor.d.ts +15 -0
  206. package/dist/editor/components/RenderModal/SchemaEditor/ZodUnionEditor.js +49 -0
  207. package/dist/editor/components/RenderModal/SchemaEditor/create-zod-values.d.ts +2 -0
  208. package/dist/editor/components/RenderModal/SchemaEditor/create-zod-values.js +158 -0
  209. package/dist/editor/components/RenderModal/SchemaEditor/date-serialization.d.ts +6 -0
  210. package/dist/editor/components/RenderModal/SchemaEditor/date-serialization.js +24 -0
  211. package/dist/editor/components/RenderModal/SchemaEditor/get-schema-label.d.ts +2 -0
  212. package/dist/editor/components/RenderModal/SchemaEditor/get-schema-label.js +15 -0
  213. package/dist/editor/components/RenderModal/SchemaEditor/zod-types.d.ts +1 -0
  214. package/dist/editor/components/RenderModal/SchemaEditor/zod-types.js +2 -0
  215. package/dist/editor/components/RenderModal/WarningIndicatorButton.d.ts +6 -0
  216. package/dist/editor/components/RenderModal/WarningIndicatorButton.js +49 -0
  217. package/dist/editor/components/RenderModal/get-render-modal-warnings.d.ts +15 -0
  218. package/dist/editor/components/RenderModal/get-render-modal-warnings.js +34 -0
  219. package/dist/editor/components/RenderModal/human-readable-audio-codecs.d.ts +2 -0
  220. package/dist/editor/components/RenderModal/human-readable-audio-codecs.js +18 -0
  221. package/dist/editor/components/RenderModal/human-readable-codec.d.ts +2 -0
  222. package/dist/editor/components/RenderModal/human-readable-codec.js +36 -0
  223. package/dist/editor/components/RenderModal/layout.d.ts +7 -0
  224. package/dist/editor/components/RenderModal/layout.js +45 -0
  225. package/dist/editor/components/RenderModal/out-name-checker.d.ts +14 -0
  226. package/dist/editor/components/RenderModal/out-name-checker.js +80 -0
  227. package/dist/editor/components/RenderQueue/CircularProgress.d.ts +5 -0
  228. package/dist/editor/components/RenderQueue/CircularProgress.js +18 -0
  229. package/dist/editor/components/RenderQueue/RenderQueueError.d.ts +5 -0
  230. package/dist/editor/components/RenderQueue/RenderQueueError.js +26 -0
  231. package/dist/editor/components/RenderQueue/RenderQueueItem.d.ts +5 -0
  232. package/dist/editor/components/RenderQueue/RenderQueueItem.js +40 -0
  233. package/dist/editor/components/RenderQueue/RenderQueueItemCancelButton.d.ts +5 -0
  234. package/dist/editor/components/RenderQueue/RenderQueueItemCancelButton.js +26 -0
  235. package/dist/editor/components/RenderQueue/RenderQueueItemStatus.d.ts +5 -0
  236. package/dist/editor/components/RenderQueue/RenderQueueItemStatus.js +43 -0
  237. package/dist/editor/components/RenderQueue/RenderQueueOpenInFolder.d.ts +5 -0
  238. package/dist/editor/components/RenderQueue/RenderQueueOpenInFolder.js +26 -0
  239. package/dist/editor/components/RenderQueue/RenderQueueOutputName.d.ts +5 -0
  240. package/dist/editor/components/RenderQueue/RenderQueueOutputName.js +26 -0
  241. package/dist/editor/components/RenderQueue/RenderQueueProgressMessage.d.ts +5 -0
  242. package/dist/editor/components/RenderQueue/RenderQueueProgressMessage.js +26 -0
  243. package/dist/editor/components/RenderQueue/RenderQueueRemoveItem.d.ts +5 -0
  244. package/dist/editor/components/RenderQueue/RenderQueueRemoveItem.js +37 -0
  245. package/dist/editor/components/RenderQueue/RenderQueueRepeat.d.ts +5 -0
  246. package/dist/editor/components/RenderQueue/RenderQueueRepeat.js +26 -0
  247. package/dist/editor/components/RenderQueue/SuccessIcon.d.ts +2 -0
  248. package/dist/editor/components/RenderQueue/SuccessIcon.js +14 -0
  249. package/dist/editor/components/RenderQueue/actions.d.ts +58 -0
  250. package/dist/editor/components/RenderQueue/actions.js +120 -0
  251. package/dist/editor/components/RenderQueue/context.d.ts +18 -0
  252. package/dist/editor/components/RenderQueue/context.js +49 -0
  253. package/dist/editor/components/RenderQueue/index.d.ts +2 -0
  254. package/dist/editor/components/RenderQueue/index.js +43 -0
  255. package/dist/editor/components/RenderQueue/item-style.d.ts +2 -0
  256. package/dist/editor/components/RenderQueue/item-style.js +21 -0
  257. package/dist/editor/components/RendersTab.d.ts +6 -0
  258. package/dist/editor/components/RendersTab.js +43 -0
  259. package/dist/editor/components/RightPanel.d.ts +8 -0
  260. package/dist/editor/components/RightPanel.js +76 -0
  261. package/dist/editor/components/SegmentedControl.d.ts +11 -0
  262. package/dist/editor/components/SegmentedControl.js +62 -0
  263. package/dist/editor/components/SetTimelineInOutProvider.d.ts +4 -0
  264. package/dist/editor/components/SetTimelineInOutProvider.js +19 -0
  265. package/dist/editor/components/SidebarCollapserControls.d.ts +2 -0
  266. package/dist/editor/components/SidebarCollapserControls.js +135 -0
  267. package/dist/editor/components/SidebarRenderButton.d.ts +6 -0
  268. package/dist/editor/components/SidebarRenderButton.js +85 -0
  269. package/dist/editor/components/SizeSelector.d.ts +0 -1
  270. package/dist/editor/components/SizeSelector.js +3 -3
  271. package/dist/editor/components/Splitter/SplitterHandle.d.ts +1 -2
  272. package/dist/editor/components/Splitter/SplitterHandle.js +15 -7
  273. package/dist/editor/components/Tabs/index.d.ts +11 -0
  274. package/dist/editor/components/Tabs/index.js +58 -0
  275. package/dist/editor/components/Tabs/vertical.d.ts +7 -0
  276. package/dist/editor/components/Tabs/vertical.js +43 -0
  277. package/dist/editor/components/Timeline/MaxTimelineTracks.js +1 -1
  278. package/dist/editor/components/Timeline/Timeline.js +1 -1
  279. package/dist/editor/components/Timeline/TimelineCollapseToggle.d.ts +1 -0
  280. package/dist/editor/components/Timeline/TimelineCollapseToggle.js +4 -5
  281. package/dist/editor/components/Timeline/TimelineListItem.js +2 -1
  282. package/dist/editor/components/Timeline/TimelineScrollable.js +2 -1
  283. package/dist/editor/components/Timeline/TimelineSequence.js +2 -14
  284. package/dist/editor/components/Timeline/TimelineSequenceFrame.js +2 -1
  285. package/dist/editor/components/Timeline/TimelineZoomControls.js +2 -5
  286. package/dist/editor/components/Timeline/imperative-state.d.ts +0 -4
  287. package/dist/editor/components/Timeline/imperative-state.js +13 -13
  288. package/dist/editor/components/Timeline/is-collapsed.js +2 -3
  289. package/dist/editor/components/Timeline/timeline-scroll-logic.d.ts +0 -1
  290. package/dist/editor/components/Timeline/timeline-scroll-logic.js +5 -6
  291. package/dist/editor/components/TimelineInOutToggle.js +3 -0
  292. package/dist/editor/components/TopPanel.d.ts +1 -0
  293. package/dist/editor/components/TopPanel.js +30 -16
  294. package/dist/editor/components/ZoomGesturesProvider.d.ts +4 -0
  295. package/dist/editor/components/ZoomGesturesProvider.js +24 -0
  296. package/dist/editor/components/ZoomPersistor.d.ts +0 -1
  297. package/dist/editor/components/ZoomPersistor.js +2 -3
  298. package/dist/editor/components/get-zod-if-possible.d.ts +10 -0
  299. package/dist/editor/components/get-zod-if-possible.js +79 -0
  300. package/dist/editor/components/layout.d.ts +3 -1
  301. package/dist/editor/components/layout.js +9 -7
  302. package/dist/editor/helpers/calculate-timeline.d.ts +0 -4
  303. package/dist/editor/helpers/client-id.d.ts +17 -0
  304. package/dist/editor/helpers/client-id.js +46 -0
  305. package/dist/editor/helpers/colors.d.ts +4 -2
  306. package/dist/editor/helpers/colors.js +7 -4
  307. package/dist/editor/helpers/convert-env-variables.d.ts +2 -0
  308. package/dist/editor/helpers/convert-env-variables.js +20 -0
  309. package/dist/editor/helpers/create-folder-tree.d.ts +2 -3
  310. package/dist/editor/helpers/create-folder-tree.js +3 -4
  311. package/dist/editor/helpers/get-timeline-sequence-layout.d.ts +2 -2
  312. package/dist/editor/helpers/get-timeline-sequence-sort-key.d.ts +2 -1
  313. package/dist/editor/helpers/is-composition-still.d.ts +2 -2
  314. package/dist/editor/helpers/is-composition-still.js +3 -0
  315. package/dist/editor/helpers/prores-labels.d.ts +2 -0
  316. package/dist/editor/helpers/prores-labels.js +25 -0
  317. package/dist/editor/helpers/render-modal-sections.d.ts +10 -0
  318. package/dist/editor/helpers/render-modal-sections.js +32 -0
  319. package/dist/editor/helpers/use-breakpoint.d.ts +1 -0
  320. package/dist/editor/helpers/use-breakpoint.js +17 -0
  321. package/dist/editor/helpers/use-file-existence.d.ts +1 -0
  322. package/dist/editor/helpers/use-file-existence.js +66 -0
  323. package/dist/editor/helpers/use-keybinding.d.ts +1 -0
  324. package/dist/editor/helpers/use-keybinding.js +9 -0
  325. package/dist/editor/helpers/use-menu-structure.js +99 -51
  326. package/dist/editor/helpers/validate-new-comp-data.d.ts +2 -2
  327. package/dist/editor/icons/Checkmark.js +1 -1
  328. package/dist/editor/icons/audio.d.ts +2 -0
  329. package/dist/editor/icons/audio.js +6 -0
  330. package/dist/editor/icons/caret.d.ts +4 -1
  331. package/dist/editor/icons/caret.js +17 -1
  332. package/dist/editor/icons/data.d.ts +2 -0
  333. package/dist/editor/icons/data.js +8 -0
  334. package/dist/editor/icons/file.d.ts +2 -0
  335. package/dist/editor/icons/file.js +6 -0
  336. package/dist/editor/icons/folder.d.ts +6 -2
  337. package/dist/editor/icons/folder.js +4 -4
  338. package/dist/editor/icons/frame.d.ts +2 -0
  339. package/dist/editor/icons/frame.js +6 -0
  340. package/dist/editor/icons/gear.d.ts +2 -0
  341. package/dist/editor/icons/gear.js +6 -0
  342. package/dist/editor/icons/gif.d.ts +2 -0
  343. package/dist/editor/icons/gif.js +6 -0
  344. package/dist/editor/icons/render.d.ts +9 -0
  345. package/dist/editor/icons/render.js +12 -0
  346. package/dist/editor/icons/still.d.ts +3 -1
  347. package/dist/editor/icons/still.js +2 -2
  348. package/dist/editor/icons/video.d.ts +5 -0
  349. package/dist/editor/icons/video.js +8 -0
  350. package/dist/editor/state/keybindings.d.ts +2 -1
  351. package/dist/editor/state/modals.d.ts +38 -0
  352. package/dist/editor/state/preview-size.d.ts +0 -1
  353. package/dist/editor/state/preview-size.js +3 -4
  354. package/dist/editor/state/sidebar.d.ts +7 -3
  355. package/dist/editor/state/sidebar.js +42 -13
  356. package/dist/editor/state/timeline-ref.d.ts +2 -1
  357. package/dist/editor/state/z-index.d.ts +0 -5
  358. package/dist/editor/state/z-index.js +16 -6
  359. package/dist/entry-point.js +17 -17
  360. package/dist/event-source-events.d.ts +15 -0
  361. package/dist/event-source.d.ts +2 -0
  362. package/dist/event-source.js +31 -5
  363. package/dist/ffmpeg.d.ts +2 -0
  364. package/dist/ffmpeg.js +26 -0
  365. package/dist/file-watcher.d.ts +9 -0
  366. package/dist/file-watcher.js +35 -0
  367. package/dist/get-cli-options.d.ts +3 -12
  368. package/dist/get-cli-options.js +11 -64
  369. package/dist/get-composition-id.d.ts +7 -3
  370. package/dist/get-composition-id.js +17 -3
  371. package/dist/get-composition-with-dimension-override.d.ts +5 -4
  372. package/dist/get-composition-with-dimension-override.js +6 -2
  373. package/dist/get-config-file-name.d.ts +0 -2
  374. package/dist/get-config-file-name.js +11 -11
  375. package/dist/get-default-out-name.d.ts +5 -0
  376. package/dist/get-default-out-name.js +10 -0
  377. package/dist/get-env.d.ts +1 -1
  378. package/dist/get-env.js +48 -57
  379. package/dist/get-filename.d.ts +5 -1
  380. package/dist/get-filename.js +6 -4
  381. package/dist/get-final-output-codec.d.ts +2 -1
  382. package/dist/get-final-output-codec.js +4 -1
  383. package/dist/get-input-props.d.ts +1 -5
  384. package/dist/get-input-props.js +18 -20
  385. package/dist/get-network-address.js +2 -2
  386. package/dist/image-formats.d.ts +5 -2
  387. package/dist/image-formats.js +16 -6
  388. package/dist/index.d.ts +91 -22
  389. package/dist/index.js +16 -13
  390. package/dist/list-of-remotion-packages.js +1 -0
  391. package/dist/load-config.js +9 -9
  392. package/dist/log.d.ts +14 -0
  393. package/dist/log.js +24 -8
  394. package/dist/parse-command-line.d.ts +5 -5
  395. package/dist/parse-command-line.js +6 -14
  396. package/dist/preview-server/api-routes.d.ts +4 -0
  397. package/dist/preview-server/api-routes.js +21 -0
  398. package/dist/preview-server/api-types.d.ts +25 -0
  399. package/dist/preview-server/api-types.js +2 -0
  400. package/dist/preview-server/dev-middleware/compatible-api.d.ts +2 -2
  401. package/dist/preview-server/dev-middleware/middleware.d.ts +1 -2
  402. package/dist/preview-server/dev-middleware/middleware.js +8 -9
  403. package/dist/preview-server/error-overlay/react-overlay/utils/get-file-source.js +5 -5
  404. package/dist/preview-server/error-overlay/react-overlay/utils/open-in-editor.js +17 -17
  405. package/dist/preview-server/error-overlay/remotion-overlay/AskOnDiscord.js +1 -0
  406. package/dist/preview-server/error-overlay/remotion-overlay/Button.d.ts +8 -4
  407. package/dist/preview-server/error-overlay/remotion-overlay/Button.js +12 -8
  408. package/dist/preview-server/error-overlay/remotion-overlay/ErrorDisplay.js +2 -1
  409. package/dist/preview-server/error-overlay/remotion-overlay/HelpLink.js +1 -0
  410. package/dist/preview-server/error-overlay/remotion-overlay/OpenInEditor.js +1 -0
  411. package/dist/preview-server/error-overlay/remotion-overlay/SearchGitHubIssues.js +1 -0
  412. package/dist/preview-server/error-overlay/remotion-overlay/ShortcutHint.js +16 -1
  413. package/dist/preview-server/file-existence-watchers.d.ts +13 -0
  414. package/dist/preview-server/file-existence-watchers.js +62 -0
  415. package/dist/preview-server/get-absolute-public-dir.js +3 -3
  416. package/dist/preview-server/get-package-manager.js +3 -3
  417. package/dist/preview-server/handler.d.ts +9 -0
  418. package/dist/preview-server/handler.js +34 -0
  419. package/dist/preview-server/hot-middleware/client.js +2 -2
  420. package/dist/preview-server/hot-middleware/index.d.ts +1 -1
  421. package/dist/preview-server/hot-middleware/index.js +2 -2
  422. package/dist/preview-server/live-events.d.ts +3 -1
  423. package/dist/preview-server/live-events.js +22 -2
  424. package/dist/preview-server/parse-body.d.ts +2 -0
  425. package/dist/preview-server/parse-body.js +16 -0
  426. package/dist/preview-server/project-info.js +5 -5
  427. package/dist/preview-server/public-folder.d.ts +0 -5
  428. package/dist/preview-server/public-folder.js +11 -12
  429. package/dist/preview-server/render-queue/get-default-video-contexts.d.ts +10 -0
  430. package/dist/preview-server/render-queue/get-default-video-contexts.js +13 -0
  431. package/dist/preview-server/render-queue/job.d.ts +138 -0
  432. package/dist/preview-server/render-queue/job.js +2 -0
  433. package/dist/preview-server/render-queue/make-retry-payload.d.ts +3 -0
  434. package/dist/preview-server/render-queue/make-retry-payload.js +91 -0
  435. package/dist/preview-server/render-queue/open-directory-in-finder.d.ts +1 -0
  436. package/dist/preview-server/render-queue/open-directory-in-finder.js +43 -0
  437. package/dist/preview-server/render-queue/process-still.d.ts +8 -0
  438. package/dist/preview-server/render-queue/process-still.js +46 -0
  439. package/dist/preview-server/render-queue/process-video.d.ts +8 -0
  440. package/dist/preview-server/render-queue/process-video.js +63 -0
  441. package/dist/preview-server/render-queue/queue.d.ts +9 -0
  442. package/dist/preview-server/render-queue/queue.js +212 -0
  443. package/dist/preview-server/routes/add-render.d.ts +3 -0
  444. package/dist/preview-server/routes/add-render.js +76 -0
  445. package/dist/preview-server/routes/can-update-default-props.d.ts +4 -0
  446. package/dist/preview-server/routes/can-update-default-props.js +39 -0
  447. package/dist/preview-server/routes/cancel-render.d.ts +3 -0
  448. package/dist/preview-server/routes/cancel-render.js +9 -0
  449. package/dist/preview-server/routes/open-in-file-explorer.d.ts +3 -0
  450. package/dist/preview-server/routes/open-in-file-explorer.js +8 -0
  451. package/dist/preview-server/routes/remove-render.d.ts +3 -0
  452. package/dist/preview-server/routes/remove-render.js +9 -0
  453. package/dist/preview-server/routes/subscribe-to-file-existence.d.ts +3 -0
  454. package/dist/preview-server/routes/subscribe-to-file-existence.js +13 -0
  455. package/dist/preview-server/routes/unsubscribe-from-file-existence.d.ts +3 -0
  456. package/dist/preview-server/routes/unsubscribe-from-file-existence.js +13 -0
  457. package/dist/preview-server/routes/update-default-props.d.ts +3 -0
  458. package/dist/preview-server/routes/update-default-props.js +24 -0
  459. package/dist/preview-server/routes.d.ts +3 -2
  460. package/dist/preview-server/routes.js +79 -21
  461. package/dist/preview-server/serve-static.d.ts +1 -1
  462. package/dist/preview-server/serve-static.js +7 -7
  463. package/dist/preview-server/start-server.js +3 -2
  464. package/dist/preview.js +12 -25
  465. package/dist/previewEntry.js +2 -3
  466. package/dist/print-compositions.d.ts +2 -2
  467. package/dist/print-error.js +4 -2
  468. package/dist/print-help.js +4 -8
  469. package/dist/progress-bar.d.ts +17 -37
  470. package/dist/progress-bar.js +102 -41
  471. package/dist/progress-types.d.ts +32 -0
  472. package/dist/progress-types.js +17 -0
  473. package/dist/render-flows/render.d.ts +47 -0
  474. package/dist/render-flows/render.js +293 -0
  475. package/dist/render-flows/still.d.ts +29 -0
  476. package/dist/render-flows/still.js +174 -0
  477. package/dist/render.js +42 -232
  478. package/dist/required-chromium-options.d.ts +3 -0
  479. package/dist/required-chromium-options.js +2 -0
  480. package/dist/resolve-from.js +5 -5
  481. package/dist/select-composition.d.ts +2 -1
  482. package/dist/setup-cache.d.ts +12 -9
  483. package/dist/setup-cache.js +29 -20
  484. package/dist/still.js +25 -130
  485. package/dist/upgrade.js +2 -2
  486. package/dist/user-passed-output-location.js +2 -7
  487. package/dist/versions.js +2 -2
  488. package/package.json +22 -7
  489. package/styles/styles.css +13 -3
@@ -0,0 +1,293 @@
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.renderVideoFlow = void 0;
7
+ const renderer_1 = require("@remotion/renderer");
8
+ const node_fs_1 = __importDefault(require("node:fs"));
9
+ const node_os_1 = __importDefault(require("node:os"));
10
+ const node_path_1 = __importDefault(require("node:path"));
11
+ const chalk_1 = require("../chalk");
12
+ const config_1 = require("../config");
13
+ const get_cli_options_1 = require("../get-cli-options");
14
+ const get_composition_with_dimension_override_1 = require("../get-composition-with-dimension-override");
15
+ const get_filename_1 = require("../get-filename");
16
+ const get_final_output_codec_1 = require("../get-final-output-codec");
17
+ const image_formats_1 = require("../image-formats");
18
+ const log_1 = require("../log");
19
+ const parse_command_line_1 = require("../parse-command-line");
20
+ const progress_bar_1 = require("../progress-bar");
21
+ const setup_cache_1 = require("../setup-cache");
22
+ const truthy_1 = require("../truthy");
23
+ const user_passed_output_location_1 = require("../user-passed-output-location");
24
+ const renderVideoFlow = async ({ remotionRoot, fullEntryPoint, indent, logLevel, browserExecutable, browser, chromiumOptions, scale, shouldOutputImageSequence, publicDir, inputProps, envVariables, puppeteerTimeout, port, height, width, remainingArgs, compositionIdFromUi, entryPointReason, overwrite, quiet, concurrency, frameRange, everyNthFrame, outputLocationFromUI, jpegQuality, onProgress, addCleanupCallback, cancelSignal, crf, uiCodec, uiImageFormat, ffmpegOverride, audioBitrate, muted, enforceAudioTrack, proResProfile, pixelFormat, videoBitrate, numberOfGifLoops, audioCodec, disallowParallelEncoding, }) => {
25
+ var _a;
26
+ const downloads = [];
27
+ const downloadMap = renderer_1.RenderInternals.makeDownloadMap();
28
+ addCleanupCallback(() => renderer_1.RenderInternals.cleanDownloadMap(downloadMap));
29
+ log_1.Log.verboseAdvanced({ indent, logLevel }, 'Browser executable: ', browserExecutable);
30
+ log_1.Log.verboseAdvanced({ indent, logLevel }, 'Asset dirs', downloadMap.assetDir);
31
+ const browserInstance = (0, renderer_1.openBrowser)(browser, {
32
+ browserExecutable,
33
+ shouldDumpIo: renderer_1.RenderInternals.isEqualOrBelowLogLevel(logLevel, 'verbose'),
34
+ chromiumOptions,
35
+ forceDeviceScaleFactor: scale,
36
+ indentationString: indent ? log_1.INDENT_TOKEN + ' ' : '',
37
+ });
38
+ const renderProgress = (0, progress_bar_1.createOverwriteableCliOutput)({
39
+ quiet,
40
+ cancelSignal,
41
+ });
42
+ const steps = [
43
+ renderer_1.RenderInternals.isServeUrl(fullEntryPoint) ? null : 'bundling',
44
+ 'rendering',
45
+ shouldOutputImageSequence ? null : 'stitching',
46
+ ].filter(truthy_1.truthy);
47
+ let bundlingProgress = {
48
+ doneIn: null,
49
+ progress: 0,
50
+ };
51
+ let renderingProgress = null;
52
+ let stitchingProgress = null;
53
+ let copyingState = {
54
+ bytes: 0,
55
+ doneIn: null,
56
+ };
57
+ const updateRenderProgress = () => {
58
+ const aggregateRenderProgress = {
59
+ rendering: renderingProgress,
60
+ stitching: shouldOutputImageSequence ? null : stitchingProgress,
61
+ downloads,
62
+ bundling: bundlingProgress,
63
+ copyingState,
64
+ };
65
+ const { output, message, progress } = (0, progress_bar_1.makeRenderingAndStitchingProgress)({
66
+ prog: aggregateRenderProgress,
67
+ indent,
68
+ steps: steps.length,
69
+ stitchingStep: steps.indexOf('bundling'),
70
+ });
71
+ onProgress({ message, value: progress, ...aggregateRenderProgress });
72
+ return renderProgress.update(output);
73
+ };
74
+ const { urlOrBundle, cleanup: cleanupBundle } = await (0, setup_cache_1.bundleOnCliOrTakeServeUrl)({
75
+ fullPath: fullEntryPoint,
76
+ remotionRoot,
77
+ publicDir,
78
+ onProgress: ({ bundling, copying }) => {
79
+ bundlingProgress = bundling;
80
+ copyingState = copying;
81
+ updateRenderProgress();
82
+ },
83
+ indentOutput: indent,
84
+ logLevel,
85
+ bundlingStep: steps.indexOf('bundling'),
86
+ steps: steps.length,
87
+ onDirectoryCreated: (dir) => {
88
+ addCleanupCallback(() => renderer_1.RenderInternals.deleteDirectory(dir));
89
+ },
90
+ });
91
+ addCleanupCallback(() => cleanupBundle());
92
+ const onDownload = (src) => {
93
+ const id = Math.random();
94
+ const download = {
95
+ id,
96
+ name: src,
97
+ progress: 0,
98
+ downloaded: 0,
99
+ totalBytes: null,
100
+ };
101
+ downloads.push(download);
102
+ updateRenderProgress();
103
+ return ({ percent, downloaded, totalSize }) => {
104
+ download.progress = percent;
105
+ download.totalBytes = totalSize;
106
+ download.downloaded = downloaded;
107
+ updateRenderProgress();
108
+ };
109
+ };
110
+ const puppeteerInstance = await browserInstance;
111
+ addCleanupCallback(() => puppeteerInstance.close(false));
112
+ const comps = await (0, renderer_1.getCompositions)(urlOrBundle, {
113
+ inputProps,
114
+ puppeteerInstance,
115
+ envVariables,
116
+ timeoutInMilliseconds: puppeteerTimeout,
117
+ chromiumOptions,
118
+ browserExecutable,
119
+ downloadMap,
120
+ port,
121
+ });
122
+ const { compositionId, config, reason, argsAfterComposition } = await (0, get_composition_with_dimension_override_1.getCompositionWithDimensionOverride)({
123
+ validCompositions: comps,
124
+ height,
125
+ width,
126
+ args: remainingArgs,
127
+ compositionIdFromUi,
128
+ });
129
+ const { codec, reason: codecReason } = (0, get_final_output_codec_1.getFinalOutputCodec)({
130
+ cliFlag: parse_command_line_1.parsedCli.codec,
131
+ configFile: (_a = config_1.ConfigInternals.getOutputCodecOrUndefined()) !== null && _a !== void 0 ? _a : null,
132
+ downloadName: null,
133
+ outName: (0, user_passed_output_location_1.getUserPassedOutputLocation)(argsAfterComposition),
134
+ uiCodec,
135
+ });
136
+ renderer_1.RenderInternals.validateEvenDimensionsWithCodec({
137
+ width: config.width,
138
+ height: config.height,
139
+ codec,
140
+ scale,
141
+ });
142
+ const relativeOutputLocation = (0, get_filename_1.getOutputFilename)({
143
+ imageSequence: shouldOutputImageSequence,
144
+ compositionName: compositionId,
145
+ defaultExtension: renderer_1.RenderInternals.getFileExtensionFromCodec(codec, audioCodec),
146
+ args: argsAfterComposition,
147
+ indent,
148
+ fromUi: outputLocationFromUI,
149
+ logLevel,
150
+ });
151
+ log_1.Log.infoAdvanced({ indent, logLevel }, chalk_1.chalk.gray(`Entry point = ${fullEntryPoint} (${entryPointReason}), Composition = ${compositionId} (${reason}), Codec = ${codec} (${codecReason}), Output = ${relativeOutputLocation}`));
152
+ const absoluteOutputFile = (0, get_cli_options_1.getAndValidateAbsoluteOutputFile)(relativeOutputLocation, overwrite);
153
+ const realFrameRange = renderer_1.RenderInternals.getRealFrameRange(config.durationInFrames, frameRange);
154
+ const totalFrames = renderer_1.RenderInternals.getFramesToRender(realFrameRange, everyNthFrame);
155
+ const actualConcurrency = renderer_1.RenderInternals.getActualConcurrency(concurrency);
156
+ renderingProgress = {
157
+ frames: 0,
158
+ totalFrames: totalFrames.length,
159
+ concurrency: actualConcurrency,
160
+ doneIn: null,
161
+ steps,
162
+ };
163
+ const imageFormat = (0, image_formats_1.getVideoImageFormat)({
164
+ codec: shouldOutputImageSequence ? undefined : codec,
165
+ uiImageFormat,
166
+ });
167
+ if (shouldOutputImageSequence) {
168
+ node_fs_1.default.mkdirSync(absoluteOutputFile, {
169
+ recursive: true,
170
+ });
171
+ if (imageFormat === 'none') {
172
+ throw new Error(`Cannot render an image sequence with a codec that renders no images. codec = ${codec}, imageFormat = ${imageFormat}`);
173
+ }
174
+ const outputDir = shouldOutputImageSequence
175
+ ? absoluteOutputFile
176
+ : await node_fs_1.default.promises.mkdtemp(node_path_1.default.join(node_os_1.default.tmpdir(), 'react-motion-render'));
177
+ log_1.Log.verboseAdvanced({ indent, logLevel }, 'Output dir', outputDir);
178
+ await (0, renderer_1.renderFrames)({
179
+ imageFormat,
180
+ inputProps,
181
+ onFrameUpdate: (rendered) => {
182
+ renderingProgress.frames = rendered;
183
+ updateRenderProgress();
184
+ },
185
+ onStart: () => undefined,
186
+ onDownload: (src) => {
187
+ if (src.startsWith('data:')) {
188
+ log_1.Log.infoAdvanced({ indent, logLevel }, '\nWriting Data URL to file: ', src.substring(0, 30) + '...');
189
+ }
190
+ else {
191
+ log_1.Log.infoAdvanced({ indent, logLevel }, '\nDownloading asset... ', src);
192
+ }
193
+ },
194
+ cancelSignal: cancelSignal !== null && cancelSignal !== void 0 ? cancelSignal : undefined,
195
+ outputDir,
196
+ serveUrl: urlOrBundle,
197
+ dumpBrowserLogs: renderer_1.RenderInternals.isEqualOrBelowLogLevel(logLevel, 'verbose'),
198
+ everyNthFrame,
199
+ envVariables,
200
+ frameRange,
201
+ concurrency: actualConcurrency,
202
+ puppeteerInstance,
203
+ jpegQuality,
204
+ timeoutInMilliseconds: puppeteerTimeout,
205
+ chromiumOptions,
206
+ scale,
207
+ browserExecutable,
208
+ port,
209
+ downloadMap,
210
+ composition: config,
211
+ });
212
+ updateRenderProgress();
213
+ process.stdout.write('\n');
214
+ log_1.Log.infoAdvanced({ indent, logLevel }, chalk_1.chalk.cyan(`▶ ${absoluteOutputFile}`));
215
+ return;
216
+ }
217
+ stitchingProgress = {
218
+ doneIn: null,
219
+ frames: 0,
220
+ stage: 'encoding',
221
+ totalFrames: totalFrames.length,
222
+ codec,
223
+ };
224
+ const { slowestFrames } = await (0, renderer_1.renderMedia)({
225
+ outputLocation: absoluteOutputFile,
226
+ composition: {
227
+ ...config,
228
+ width: width !== null && width !== void 0 ? width : config.width,
229
+ height: height !== null && height !== void 0 ? height : config.height,
230
+ },
231
+ crf,
232
+ envVariables,
233
+ frameRange,
234
+ inputProps,
235
+ overwrite,
236
+ pixelFormat,
237
+ proResProfile,
238
+ jpegQuality,
239
+ dumpBrowserLogs: renderer_1.RenderInternals.isEqualOrBelowLogLevel(logLevel, 'verbose'),
240
+ chromiumOptions,
241
+ timeoutInMilliseconds: config_1.ConfigInternals.getCurrentPuppeteerTimeout(),
242
+ scale,
243
+ port,
244
+ numberOfGifLoops,
245
+ everyNthFrame,
246
+ verbose: renderer_1.RenderInternals.isEqualOrBelowLogLevel(logLevel, 'verbose'),
247
+ muted,
248
+ enforceAudioTrack,
249
+ browserExecutable,
250
+ ffmpegOverride,
251
+ concurrency,
252
+ serveUrl: urlOrBundle,
253
+ codec,
254
+ audioBitrate,
255
+ videoBitrate,
256
+ onProgress: (update) => {
257
+ stitchingProgress.doneIn =
258
+ update.encodedDoneIn;
259
+ stitchingProgress.frames =
260
+ update.encodedFrames;
261
+ stitchingProgress.stage = update.stitchStage;
262
+ renderingProgress.doneIn =
263
+ update.renderedDoneIn;
264
+ renderingProgress.frames =
265
+ update.renderedFrames;
266
+ updateRenderProgress();
267
+ },
268
+ puppeteerInstance,
269
+ onDownload,
270
+ internal: {
271
+ onCtrlCExit: addCleanupCallback,
272
+ downloadMap,
273
+ },
274
+ cancelSignal: cancelSignal !== null && cancelSignal !== void 0 ? cancelSignal : undefined,
275
+ printLog: (...str) => log_1.Log.verboseAdvanced({ indent, logLevel }, ...str),
276
+ audioCodec,
277
+ preferLossless: false,
278
+ imageFormat,
279
+ disallowParallelEncoding,
280
+ });
281
+ log_1.Log.verboseAdvanced({ indent, logLevel });
282
+ log_1.Log.verboseAdvanced({ indent, logLevel }, `Slowest frames:`);
283
+ slowestFrames.forEach(({ frame, time }) => {
284
+ log_1.Log.verboseAdvanced({ indent, logLevel }, `Frame ${frame} (${time.toFixed(3)}ms)`);
285
+ });
286
+ updateRenderProgress();
287
+ process.stdout.write('\n');
288
+ log_1.Log.infoAdvanced({ indent, logLevel }, chalk_1.chalk.cyan(`▶ ${absoluteOutputFile}`));
289
+ for (const line of renderer_1.RenderInternals.perf.getPerf()) {
290
+ log_1.Log.verboseAdvanced({ indent, logLevel }, line);
291
+ }
292
+ };
293
+ exports.renderVideoFlow = renderVideoFlow;
@@ -0,0 +1,29 @@
1
+ import type { Browser, BrowserExecutable, CancelSignal, ChromiumOptions, LogLevel, StillImageFormat } from '@remotion/renderer';
2
+ import type { JobProgressCallback } from '../preview-server/render-queue/job';
3
+ export declare const renderStillFlow: ({ remotionRoot, fullEntryPoint, entryPointReason, remainingArgs, browser, browserExecutable, chromiumOptions, envVariables, height, inputProps, overwrite, port, publicDir, puppeteerTimeout, jpegQuality, scale, stillFrame, width, compositionIdFromUi, imageFormatFromUi, logLevel, onProgress, indentOutput, addCleanupCallback, cancelSignal, }: {
4
+ remotionRoot: string;
5
+ fullEntryPoint: string;
6
+ entryPointReason: string;
7
+ remainingArgs: string[];
8
+ inputProps: object;
9
+ envVariables: Record<string, string>;
10
+ jpegQuality: number | undefined;
11
+ browser: Browser;
12
+ stillFrame: number;
13
+ browserExecutable: BrowserExecutable;
14
+ chromiumOptions: ChromiumOptions;
15
+ scale: number;
16
+ overwrite: boolean;
17
+ puppeteerTimeout: number;
18
+ port: number | null;
19
+ publicDir: string | null;
20
+ height: number | null;
21
+ width: number | null;
22
+ compositionIdFromUi: string | null;
23
+ imageFormatFromUi: StillImageFormat | null;
24
+ logLevel: LogLevel;
25
+ onProgress: JobProgressCallback;
26
+ indentOutput: boolean;
27
+ addCleanupCallback: (cb: () => void) => void;
28
+ cancelSignal: CancelSignal | null;
29
+ }) => Promise<void>;
@@ -0,0 +1,174 @@
1
+ "use strict";
2
+ // Prints to CLI and also reports back to browser
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.renderStillFlow = void 0;
8
+ const renderer_1 = require("@remotion/renderer");
9
+ const node_fs_1 = require("node:fs");
10
+ const node_path_1 = __importDefault(require("node:path"));
11
+ const chalk_1 = require("../chalk");
12
+ const cleanup_before_quit_1 = require("../cleanup-before-quit");
13
+ const config_1 = require("../config");
14
+ const determine_image_format_1 = require("../determine-image-format");
15
+ const get_cli_options_1 = require("../get-cli-options");
16
+ const get_composition_with_dimension_override_1 = require("../get-composition-with-dimension-override");
17
+ const log_1 = require("../log");
18
+ const parse_command_line_1 = require("../parse-command-line");
19
+ const progress_bar_1 = require("../progress-bar");
20
+ const progress_types_1 = require("../progress-types");
21
+ const setup_cache_1 = require("../setup-cache");
22
+ const truthy_1 = require("../truthy");
23
+ const user_passed_output_location_1 = require("../user-passed-output-location");
24
+ const renderStillFlow = async ({ remotionRoot, fullEntryPoint, entryPointReason, remainingArgs, browser, browserExecutable, chromiumOptions, envVariables, height, inputProps, overwrite, port, publicDir, puppeteerTimeout, jpegQuality, scale, stillFrame, width, compositionIdFromUi, imageFormatFromUi, logLevel, onProgress, indentOutput, addCleanupCallback, cancelSignal, }) => {
25
+ var _a, _b;
26
+ const downloads = [];
27
+ const aggregate = (0, progress_types_1.initialAggregateRenderProgress)();
28
+ let renderProgress = null;
29
+ const steps = [
30
+ renderer_1.RenderInternals.isServeUrl(fullEntryPoint) ? null : 'bundling',
31
+ 'rendering',
32
+ ].filter(truthy_1.truthy);
33
+ const updateProgress = () => {
34
+ const { output, progress, message } = (0, progress_bar_1.makeRenderingAndStitchingProgress)({
35
+ prog: aggregate,
36
+ indent: indentOutput,
37
+ steps: steps.length,
38
+ stitchingStep: steps.indexOf('stitching'),
39
+ });
40
+ if (renderProgress) {
41
+ renderProgress.update(output);
42
+ }
43
+ onProgress({ message, value: progress, ...aggregate });
44
+ };
45
+ log_1.Log.verboseAdvanced({ indent: indentOutput, logLevel }, 'Browser executable: ', browserExecutable);
46
+ const shouldDumpIo = renderer_1.RenderInternals.isEqualOrBelowLogLevel(logLevel, 'verbose');
47
+ const browserInstance = (0, renderer_1.openBrowser)(browser, {
48
+ browserExecutable,
49
+ chromiumOptions,
50
+ shouldDumpIo,
51
+ forceDeviceScaleFactor: scale,
52
+ indentationString: indentOutput ? log_1.INDENT_TOKEN + ' ' : '',
53
+ });
54
+ const { cleanup: cleanupBundle, urlOrBundle } = await (0, setup_cache_1.bundleOnCliOrTakeServeUrl)({
55
+ fullPath: fullEntryPoint,
56
+ remotionRoot,
57
+ steps: steps.length,
58
+ publicDir,
59
+ onProgress: ({ copying, bundling }) => {
60
+ aggregate.bundling = bundling;
61
+ aggregate.copyingState = copying;
62
+ updateProgress();
63
+ },
64
+ indentOutput,
65
+ logLevel,
66
+ bundlingStep: steps.indexOf('bundling'),
67
+ onDirectoryCreated: (dir) => {
68
+ (0, cleanup_before_quit_1.registerCleanupJob)(() => {
69
+ renderer_1.RenderInternals.deleteDirectory(dir);
70
+ });
71
+ },
72
+ });
73
+ addCleanupCallback(() => cleanupBundle());
74
+ const puppeteerInstance = await browserInstance;
75
+ addCleanupCallback(() => puppeteerInstance.close(false));
76
+ const downloadMap = renderer_1.RenderInternals.makeDownloadMap();
77
+ addCleanupCallback(() => renderer_1.RenderInternals.cleanDownloadMap(downloadMap));
78
+ const comps = await (0, renderer_1.getCompositions)(urlOrBundle, {
79
+ inputProps,
80
+ puppeteerInstance,
81
+ envVariables,
82
+ timeoutInMilliseconds: puppeteerTimeout,
83
+ chromiumOptions,
84
+ port,
85
+ browserExecutable,
86
+ downloadMap,
87
+ });
88
+ const { compositionId, config, reason, argsAfterComposition } = await (0, get_composition_with_dimension_override_1.getCompositionWithDimensionOverride)({
89
+ validCompositions: comps,
90
+ height,
91
+ width,
92
+ args: remainingArgs,
93
+ compositionIdFromUi,
94
+ });
95
+ const { format: imageFormat, source } = (0, determine_image_format_1.determineFinalStillImageFormat)({
96
+ cliFlag: (_a = parse_command_line_1.parsedCli['image-format']) !== null && _a !== void 0 ? _a : null,
97
+ configImageFormat: (_b = config_1.ConfigInternals.getUserPreferredStillImageFormat()) !== null && _b !== void 0 ? _b : null,
98
+ downloadName: null,
99
+ outName: (0, user_passed_output_location_1.getUserPassedOutputLocation)(argsAfterComposition),
100
+ isLambda: false,
101
+ fromUi: imageFormatFromUi,
102
+ });
103
+ const relativeOutputLocation = (0, user_passed_output_location_1.getOutputLocation)({
104
+ compositionId,
105
+ defaultExtension: imageFormat,
106
+ args: argsAfterComposition,
107
+ type: 'asset',
108
+ });
109
+ const absoluteOutputLocation = (0, get_cli_options_1.getAndValidateAbsoluteOutputFile)(relativeOutputLocation, overwrite);
110
+ (0, node_fs_1.mkdirSync)(node_path_1.default.join(absoluteOutputLocation, '..'), {
111
+ recursive: true,
112
+ });
113
+ log_1.Log.infoAdvanced({ indent: indentOutput, logLevel }, chalk_1.chalk.gray(`Entry point = ${fullEntryPoint} (${entryPointReason}), Output = ${relativeOutputLocation}, Format = ${imageFormat} (${source}), Composition = ${compositionId} (${reason})`));
114
+ renderProgress = (0, progress_bar_1.createOverwriteableCliOutput)({
115
+ quiet: (0, parse_command_line_1.quietFlagProvided)(),
116
+ cancelSignal,
117
+ });
118
+ const renderStart = Date.now();
119
+ aggregate.rendering = {
120
+ frames: 0,
121
+ concurrency: 1,
122
+ doneIn: null,
123
+ steps,
124
+ totalFrames: 1,
125
+ };
126
+ updateProgress();
127
+ const onDownload = (src) => {
128
+ const id = Math.random();
129
+ const download = {
130
+ id,
131
+ name: src,
132
+ progress: 0,
133
+ downloaded: 0,
134
+ totalBytes: null,
135
+ };
136
+ downloads.push(download);
137
+ updateProgress();
138
+ return ({ percent }) => {
139
+ download.progress = percent;
140
+ updateProgress();
141
+ };
142
+ };
143
+ await (0, renderer_1.renderStill)({
144
+ composition: config,
145
+ frame: stillFrame,
146
+ output: absoluteOutputLocation,
147
+ serveUrl: urlOrBundle,
148
+ jpegQuality,
149
+ dumpBrowserLogs: shouldDumpIo,
150
+ envVariables,
151
+ imageFormat,
152
+ inputProps,
153
+ chromiumOptions,
154
+ timeoutInMilliseconds: puppeteerTimeout,
155
+ scale,
156
+ browserExecutable,
157
+ overwrite,
158
+ onDownload,
159
+ port,
160
+ downloadMap,
161
+ puppeteerInstance,
162
+ });
163
+ aggregate.rendering = {
164
+ frames: 1,
165
+ concurrency: 1,
166
+ doneIn: Date.now() - renderStart,
167
+ steps,
168
+ totalFrames: 1,
169
+ };
170
+ updateProgress();
171
+ log_1.Log.infoAdvanced({ indent: indentOutput, logLevel });
172
+ log_1.Log.infoAdvanced({ indent: indentOutput, logLevel }, chalk_1.chalk.cyan(`▶️ ${absoluteOutputLocation}`));
173
+ };
174
+ exports.renderStillFlow = renderStillFlow;