@remotion/cli 3.0.29 → 3.1.0

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 (415) hide show
  1. package/dist/chalk/symbols.d.ts +111 -0
  2. package/dist/chalk/symbols.js +75 -0
  3. package/dist/chalk/utilities.d.ts +2 -0
  4. package/dist/chalk/utilities.js +37 -0
  5. package/dist/compositions.js +10 -4
  6. package/dist/editor/components/CompositionManager.d.ts +4 -0
  7. package/dist/editor/components/CompositionManager.js +60 -0
  8. package/dist/editor/components/CopyButton.js +1 -1
  9. package/dist/editor/components/Editor.js +2 -1
  10. package/dist/editor/components/GlobalKeybindings.js +26 -11
  11. package/dist/editor/components/KeyboardShortcutsModal.js +1 -1
  12. package/dist/editor/components/Menu/MenuItem.d.ts +1 -1
  13. package/dist/editor/components/MenuToolbar.js +24 -2
  14. package/dist/editor/components/NewComposition/MenuContent.js +42 -7
  15. package/dist/editor/components/Notifications/ColorDot.d.ts +4 -0
  16. package/dist/editor/components/Notifications/ColorDot.js +22 -0
  17. package/dist/editor/components/Notifications/Notification.d.ts +8 -0
  18. package/dist/editor/components/Notifications/Notification.js +31 -0
  19. package/dist/editor/components/Notifications/NotificationCenter.d.ts +13 -0
  20. package/dist/editor/components/Notifications/NotificationCenter.js +39 -0
  21. package/dist/editor/components/PlayPause.js +53 -7
  22. package/dist/editor/components/PlaybackKeyboardShortcutsManager.js +18 -3
  23. package/dist/editor/components/TimelineInOutToggle.js +21 -6
  24. package/dist/editor/components/UpdateModal/UpdateModal.js +1 -1
  25. package/dist/editor/helpers/copy-text.d.ts +1 -1
  26. package/dist/editor/helpers/copy-text.js +5 -4
  27. package/dist/editor/helpers/pick-color.d.ts +1 -0
  28. package/dist/editor/helpers/pick-color.js +36 -0
  29. package/dist/editor/helpers/use-keybinding.d.ts +6 -1
  30. package/dist/editor/helpers/use-keybinding.js +10 -5
  31. package/dist/editor/state/keybindings.js +3 -1
  32. package/dist/editor/state/z-index.js +6 -1
  33. package/dist/get-cli-options.d.ts +3 -1
  34. package/dist/get-cli-options.js +7 -1
  35. package/dist/image-formats.js +2 -1
  36. package/dist/index.d.ts +3 -1
  37. package/dist/parse-command-line.d.ts +2 -0
  38. package/dist/parse-command-line.js +9 -3
  39. package/dist/preview-server/error-overlay/remotion-overlay/AskOnDiscord.d.ts +3 -1
  40. package/dist/preview-server/error-overlay/remotion-overlay/AskOnDiscord.js +20 -2
  41. package/dist/preview-server/error-overlay/remotion-overlay/Button.js +4 -4
  42. package/dist/preview-server/error-overlay/remotion-overlay/ErrorDisplay.d.ts +1 -0
  43. package/dist/preview-server/error-overlay/remotion-overlay/ErrorDisplay.js +5 -2
  44. package/dist/preview-server/error-overlay/remotion-overlay/ErrorLoader.d.ts +1 -0
  45. package/dist/preview-server/error-overlay/remotion-overlay/ErrorLoader.js +2 -2
  46. package/dist/preview-server/error-overlay/remotion-overlay/ErrorMessage.d.ts +4 -0
  47. package/dist/preview-server/error-overlay/remotion-overlay/ErrorMessage.js +67 -0
  48. package/dist/preview-server/error-overlay/remotion-overlay/ErrorTitle.js +5 -9
  49. package/dist/preview-server/error-overlay/remotion-overlay/HelpLink.d.ts +6 -0
  50. package/dist/preview-server/error-overlay/remotion-overlay/HelpLink.js +31 -0
  51. package/dist/preview-server/error-overlay/remotion-overlay/OpenInEditor.d.ts +1 -0
  52. package/dist/preview-server/error-overlay/remotion-overlay/OpenInEditor.js +20 -2
  53. package/dist/preview-server/error-overlay/remotion-overlay/Overlay.js +8 -7
  54. package/dist/preview-server/error-overlay/remotion-overlay/SearchGitHubIssues.d.ts +1 -0
  55. package/dist/preview-server/error-overlay/remotion-overlay/SearchGitHubIssues.js +20 -2
  56. package/dist/preview-server/error-overlay/remotion-overlay/ShortcutHint.d.ts +5 -0
  57. package/dist/preview-server/error-overlay/remotion-overlay/ShortcutHint.js +16 -0
  58. package/dist/preview-server/error-overlay/remotion-overlay/StackFrame.js +1 -1
  59. package/dist/preview-server/error-overlay/remotion-overlay/carets.d.ts +4 -2
  60. package/dist/preview-server/error-overlay/remotion-overlay/carets.js +2 -2
  61. package/dist/preview-server/error-overlay/remotion-overlay/get-help-link.d.ts +5 -0
  62. package/dist/preview-server/error-overlay/remotion-overlay/get-help-link.js +19 -0
  63. package/dist/preview-server/fast-refresh/helpers.d.ts +39 -0
  64. package/dist/preview-server/fast-refresh/helpers.js +145 -0
  65. package/dist/preview-server/fast-refresh/index.d.ts +30 -0
  66. package/dist/preview-server/fast-refresh/index.js +86 -0
  67. package/dist/preview-server/fast-refresh/loader.d.ts +35 -0
  68. package/dist/preview-server/fast-refresh/loader.js +81 -0
  69. package/dist/preview-server/fast-refresh/runtime.d.ts +35 -0
  70. package/dist/preview-server/fast-refresh/runtime.js +32 -0
  71. package/dist/preview-server/static-preview.d.ts +1 -0
  72. package/dist/preview-server/static-preview.js +40 -0
  73. package/dist/preview-server/webpack-cache.d.ts +12 -0
  74. package/dist/preview-server/webpack-cache.js +66 -0
  75. package/dist/progress-bar.d.ts +3 -1
  76. package/dist/progress-bar.js +4 -3
  77. package/dist/render.js +13 -14
  78. package/dist/setup-cache.d.ts +4 -1
  79. package/dist/setup-cache.js +1 -1
  80. package/dist/still.js +1 -1
  81. package/package.json +10 -12
  82. package/tsconfig.json +2 -1
  83. package/vitest.config.ts +9 -0
  84. package/dist/ansi/ansi-diff.d.ts.map +0 -1
  85. package/dist/ansi/ansi-diff.js.map +0 -1
  86. package/dist/ansi/ansi-regex.d.ts.map +0 -1
  87. package/dist/ansi/ansi-regex.js.map +0 -1
  88. package/dist/ansi/ansi-split.d.ts.map +0 -1
  89. package/dist/ansi/ansi-split.js.map +0 -1
  90. package/dist/check-version.d.ts.map +0 -1
  91. package/dist/check-version.js.map +0 -1
  92. package/dist/code-frame.d.ts.map +0 -1
  93. package/dist/code-frame.js.map +0 -1
  94. package/dist/compositions.d.ts.map +0 -1
  95. package/dist/compositions.js.map +0 -1
  96. package/dist/download-progress.d.ts.map +0 -1
  97. package/dist/download-progress.js.map +0 -1
  98. package/dist/editor/components/AudioWaveform.d.ts.map +0 -1
  99. package/dist/editor/components/AudioWaveform.js.map +0 -1
  100. package/dist/editor/components/AudioWaveformBar.d.ts.map +0 -1
  101. package/dist/editor/components/AudioWaveformBar.js.map +0 -1
  102. package/dist/editor/components/Canvas.d.ts.map +0 -1
  103. package/dist/editor/components/Canvas.js.map +0 -1
  104. package/dist/editor/components/CheckboardToggle.d.ts.map +0 -1
  105. package/dist/editor/components/CheckboardToggle.js.map +0 -1
  106. package/dist/editor/components/ClipboardIcon.d.ts.map +0 -1
  107. package/dist/editor/components/ClipboardIcon.js.map +0 -1
  108. package/dist/editor/components/CompositionSelector.d.ts.map +0 -1
  109. package/dist/editor/components/CompositionSelector.js.map +0 -1
  110. package/dist/editor/components/CompositionSelectorItem.d.ts.map +0 -1
  111. package/dist/editor/components/CompositionSelectorItem.js.map +0 -1
  112. package/dist/editor/components/ControlButton.d.ts.map +0 -1
  113. package/dist/editor/components/ControlButton.js.map +0 -1
  114. package/dist/editor/components/CopyButton.d.ts.map +0 -1
  115. package/dist/editor/components/CopyButton.js.map +0 -1
  116. package/dist/editor/components/CurrentComposition.d.ts.map +0 -1
  117. package/dist/editor/components/CurrentComposition.js.map +0 -1
  118. package/dist/editor/components/Editor.d.ts.map +0 -1
  119. package/dist/editor/components/Editor.js.map +0 -1
  120. package/dist/editor/components/EditorContent.d.ts.map +0 -1
  121. package/dist/editor/components/EditorContent.js.map +0 -1
  122. package/dist/editor/components/FpsCounter.d.ts.map +0 -1
  123. package/dist/editor/components/FpsCounter.js.map +0 -1
  124. package/dist/editor/components/FramePersistor.d.ts.map +0 -1
  125. package/dist/editor/components/FramePersistor.js.map +0 -1
  126. package/dist/editor/components/GlobalKeybindings.d.ts.map +0 -1
  127. package/dist/editor/components/GlobalKeybindings.js.map +0 -1
  128. package/dist/editor/components/KeyboardShortcutsModal.d.ts.map +0 -1
  129. package/dist/editor/components/KeyboardShortcutsModal.js.map +0 -1
  130. package/dist/editor/components/LoadingIndicator.d.ts.map +0 -1
  131. package/dist/editor/components/LoadingIndicator.js.map +0 -1
  132. package/dist/editor/components/LoopToggle.d.ts.map +0 -1
  133. package/dist/editor/components/LoopToggle.js.map +0 -1
  134. package/dist/editor/components/Menu/MenuDivider.d.ts.map +0 -1
  135. package/dist/editor/components/Menu/MenuDivider.js.map +0 -1
  136. package/dist/editor/components/Menu/MenuItem.d.ts.map +0 -1
  137. package/dist/editor/components/Menu/MenuItem.js.map +0 -1
  138. package/dist/editor/components/Menu/MenuSubItem.d.ts.map +0 -1
  139. package/dist/editor/components/Menu/MenuSubItem.js.map +0 -1
  140. package/dist/editor/components/Menu/SubMenu.d.ts.map +0 -1
  141. package/dist/editor/components/Menu/SubMenu.js.map +0 -1
  142. package/dist/editor/components/Menu/portals.d.ts.map +0 -1
  143. package/dist/editor/components/Menu/portals.js.map +0 -1
  144. package/dist/editor/components/Menu/styles.d.ts.map +0 -1
  145. package/dist/editor/components/Menu/styles.js.map +0 -1
  146. package/dist/editor/components/MenuToolbar.d.ts.map +0 -1
  147. package/dist/editor/components/MenuToolbar.js.map +0 -1
  148. package/dist/editor/components/ModalContainer.d.ts.map +0 -1
  149. package/dist/editor/components/ModalContainer.js.map +0 -1
  150. package/dist/editor/components/ModalHeader.d.ts.map +0 -1
  151. package/dist/editor/components/ModalHeader.js.map +0 -1
  152. package/dist/editor/components/MuteToggle.d.ts.map +0 -1
  153. package/dist/editor/components/MuteToggle.js.map +0 -1
  154. package/dist/editor/components/NewComposition/CancelButton.d.ts.map +0 -1
  155. package/dist/editor/components/NewComposition/CancelButton.js.map +0 -1
  156. package/dist/editor/components/NewComposition/ComboBox.d.ts.map +0 -1
  157. package/dist/editor/components/NewComposition/ComboBox.js.map +0 -1
  158. package/dist/editor/components/NewComposition/CopyHint.d.ts.map +0 -1
  159. package/dist/editor/components/NewComposition/CopyHint.js.map +0 -1
  160. package/dist/editor/components/NewComposition/InputDragger.d.ts.map +0 -1
  161. package/dist/editor/components/NewComposition/InputDragger.js.map +0 -1
  162. package/dist/editor/components/NewComposition/MenuContent.d.ts.map +0 -1
  163. package/dist/editor/components/NewComposition/MenuContent.js.map +0 -1
  164. package/dist/editor/components/NewComposition/NewCompAspectRatio.d.ts.map +0 -1
  165. package/dist/editor/components/NewComposition/NewCompAspectRatio.js.map +0 -1
  166. package/dist/editor/components/NewComposition/NewCompCode.d.ts.map +0 -1
  167. package/dist/editor/components/NewComposition/NewCompCode.js.map +0 -1
  168. package/dist/editor/components/NewComposition/NewCompDuration.d.ts.map +0 -1
  169. package/dist/editor/components/NewComposition/NewCompDuration.js.map +0 -1
  170. package/dist/editor/components/NewComposition/NewComposition.d.ts.map +0 -1
  171. package/dist/editor/components/NewComposition/NewComposition.js.map +0 -1
  172. package/dist/editor/components/NewComposition/RemInput.d.ts.map +0 -1
  173. package/dist/editor/components/NewComposition/RemInput.js.map +0 -1
  174. package/dist/editor/components/NewComposition/ToggleAspectRatio.d.ts.map +0 -1
  175. package/dist/editor/components/NewComposition/ToggleAspectRatio.js.map +0 -1
  176. package/dist/editor/components/NewComposition/ValidationMessage.d.ts.map +0 -1
  177. package/dist/editor/components/NewComposition/ValidationMessage.js.map +0 -1
  178. package/dist/editor/components/NewComposition/new-comp-layout.d.ts.map +0 -1
  179. package/dist/editor/components/NewComposition/new-comp-layout.js.map +0 -1
  180. package/dist/editor/components/NewComposition/render-aspect-ratio.d.ts.map +0 -1
  181. package/dist/editor/components/NewComposition/render-aspect-ratio.js.map +0 -1
  182. package/dist/editor/components/PlayPause.d.ts.map +0 -1
  183. package/dist/editor/components/PlayPause.js.map +0 -1
  184. package/dist/editor/components/PlaybackKeyboardShortcutsManager.d.ts.map +0 -1
  185. package/dist/editor/components/PlaybackKeyboardShortcutsManager.js.map +0 -1
  186. package/dist/editor/components/PlaybackRatePersistor.d.ts.map +0 -1
  187. package/dist/editor/components/PlaybackRatePersistor.js.map +0 -1
  188. package/dist/editor/components/PlaybackRateSelector.d.ts.map +0 -1
  189. package/dist/editor/components/PlaybackRateSelector.js.map +0 -1
  190. package/dist/editor/components/Preview.d.ts.map +0 -1
  191. package/dist/editor/components/Preview.js.map +0 -1
  192. package/dist/editor/components/PreviewToolbar.d.ts.map +0 -1
  193. package/dist/editor/components/PreviewToolbar.js.map +0 -1
  194. package/dist/editor/components/RichTimelineToggle.d.ts.map +0 -1
  195. package/dist/editor/components/RichTimelineToggle.js.map +0 -1
  196. package/dist/editor/components/SizeSelector.d.ts.map +0 -1
  197. package/dist/editor/components/SizeSelector.js.map +0 -1
  198. package/dist/editor/components/Splitter/SplitterContainer.d.ts.map +0 -1
  199. package/dist/editor/components/Splitter/SplitterContainer.js.map +0 -1
  200. package/dist/editor/components/Splitter/SplitterContext.d.ts.map +0 -1
  201. package/dist/editor/components/Splitter/SplitterContext.js.map +0 -1
  202. package/dist/editor/components/Splitter/SplitterElement.d.ts.map +0 -1
  203. package/dist/editor/components/Splitter/SplitterElement.js.map +0 -1
  204. package/dist/editor/components/Splitter/SplitterHandle.d.ts.map +0 -1
  205. package/dist/editor/components/Splitter/SplitterHandle.js.map +0 -1
  206. package/dist/editor/components/Thumbnail.d.ts.map +0 -1
  207. package/dist/editor/components/Thumbnail.js.map +0 -1
  208. package/dist/editor/components/TimeValue.d.ts.map +0 -1
  209. package/dist/editor/components/TimeValue.js.map +0 -1
  210. package/dist/editor/components/Timeline/LoopedIndicator.d.ts.map +0 -1
  211. package/dist/editor/components/Timeline/LoopedIndicator.js.map +0 -1
  212. package/dist/editor/components/Timeline/LoopedTimelineIndicators.d.ts.map +0 -1
  213. package/dist/editor/components/Timeline/LoopedTimelineIndicators.js.map +0 -1
  214. package/dist/editor/components/Timeline/MaxTimelineTracks.d.ts.map +0 -1
  215. package/dist/editor/components/Timeline/MaxTimelineTracks.js.map +0 -1
  216. package/dist/editor/components/Timeline/Timeline.d.ts.map +0 -1
  217. package/dist/editor/components/Timeline/Timeline.js.map +0 -1
  218. package/dist/editor/components/Timeline/TimelineCollapseToggle.d.ts.map +0 -1
  219. package/dist/editor/components/Timeline/TimelineCollapseToggle.js.map +0 -1
  220. package/dist/editor/components/Timeline/TimelineDragHandler.d.ts.map +0 -1
  221. package/dist/editor/components/Timeline/TimelineDragHandler.js.map +0 -1
  222. package/dist/editor/components/Timeline/TimelineInOutPointer.d.ts.map +0 -1
  223. package/dist/editor/components/Timeline/TimelineInOutPointer.js.map +0 -1
  224. package/dist/editor/components/Timeline/TimelineInOutPointerHandle.d.ts.map +0 -1
  225. package/dist/editor/components/Timeline/TimelineInOutPointerHandle.js.map +0 -1
  226. package/dist/editor/components/Timeline/TimelineList.d.ts.map +0 -1
  227. package/dist/editor/components/Timeline/TimelineList.js.map +0 -1
  228. package/dist/editor/components/Timeline/TimelineListItem.d.ts.map +0 -1
  229. package/dist/editor/components/Timeline/TimelineListItem.js.map +0 -1
  230. package/dist/editor/components/Timeline/TimelineSequence.d.ts.map +0 -1
  231. package/dist/editor/components/Timeline/TimelineSequence.js.map +0 -1
  232. package/dist/editor/components/Timeline/TimelineSequenceFrame.d.ts.map +0 -1
  233. package/dist/editor/components/Timeline/TimelineSequenceFrame.js.map +0 -1
  234. package/dist/editor/components/Timeline/TimelineSlider.d.ts.map +0 -1
  235. package/dist/editor/components/Timeline/TimelineSlider.js.map +0 -1
  236. package/dist/editor/components/Timeline/TimelineSliderHandle.d.ts.map +0 -1
  237. package/dist/editor/components/Timeline/TimelineSliderHandle.js.map +0 -1
  238. package/dist/editor/components/Timeline/TimelineTracks.d.ts.map +0 -1
  239. package/dist/editor/components/Timeline/TimelineTracks.js.map +0 -1
  240. package/dist/editor/components/Timeline/TimelineVideoInfo.d.ts.map +0 -1
  241. package/dist/editor/components/Timeline/TimelineVideoInfo.js.map +0 -1
  242. package/dist/editor/components/Timeline/is-collapsed.d.ts.map +0 -1
  243. package/dist/editor/components/Timeline/is-collapsed.js.map +0 -1
  244. package/dist/editor/components/Timeline/timeline-refs.d.ts.map +0 -1
  245. package/dist/editor/components/Timeline/timeline-refs.js.map +0 -1
  246. package/dist/editor/components/Timeline/timeline-state-reducer.d.ts.map +0 -1
  247. package/dist/editor/components/Timeline/timeline-state-reducer.js.map +0 -1
  248. package/dist/editor/components/TimelineInOutToggle.d.ts.map +0 -1
  249. package/dist/editor/components/TimelineInOutToggle.js.map +0 -1
  250. package/dist/editor/components/TopPanel.d.ts.map +0 -1
  251. package/dist/editor/components/TopPanel.js.map +0 -1
  252. package/dist/editor/components/UpdateCheck.d.ts.map +0 -1
  253. package/dist/editor/components/UpdateCheck.js.map +0 -1
  254. package/dist/editor/components/UpdateModal/UpdateModal.d.ts.map +0 -1
  255. package/dist/editor/components/UpdateModal/UpdateModal.js.map +0 -1
  256. package/dist/editor/components/layout.d.ts.map +0 -1
  257. package/dist/editor/components/layout.js.map +0 -1
  258. package/dist/editor/helpers/calculate-timeline.d.ts.map +0 -1
  259. package/dist/editor/helpers/calculate-timeline.js.map +0 -1
  260. package/dist/editor/helpers/checkerboard-background.d.ts.map +0 -1
  261. package/dist/editor/helpers/checkerboard-background.js.map +0 -1
  262. package/dist/editor/helpers/colors.d.ts.map +0 -1
  263. package/dist/editor/helpers/colors.js.map +0 -1
  264. package/dist/editor/helpers/copy-text.d.ts.map +0 -1
  265. package/dist/editor/helpers/copy-text.js.map +0 -1
  266. package/dist/editor/helpers/create-folder-tree.d.ts.map +0 -1
  267. package/dist/editor/helpers/create-folder-tree.js.map +0 -1
  268. package/dist/editor/helpers/get-left-of-timeline-slider.d.ts.map +0 -1
  269. package/dist/editor/helpers/get-left-of-timeline-slider.js.map +0 -1
  270. package/dist/editor/helpers/get-sequence-visible-range.d.ts.map +0 -1
  271. package/dist/editor/helpers/get-sequence-visible-range.js.map +0 -1
  272. package/dist/editor/helpers/get-timeline-nestedness.d.ts.map +0 -1
  273. package/dist/editor/helpers/get-timeline-nestedness.js.map +0 -1
  274. package/dist/editor/helpers/get-timeline-sequence-hash.d.ts.map +0 -1
  275. package/dist/editor/helpers/get-timeline-sequence-hash.js.map +0 -1
  276. package/dist/editor/helpers/get-timeline-sequence-layout.d.ts.map +0 -1
  277. package/dist/editor/helpers/get-timeline-sequence-layout.js.map +0 -1
  278. package/dist/editor/helpers/get-timeline-sequence-sort-key.d.ts.map +0 -1
  279. package/dist/editor/helpers/get-timeline-sequence-sort-key.js.map +0 -1
  280. package/dist/editor/helpers/is-composition-still.d.ts.map +0 -1
  281. package/dist/editor/helpers/is-composition-still.js.map +0 -1
  282. package/dist/editor/helpers/is-current-selected-still.d.ts.map +0 -1
  283. package/dist/editor/helpers/is-current-selected-still.js.map +0 -1
  284. package/dist/editor/helpers/noop.d.ts.map +0 -1
  285. package/dist/editor/helpers/noop.js.map +0 -1
  286. package/dist/editor/helpers/persist-open-folders.d.ts.map +0 -1
  287. package/dist/editor/helpers/persist-open-folders.js.map +0 -1
  288. package/dist/editor/helpers/timeline-layout.d.ts.map +0 -1
  289. package/dist/editor/helpers/timeline-layout.js.map +0 -1
  290. package/dist/editor/helpers/use-keybinding.d.ts.map +0 -1
  291. package/dist/editor/helpers/use-keybinding.js.map +0 -1
  292. package/dist/editor/helpers/validate-new-comp-data.d.ts.map +0 -1
  293. package/dist/editor/helpers/validate-new-comp-data.js.map +0 -1
  294. package/dist/editor/icons/Checkmark.d.ts.map +0 -1
  295. package/dist/editor/icons/Checkmark.js.map +0 -1
  296. package/dist/editor/icons/caret.d.ts.map +0 -1
  297. package/dist/editor/icons/caret.js.map +0 -1
  298. package/dist/editor/icons/film.d.ts.map +0 -1
  299. package/dist/editor/icons/film.js.map +0 -1
  300. package/dist/editor/icons/folder.d.ts.map +0 -1
  301. package/dist/editor/icons/folder.js.map +0 -1
  302. package/dist/editor/icons/keys.d.ts.map +0 -1
  303. package/dist/editor/icons/keys.js.map +0 -1
  304. package/dist/editor/icons/lock.d.ts.map +0 -1
  305. package/dist/editor/icons/lock.js.map +0 -1
  306. package/dist/editor/icons/media-volume.d.ts.map +0 -1
  307. package/dist/editor/icons/media-volume.js.map +0 -1
  308. package/dist/editor/icons/pause.d.ts.map +0 -1
  309. package/dist/editor/icons/pause.js.map +0 -1
  310. package/dist/editor/icons/play.d.ts.map +0 -1
  311. package/dist/editor/icons/play.js.map +0 -1
  312. package/dist/editor/icons/step-back.d.ts.map +0 -1
  313. package/dist/editor/icons/step-back.js.map +0 -1
  314. package/dist/editor/icons/step-forward.d.ts.map +0 -1
  315. package/dist/editor/icons/step-forward.js.map +0 -1
  316. package/dist/editor/icons/still.d.ts.map +0 -1
  317. package/dist/editor/icons/still.js.map +0 -1
  318. package/dist/editor/icons/timeline.d.ts.map +0 -1
  319. package/dist/editor/icons/timeline.js.map +0 -1
  320. package/dist/editor/icons/timelineInOutPointer.d.ts.map +0 -1
  321. package/dist/editor/icons/timelineInOutPointer.js.map +0 -1
  322. package/dist/editor/state/aspect-ratio-locked.d.ts.map +0 -1
  323. package/dist/editor/state/aspect-ratio-locked.js.map +0 -1
  324. package/dist/editor/state/checkerboard.d.ts.map +0 -1
  325. package/dist/editor/state/checkerboard.js.map +0 -1
  326. package/dist/editor/state/highest-z-index.d.ts.map +0 -1
  327. package/dist/editor/state/highest-z-index.js.map +0 -1
  328. package/dist/editor/state/input-dragger-click-lock.d.ts.map +0 -1
  329. package/dist/editor/state/input-dragger-click-lock.js.map +0 -1
  330. package/dist/editor/state/keybindings.d.ts.map +0 -1
  331. package/dist/editor/state/keybindings.js.map +0 -1
  332. package/dist/editor/state/loop.d.ts.map +0 -1
  333. package/dist/editor/state/loop.js.map +0 -1
  334. package/dist/editor/state/marks.d.ts.map +0 -1
  335. package/dist/editor/state/marks.js.map +0 -1
  336. package/dist/editor/state/modals.d.ts.map +0 -1
  337. package/dist/editor/state/modals.js.map +0 -1
  338. package/dist/editor/state/mute.d.ts.map +0 -1
  339. package/dist/editor/state/mute.js.map +0 -1
  340. package/dist/editor/state/playbackrate.d.ts.map +0 -1
  341. package/dist/editor/state/playbackrate.js.map +0 -1
  342. package/dist/editor/state/preview-size.d.ts.map +0 -1
  343. package/dist/editor/state/preview-size.js.map +0 -1
  344. package/dist/editor/state/render-frame.d.ts.map +0 -1
  345. package/dist/editor/state/render-frame.js.map +0 -1
  346. package/dist/editor/state/rich-timeline.d.ts.map +0 -1
  347. package/dist/editor/state/rich-timeline.js.map +0 -1
  348. package/dist/editor/state/timeline-ref.d.ts.map +0 -1
  349. package/dist/editor/state/timeline-ref.js.map +0 -1
  350. package/dist/editor/state/timeline.d.ts.map +0 -1
  351. package/dist/editor/state/timeline.js.map +0 -1
  352. package/dist/editor/state/z-index.d.ts.map +0 -1
  353. package/dist/editor/state/z-index.js.map +0 -1
  354. package/dist/get-cli-options.d.ts.map +0 -1
  355. package/dist/get-cli-options.js.map +0 -1
  356. package/dist/get-composition-id.d.ts.map +0 -1
  357. package/dist/get-composition-id.js.map +0 -1
  358. package/dist/get-config-file-name.d.ts.map +0 -1
  359. package/dist/get-config-file-name.js.map +0 -1
  360. package/dist/get-env.d.ts.map +0 -1
  361. package/dist/get-env.js.map +0 -1
  362. package/dist/get-filename.d.ts.map +0 -1
  363. package/dist/get-filename.js.map +0 -1
  364. package/dist/get-input-props.d.ts.map +0 -1
  365. package/dist/get-input-props.js.map +0 -1
  366. package/dist/handle-common-errors.d.ts.map +0 -1
  367. package/dist/handle-common-errors.js.map +0 -1
  368. package/dist/image-formats.d.ts.map +0 -1
  369. package/dist/image-formats.js.map +0 -1
  370. package/dist/index.d.ts.map +0 -1
  371. package/dist/index.js.map +0 -1
  372. package/dist/initialize-render-cli.d.ts.map +0 -1
  373. package/dist/initialize-render-cli.js.map +0 -1
  374. package/dist/is-javascript.d.ts.map +0 -1
  375. package/dist/is-javascript.js.map +0 -1
  376. package/dist/lambda-command.d.ts.map +0 -1
  377. package/dist/lambda-command.js.map +0 -1
  378. package/dist/load-config.d.ts.map +0 -1
  379. package/dist/load-config.js.map +0 -1
  380. package/dist/log.d.ts.map +0 -1
  381. package/dist/log.js.map +0 -1
  382. package/dist/make-progress-bar.d.ts.map +0 -1
  383. package/dist/make-progress-bar.js.map +0 -1
  384. package/dist/parse-command-line.d.ts.map +0 -1
  385. package/dist/parse-command-line.js.map +0 -1
  386. package/dist/preview.d.ts.map +0 -1
  387. package/dist/preview.js.map +0 -1
  388. package/dist/previewEntry.d.ts.map +0 -1
  389. package/dist/previewEntry.js.map +0 -1
  390. package/dist/print-error.d.ts.map +0 -1
  391. package/dist/print-error.js.map +0 -1
  392. package/dist/print-help.d.ts.map +0 -1
  393. package/dist/print-help.js.map +0 -1
  394. package/dist/progress-bar.d.ts.map +0 -1
  395. package/dist/progress-bar.js.map +0 -1
  396. package/dist/render.d.ts.map +0 -1
  397. package/dist/render.js.map +0 -1
  398. package/dist/resolve-from.d.ts.map +0 -1
  399. package/dist/resolve-from.js.map +0 -1
  400. package/dist/setup-cache.d.ts.map +0 -1
  401. package/dist/setup-cache.js.map +0 -1
  402. package/dist/step.d.ts.map +0 -1
  403. package/dist/step.js.map +0 -1
  404. package/dist/still.d.ts.map +0 -1
  405. package/dist/still.js.map +0 -1
  406. package/dist/upgrade.d.ts.map +0 -1
  407. package/dist/upgrade.js.map +0 -1
  408. package/dist/user-passed-output-location.d.ts.map +0 -1
  409. package/dist/user-passed-output-location.js.map +0 -1
  410. package/dist/validate-ffmpeg-version.d.ts.map +0 -1
  411. package/dist/validate-ffmpeg-version.js.map +0 -1
  412. package/dist/versions.d.ts.map +0 -1
  413. package/dist/versions.js.map +0 -1
  414. package/dist/warn-about-ffmpeg-version.d.ts.map +0 -1
  415. package/dist/warn-about-ffmpeg-version.js.map +0 -1
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NotificationCenter = exports.notificationCenter = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const Notification_1 = require("./Notification");
7
+ const container = {
8
+ position: 'absolute',
9
+ justifyContent: 'center',
10
+ alignItems: 'center',
11
+ display: 'flex',
12
+ width: '100%',
13
+ flexDirection: 'column',
14
+ paddingTop: 20,
15
+ pointerEvents: 'none',
16
+ };
17
+ exports.notificationCenter = (0, react_1.createRef)();
18
+ const NotificationCenter = () => {
19
+ const [notifications, setNotifications] = (0, react_1.useState)([]);
20
+ const onRemove = (0, react_1.useCallback)((id) => {
21
+ setNotifications((not) => {
22
+ return not.filter((n) => n.id !== id);
23
+ });
24
+ }, []);
25
+ const addNotification = (0, react_1.useCallback)((notification) => {
26
+ setNotifications((previousNotifications) => {
27
+ return [...previousNotifications, notification];
28
+ });
29
+ }, []);
30
+ (0, react_1.useImperativeHandle)(exports.notificationCenter, () => {
31
+ return {
32
+ addNotification,
33
+ };
34
+ });
35
+ return ((0, jsx_runtime_1.jsx)("div", { style: container, children: notifications.map((n) => {
36
+ return ((0, jsx_runtime_1.jsx)(Notification_1.Notification, { created: n.created, duration: n.duration, id: n.id, onRemove: onRemove, children: n.content }, n.id));
37
+ }) }));
38
+ };
39
+ exports.NotificationCenter = NotificationCenter;
@@ -25,7 +25,7 @@ const PlayPause = ({ playbackRate, loop }) => {
25
25
  loop,
26
26
  playbackRate,
27
27
  });
28
- const { playing, play, pause, frameBack, seek, frameForward, isLastFrame } = player_1.PlayerInternals.usePlayer();
28
+ const { playing, play, pause, pauseAndReturnToPlayStart, frameBack, seek, frameForward, isLastFrame, } = player_1.PlayerInternals.usePlayer();
29
29
  const isStill = (0, is_current_selected_still_1.useIsStill)();
30
30
  (0, react_1.useEffect)(() => {
31
31
  if (isStill) {
@@ -41,6 +41,12 @@ const PlayPause = ({ playbackRate, loop }) => {
41
41
  }
42
42
  e.preventDefault();
43
43
  }, [pause, play, playing]);
44
+ const onEnter = (0, react_1.useCallback)((e) => {
45
+ if (playing) {
46
+ pauseAndReturnToPlayStart();
47
+ }
48
+ e.preventDefault();
49
+ }, [pauseAndReturnToPlayStart, playing]);
44
50
  const videoFps = (_a = video === null || video === void 0 ? void 0 : video.fps) !== null && _a !== void 0 ? _a : null;
45
51
  const onArrowLeft = (0, react_1.useCallback)((e) => {
46
52
  if (!videoFps) {
@@ -89,19 +95,59 @@ const PlayPause = ({ playbackRate, loop }) => {
89
95
  }, [seek, video]);
90
96
  const keybindings = (0, use_keybinding_1.useKeybinding)();
91
97
  (0, react_1.useEffect)(() => {
92
- const arrowLeft = keybindings.registerKeybinding('keydown', 'ArrowLeft', onArrowLeft);
93
- const arrowRight = keybindings.registerKeybinding('keydown', 'ArrowRight', onArrowRight);
94
- const space = keybindings.registerKeybinding('keydown', ' ', onSpace);
95
- const a = keybindings.registerKeybinding('keydown', 'a', jumpToStart);
96
- const e = keybindings.registerKeybinding('keydown', 'e', jumpToEnd);
98
+ const arrowLeft = keybindings.registerKeybinding({
99
+ event: 'keydown',
100
+ key: 'ArrowLeft',
101
+ callback: onArrowLeft,
102
+ commandCtrlKey: false,
103
+ });
104
+ const arrowRight = keybindings.registerKeybinding({
105
+ event: 'keydown',
106
+ key: 'ArrowRight',
107
+ callback: onArrowRight,
108
+ commandCtrlKey: false,
109
+ });
110
+ const space = keybindings.registerKeybinding({
111
+ event: 'keydown',
112
+ key: ' ',
113
+ callback: onSpace,
114
+ commandCtrlKey: false,
115
+ });
116
+ const enter = keybindings.registerKeybinding({
117
+ event: 'keydown',
118
+ key: 'enter',
119
+ callback: onEnter,
120
+ commandCtrlKey: false,
121
+ });
122
+ const a = keybindings.registerKeybinding({
123
+ event: 'keydown',
124
+ key: 'a',
125
+ callback: jumpToStart,
126
+ commandCtrlKey: false,
127
+ });
128
+ const e = keybindings.registerKeybinding({
129
+ event: 'keydown',
130
+ key: 'e',
131
+ callback: jumpToEnd,
132
+ commandCtrlKey: false,
133
+ });
97
134
  return () => {
98
135
  arrowLeft.unregister();
99
136
  arrowRight.unregister();
100
137
  space.unregister();
138
+ enter.unregister();
101
139
  a.unregister();
102
140
  e.unregister();
103
141
  };
104
- }, [jumpToEnd, jumpToStart, keybindings, onArrowLeft, onArrowRight, onSpace]);
142
+ }, [
143
+ jumpToEnd,
144
+ jumpToStart,
145
+ keybindings,
146
+ onArrowLeft,
147
+ onArrowRight,
148
+ onEnter,
149
+ onSpace,
150
+ ]);
105
151
  if (isStill) {
106
152
  return null;
107
153
  }
@@ -54,9 +54,24 @@ const PlaybackKeyboardShortcutsManager = ({ setPlaybackRate }) => {
54
54
  play();
55
55
  }, [play, playing, setPlaybackRate]);
56
56
  (0, react_1.useEffect)(() => {
57
- const jKey = keybindings.registerKeybinding('keydown', 'j', onJKey);
58
- const kKey = keybindings.registerKeybinding('keydown', 'k', onKKey);
59
- const lKey = keybindings.registerKeybinding('keydown', 'l', onLKey);
57
+ const jKey = keybindings.registerKeybinding({
58
+ event: 'keydown',
59
+ key: 'j',
60
+ callback: onJKey,
61
+ commandCtrlKey: false,
62
+ });
63
+ const kKey = keybindings.registerKeybinding({
64
+ event: 'keydown',
65
+ key: 'k',
66
+ callback: onKKey,
67
+ commandCtrlKey: false,
68
+ });
69
+ const lKey = keybindings.registerKeybinding({
70
+ event: 'keydown',
71
+ key: 'l',
72
+ callback: onLKey,
73
+ commandCtrlKey: false,
74
+ });
60
75
  return () => {
61
76
  jKey.unregister();
62
77
  kKey.unregister();
@@ -87,14 +87,29 @@ const TimelineInOutPointToggle = () => {
87
87
  });
88
88
  }, [setInAndOutFrames]);
89
89
  (0, react_1.useEffect)(() => {
90
- const iKey = keybindings.registerKeybinding('keypress', 'i', () => {
91
- onInMark();
90
+ const iKey = keybindings.registerKeybinding({
91
+ event: 'keypress',
92
+ key: 'i',
93
+ callback: () => {
94
+ onInMark();
95
+ },
96
+ commandCtrlKey: false,
92
97
  });
93
- const oKey = keybindings.registerKeybinding('keypress', 'o', () => {
94
- onOutMark();
98
+ const oKey = keybindings.registerKeybinding({
99
+ event: 'keypress',
100
+ key: 'o',
101
+ callback: () => {
102
+ onOutMark();
103
+ },
104
+ commandCtrlKey: false,
95
105
  });
96
- const xKey = keybindings.registerKeybinding('keypress', 'x', () => {
97
- onInOutClear();
106
+ const xKey = keybindings.registerKeybinding({
107
+ event: 'keypress',
108
+ key: 'x',
109
+ callback: () => {
110
+ onInOutClear();
111
+ },
112
+ commandCtrlKey: false,
98
113
  });
99
114
  return () => {
100
115
  oKey.unregister();
@@ -38,6 +38,6 @@ const UpdateModal = ({ info }) => {
38
38
  setSelectedModal(null);
39
39
  }, [setSelectedModal]);
40
40
  const command = commands[info.packageManager];
41
- return ((0, jsx_runtime_1.jsxs)(ModalContainer_1.ModalContainer, { onOutsideClick: onQuit, onEscape: onQuit, children: [(0, jsx_runtime_1.jsx)(ModalHeader_1.NewCompHeader, { title: "Update available" }), (0, jsx_runtime_1.jsxs)("div", { style: container, children: [(0, jsx_runtime_1.jsx)("p", { children: "A new update for Remotion is available! Run the following command:" }), (0, jsx_runtime_1.jsxs)(layout_1.Row, { align: "center", children: [(0, jsx_runtime_1.jsx)(layout_1.Flex, { children: (0, jsx_runtime_1.jsx)("pre", { onClick: () => (0, copy_text_1.copyCmd)(command), style: code, children: command }) }), (0, jsx_runtime_1.jsx)(layout_1.Spacing, { x: 1 }), (0, jsx_runtime_1.jsx)(CopyButton_1.CopyButton, { textToCopy: command, label: "Copy command", labelWhenCopied: "Copied!" })] }), (0, jsx_runtime_1.jsxs)("p", { children: ["This will upgrade Remotion from ", info.currentVersion, " to", ' ', info.latestVersion, "."] }), (0, jsx_runtime_1.jsxs)("p", { children: ["Read the", ' ', (0, jsx_runtime_1.jsx)("a", { style: link, target: "_blank", href: "https://github.com/remotion-dev/remotion/releases", children: "Release notes" }), ' ', "to know what", "'s", " new in Remotion."] })] })] }));
41
+ return ((0, jsx_runtime_1.jsxs)(ModalContainer_1.ModalContainer, { onOutsideClick: onQuit, onEscape: onQuit, children: [(0, jsx_runtime_1.jsx)(ModalHeader_1.NewCompHeader, { title: "Update available" }), (0, jsx_runtime_1.jsxs)("div", { style: container, children: [(0, jsx_runtime_1.jsx)("p", { children: "A new update for Remotion is available! Run the following command:" }), (0, jsx_runtime_1.jsxs)(layout_1.Row, { align: "center", children: [(0, jsx_runtime_1.jsx)(layout_1.Flex, { children: (0, jsx_runtime_1.jsx)("pre", { onClick: () => (0, copy_text_1.copyText)(command), style: code, children: command }) }), (0, jsx_runtime_1.jsx)(layout_1.Spacing, { x: 1 }), (0, jsx_runtime_1.jsx)(CopyButton_1.CopyButton, { textToCopy: command, label: "Copy command", labelWhenCopied: "Copied!" })] }), (0, jsx_runtime_1.jsxs)("p", { children: ["This will upgrade Remotion from ", info.currentVersion, " to", ' ', info.latestVersion, "."] }), (0, jsx_runtime_1.jsxs)("p", { children: ["Read the", ' ', (0, jsx_runtime_1.jsx)("a", { style: link, target: "_blank", href: "https://github.com/remotion-dev/remotion/releases", children: "Release notes" }), ' ', "to know what", "'s", " new in Remotion."] })] })] }));
42
42
  };
43
43
  exports.UpdateModal = UpdateModal;
@@ -1 +1 @@
1
- export declare const copyCmd: (cmd: string) => void;
1
+ export declare const copyText: (cmd: string) => void;
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.copyCmd = void 0;
4
- const copyCmd = (cmd) => {
3
+ exports.copyText = void 0;
4
+ const copyText = (cmd) => {
5
5
  const permissionName = 'clipboard-write';
6
6
  navigator.permissions
7
7
  .query({ name: permissionName })
@@ -11,7 +11,8 @@ const copyCmd = (cmd) => {
11
11
  }
12
12
  })
13
13
  .catch((err) => {
14
- console.log('Could not copy command', err);
14
+ // eslint-disable-next-line no-alert
15
+ alert('Could not copy:' + err);
15
16
  });
16
17
  };
17
- exports.copyCmd = copyCmd;
18
+ exports.copyText = copyText;
@@ -0,0 +1 @@
1
+ export declare const pickColor: () => void;
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.pickColor = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const layout_1 = require("../components/layout");
6
+ const ColorDot_1 = require("../components/Notifications/ColorDot");
7
+ const NotificationCenter_1 = require("../components/Notifications/NotificationCenter");
8
+ const copy_text_1 = require("./copy-text");
9
+ const pickColor = () => {
10
+ // @ts-expect-error
11
+ const open = new EyeDropper().open();
12
+ open
13
+ .then((color) => {
14
+ var _a;
15
+ (0, copy_text_1.copyText)(color.sRGBHex);
16
+ (_a = NotificationCenter_1.notificationCenter.current) === null || _a === void 0 ? void 0 : _a.addNotification({
17
+ content: ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(ColorDot_1.ColorDot, { color: color.sRGBHex }), " ", (0, jsx_runtime_1.jsx)(layout_1.Spacing, { x: 1 }), " Copied", ' ', color.sRGBHex] })),
18
+ created: Date.now(),
19
+ duration: 2000,
20
+ id: String(Math.random()),
21
+ });
22
+ })
23
+ .catch((err) => {
24
+ var _a;
25
+ if (err.message.includes('canceled')) {
26
+ return;
27
+ }
28
+ (_a = NotificationCenter_1.notificationCenter.current) === null || _a === void 0 ? void 0 : _a.addNotification({
29
+ content: `Could not pick color.`,
30
+ duration: 2000,
31
+ created: Date.now(),
32
+ id: String(Math.random()),
33
+ });
34
+ });
35
+ };
36
+ exports.pickColor = pickColor;
@@ -1,6 +1,11 @@
1
1
  import type { KeyEventType } from '../state/keybindings';
2
2
  export declare const useKeybinding: () => {
3
- registerKeybinding: (event: KeyEventType, key: string, callback: (e: KeyboardEvent) => void) => {
3
+ registerKeybinding: (options: {
4
+ event: KeyEventType;
5
+ key: string;
6
+ commandCtrlKey: boolean;
7
+ callback: (e: KeyboardEvent) => void;
8
+ }) => {
4
9
  unregister: () => void;
5
10
  };
6
11
  isHighestContext: boolean;
@@ -8,21 +8,26 @@ const useKeybinding = () => {
8
8
  const [paneId] = (0, react_1.useState)(() => String(Math.random()));
9
9
  const context = (0, react_1.useContext)(keybindings_1.KeybindingContext);
10
10
  const { isHighestContext } = (0, z_index_1.useZIndex)();
11
- const registerKeybinding = (0, react_1.useCallback)((event, key, callback) => {
11
+ const registerKeybinding = (0, react_1.useCallback)((options) => {
12
12
  if (!isHighestContext) {
13
13
  return {
14
14
  unregister: () => undefined,
15
15
  };
16
16
  }
17
17
  const listener = (e) => {
18
- if (e.key.toLowerCase() === key.toLowerCase()) {
19
- callback(e);
18
+ const commandKey = window.navigator.platform.startsWith('Mac')
19
+ ? e.metaKey
20
+ : e.ctrlKey;
21
+ if (e.key.toLowerCase() === options.key.toLowerCase() &&
22
+ options.commandCtrlKey === commandKey) {
23
+ options.callback(e);
24
+ e.preventDefault();
20
25
  }
21
26
  };
22
27
  const toRegister = {
23
28
  registeredFromPane: paneId,
24
- event,
25
- key,
29
+ event: options.event,
30
+ key: options.key,
26
31
  callback: listener,
27
32
  id: String(Math.random()),
28
33
  };
@@ -4,7 +4,9 @@ exports.KeybindingContextProvider = exports.KeybindingContext = void 0;
4
4
  const jsx_runtime_1 = require("react/jsx-runtime");
5
5
  const react_1 = require("react");
6
6
  exports.KeybindingContext = (0, react_1.createContext)({
7
- registerKeybinding: () => undefined,
7
+ registerKeybinding: () => {
8
+ throw new Error('Has no keybinding context');
9
+ },
8
10
  unregisterKeybinding: () => undefined,
9
11
  unregisterPane: () => undefined,
10
12
  });
@@ -12,7 +12,12 @@ exports.ZIndexContext = (0, react_1.createContext)({
12
12
  const EscapeHook = ({ onEscape }) => {
13
13
  const keybindings = (0, use_keybinding_1.useKeybinding)();
14
14
  (0, react_1.useEffect)(() => {
15
- const escape = keybindings.registerKeybinding('keydown', 'Escape', onEscape);
15
+ const escape = keybindings.registerKeybinding({
16
+ event: 'keydown',
17
+ key: 'Escape',
18
+ callback: onEscape,
19
+ commandCtrlKey: false,
20
+ });
16
21
  return () => {
17
22
  escape.unregister();
18
23
  };
@@ -8,7 +8,7 @@ export declare const getCliOptions: (options: {
8
8
  parallelism: number | null;
9
9
  frameRange: FrameRange | null;
10
10
  shouldOutputImageSequence: boolean;
11
- codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv";
11
+ codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif";
12
12
  overwrite: boolean;
13
13
  inputProps: object;
14
14
  envVariables: Record<string, string>;
@@ -19,6 +19,8 @@ export declare const getCliOptions: (options: {
19
19
  pixelFormat: "yuv420p" | "yuva420p" | "yuv422p" | "yuv444p" | "yuv420p10le" | "yuv422p10le" | "yuv444p10le" | "yuva444p10le";
20
20
  imageFormat: "png" | "jpeg" | "none";
21
21
  proResProfile: "4444-xq" | "4444" | "hq" | "standard" | "light" | "proxy" | undefined;
22
+ everyNthFrame: number;
23
+ numberOfGifLoops: number | null;
22
24
  stillFrame: number;
23
25
  browserExecutable: BrowserExecutable;
24
26
  ffmpegExecutable: import("remotion").FfmpegExecutable;
@@ -152,9 +152,13 @@ const getCliOptions = async (options) => {
152
152
  headless: remotion_1.Internals.getChromiumHeadlessMode(),
153
153
  gl: (_a = remotion_1.Internals.getChromiumOpenGlRenderer()) !== null && _a !== void 0 ? _a : remotion_1.Internals.DEFAULT_OPENGL_RENDERER,
154
154
  };
155
+ const everyNthFrame = remotion_1.Internals.getAndValidateEveryNthFrame(codec);
156
+ const numberOfGifLoops = remotion_1.Internals.getAndValidateNumberOfGifLoops(codec);
157
+ const parallelism = remotion_1.Internals.getConcurrency();
158
+ renderer_1.RenderInternals.validateConcurrency(parallelism, 'concurrency');
155
159
  return {
156
160
  puppeteerTimeout: remotion_1.Internals.getCurrentPuppeteerTimeout(),
157
- parallelism: remotion_1.Internals.getConcurrency(),
161
+ parallelism,
158
162
  frameRange,
159
163
  shouldOutputImageSequence,
160
164
  codec,
@@ -170,6 +174,8 @@ const getCliOptions = async (options) => {
170
174
  pixelFormat,
171
175
  imageFormat,
172
176
  proResProfile,
177
+ everyNthFrame,
178
+ numberOfGifLoops,
173
179
  stillFrame: remotion_1.Internals.getStillFrame(),
174
180
  browserExecutable,
175
181
  ffmpegExecutable,
@@ -15,7 +15,8 @@ const getImageFormat = (codec) => {
15
15
  codec === 'h265' ||
16
16
  codec === 'vp8' ||
17
17
  codec === 'vp9' ||
18
- codec === 'prores') {
18
+ codec === 'prores' ||
19
+ codec === 'gif') {
19
20
  return 'jpeg';
20
21
  }
21
22
  if (codec === undefined) {
package/dist/index.d.ts CHANGED
@@ -74,7 +74,7 @@ export declare const CliInternals: {
74
74
  parallelism: number | null;
75
75
  frameRange: import("remotion").FrameRange | null;
76
76
  shouldOutputImageSequence: boolean;
77
- codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv";
77
+ codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif";
78
78
  overwrite: boolean;
79
79
  inputProps: object;
80
80
  envVariables: Record<string, string>;
@@ -85,6 +85,8 @@ export declare const CliInternals: {
85
85
  pixelFormat: "yuv420p" | "yuva420p" | "yuv422p" | "yuv444p" | "yuv420p10le" | "yuv422p10le" | "yuv444p10le" | "yuva444p10le";
86
86
  imageFormat: "png" | "jpeg" | "none";
87
87
  proResProfile: "4444-xq" | "4444" | "hq" | "standard" | "light" | "proxy" | undefined;
88
+ everyNthFrame: number;
89
+ numberOfGifLoops: number | null;
88
90
  stillFrame: number;
89
91
  browserExecutable: import("remotion").BrowserExecutable;
90
92
  ffmpegExecutable: import("remotion").FfmpegExecutable;
@@ -11,6 +11,8 @@ export declare type CommandLineOptions = {
11
11
  ['env-file']: string;
12
12
  ['ignore-certificate-errors']: string;
13
13
  ['disable-web-security']: string;
14
+ ['every-nth-frame']: number;
15
+ ['number-of-gif-loops']: number;
14
16
  codec: Codec;
15
17
  concurrency: number;
16
18
  timeout: number;
@@ -42,6 +42,9 @@ const parseCommandLine = (type) => {
42
42
  if (exports.parsedCli['ffmpeg-executable']) {
43
43
  remotion_1.Config.Rendering.setFfmpegExecutable((0, path_1.resolve)(exports.parsedCli['ffmpeg-executable']));
44
44
  }
45
+ if (exports.parsedCli['number-of-gif-loops']) {
46
+ remotion_1.Config.Rendering.setNumberOfGifLoops(exports.parsedCli['number-of-gif-loops']);
47
+ }
45
48
  if (exports.parsedCli['ffprobe-executable']) {
46
49
  remotion_1.Config.Rendering.setFfprobeExecutable((0, path_1.resolve)(exports.parsedCli['ffprobe-executable']));
47
50
  }
@@ -57,9 +60,6 @@ const parseCommandLine = (type) => {
57
60
  if (exports.parsedCli['disable-headless']) {
58
61
  remotion_1.Config.Puppeteer.setChromiumHeadlessMode(false);
59
62
  }
60
- if (exports.parsedCli.gl) {
61
- remotion_1.Config.Puppeteer.setChromiumOpenGlRenderer(exports.parsedCli.gl);
62
- }
63
63
  if (exports.parsedCli.log) {
64
64
  if (!remotion_1.Internals.Logging.isValidLogLevel(exports.parsedCli.log)) {
65
65
  log_1.Log.error('Invalid `--log` value passed.');
@@ -104,6 +104,12 @@ const parseCommandLine = (type) => {
104
104
  if (exports.parsedCli.codec) {
105
105
  remotion_1.Config.Output.setCodec(exports.parsedCli.codec);
106
106
  }
107
+ if (exports.parsedCli['every-nth-frame']) {
108
+ remotion_1.Config.Rendering.setEveryNthFrame(exports.parsedCli['every-nth-frame']);
109
+ }
110
+ if (exports.parsedCli.gl) {
111
+ remotion_1.Config.Puppeteer.setChromiumOpenGlRenderer(exports.parsedCli.gl);
112
+ }
107
113
  if (exports.parsedCli['prores-profile']) {
108
114
  remotion_1.Config.Output.setProResProfile(String(exports.parsedCli['prores-profile']));
109
115
  }
@@ -1,2 +1,4 @@
1
1
  import React from 'react';
2
- export declare const AskOnDiscord: React.FC;
2
+ export declare const AskOnDiscord: React.FC<{
3
+ canHaveKeyboardShortcuts: boolean;
4
+ }>;
@@ -4,11 +4,29 @@ exports.AskOnDiscord = void 0;
4
4
  const jsx_runtime_1 = require("react/jsx-runtime");
5
5
  const DISCORD_LINK = 'https://remotion.dev/discord';
6
6
  const react_1 = require("react");
7
+ const use_keybinding_1 = require("../../../editor/helpers/use-keybinding");
7
8
  const Button_1 = require("./Button");
8
- const AskOnDiscord = () => {
9
+ const ShortcutHint_1 = require("./ShortcutHint");
10
+ const AskOnDiscord = ({ canHaveKeyboardShortcuts }) => {
9
11
  const openInBrowser = (0, react_1.useCallback)(() => {
10
12
  window.open(DISCORD_LINK, '_blank');
11
13
  }, []);
12
- return (0, jsx_runtime_1.jsx)(Button_1.Button, { onClick: openInBrowser, children: "Ask on Discord" });
14
+ const { registerKeybinding } = (0, use_keybinding_1.useKeybinding)();
15
+ (0, react_1.useEffect)(() => {
16
+ if (!canHaveKeyboardShortcuts) {
17
+ return;
18
+ }
19
+ const onEditor = () => {
20
+ openInBrowser();
21
+ };
22
+ const { unregister } = registerKeybinding({
23
+ event: 'keydown',
24
+ key: 'd',
25
+ callback: onEditor,
26
+ commandCtrlKey: true,
27
+ });
28
+ return () => unregister();
29
+ }, [canHaveKeyboardShortcuts, openInBrowser, registerKeybinding]);
30
+ return ((0, jsx_runtime_1.jsxs)(Button_1.Button, { onClick: openInBrowser, children: ["Ask on Discord", ' ', canHaveKeyboardShortcuts ? ((0, jsx_runtime_1.jsx)(ShortcutHint_1.ShortcutHint, { keyToPress: "d", cmdOrCtrl: true })) : null] }));
13
31
  };
14
32
  exports.AskOnDiscord = AskOnDiscord;
@@ -2,16 +2,16 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.Button = void 0;
4
4
  const jsx_runtime_1 = require("react/jsx-runtime");
5
- const INPUT_BORDER_COLOR_UNHOVERED = 'rgba(0, 0, 0, 0.6)';
6
- const INPUT_BACKGROUND = '#2f363d';
5
+ const colors_1 = require("../../../editor/helpers/colors");
7
6
  const button = {
8
- border: `1px solid ${INPUT_BORDER_COLOR_UNHOVERED}`,
7
+ border: `1px solid ${colors_1.INPUT_BORDER_COLOR_UNHOVERED}`,
9
8
  borderRadius: 4,
10
- backgroundColor: INPUT_BACKGROUND,
9
+ backgroundColor: colors_1.INPUT_BACKGROUND,
11
10
  appearance: 'none',
12
11
  fontFamily: 'inherit',
13
12
  fontSize: 14,
14
13
  color: 'white',
14
+ flexDirection: 'row',
15
15
  };
16
16
  const buttonContainer = {
17
17
  padding: 10,
@@ -2,4 +2,5 @@ import React from 'react';
2
2
  import type { ErrorRecord } from '../react-overlay/listen-to-runtime-errors';
3
3
  export declare const ErrorDisplay: React.FC<{
4
4
  display: ErrorRecord;
5
+ keyboardShortcuts: boolean;
5
6
  }>;
@@ -6,6 +6,8 @@ const react_1 = require("react");
6
6
  const map_error_to_react_stack_1 = require("../react-overlay/effects/map-error-to-react-stack");
7
7
  const AskOnDiscord_1 = require("./AskOnDiscord");
8
8
  const ErrorTitle_1 = require("./ErrorTitle");
9
+ const get_help_link_1 = require("./get-help-link");
10
+ const HelpLink_1 = require("./HelpLink");
9
11
  const OpenInEditor_1 = require("./OpenInEditor");
10
12
  const SearchGitHubIssues_1 = require("./SearchGitHubIssues");
11
13
  const StackFrame_1 = require("./StackFrame");
@@ -18,7 +20,7 @@ const spacer = {
18
20
  width: 5,
19
21
  display: 'inline-block',
20
22
  };
21
- const ErrorDisplay = ({ display }) => {
23
+ const ErrorDisplay = ({ display, keyboardShortcuts }) => {
22
24
  const highestLineNumber = Math.max(...display.stackFrames
23
25
  .map((s) => s.originalScriptCode)
24
26
  .flat(1)
@@ -36,7 +38,8 @@ const ErrorDisplay = ({ display }) => {
36
38
  .trim();
37
39
  }, [display.error]);
38
40
  const lineNumberWidth = String(highestLineNumber).length;
39
- return ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)(ErrorTitle_1.ErrorTitle, { symbolicating: false, name: display.error.name, message: message }), display.stackFrames.length > 0 && window.remotion_editorName ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(OpenInEditor_1.OpenInEditor, { stack: display.stackFrames[0] }), (0, jsx_runtime_1.jsx)("div", { style: spacer })] })) : null, (0, jsx_runtime_1.jsx)(SearchGitHubIssues_1.SearchGithubIssues, { message: display.error.message }), (0, jsx_runtime_1.jsx)("div", { style: spacer }), (0, jsx_runtime_1.jsx)(AskOnDiscord_1.AskOnDiscord, {}), (0, jsx_runtime_1.jsx)("div", { style: stack, children: display.stackFrames.map((s, i) => {
41
+ const helpLink = (0, get_help_link_1.getHelpLink)(message);
42
+ return ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)(ErrorTitle_1.ErrorTitle, { symbolicating: false, name: display.error.name, message: message }), helpLink ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(HelpLink_1.HelpLink, { link: helpLink, canHaveKeyboardShortcuts: keyboardShortcuts }), (0, jsx_runtime_1.jsx)("div", { style: spacer })] })) : null, display.stackFrames.length > 0 && window.remotion_editorName ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(OpenInEditor_1.OpenInEditor, { canHaveKeyboardShortcuts: keyboardShortcuts, stack: display.stackFrames[0] }), (0, jsx_runtime_1.jsx)("div", { style: spacer })] })) : null, (0, jsx_runtime_1.jsx)(SearchGitHubIssues_1.SearchGithubIssues, { canHaveKeyboardShortcuts: keyboardShortcuts, message: display.error.message }), (0, jsx_runtime_1.jsx)("div", { style: spacer }), (0, jsx_runtime_1.jsx)(AskOnDiscord_1.AskOnDiscord, { canHaveKeyboardShortcuts: keyboardShortcuts }), (0, jsx_runtime_1.jsx)("div", { style: stack, children: display.stackFrames.map((s, i) => {
40
43
  return ((0, jsx_runtime_1.jsx)(StackFrame_1.StackElement
41
44
  // eslint-disable-next-line react/no-array-index-key
42
45
  , { isFirst: i === 0, s: s, lineNumberWidth: lineNumberWidth, defaultFunctionName: '(anonymous function)' }, i));
@@ -1,4 +1,5 @@
1
1
  import React from 'react';
2
2
  export declare const ErrorLoader: React.FC<{
3
3
  error: Error;
4
+ keyboardShortcuts: boolean;
4
5
  }>;
@@ -21,7 +21,7 @@ const errorWhileErrorStyle = {
21
21
  lineHeight: 1.5,
22
22
  whiteSpace: 'pre',
23
23
  };
24
- const ErrorLoader = ({ error }) => {
24
+ const ErrorLoader = ({ error, keyboardShortcuts }) => {
25
25
  const [state, setState] = (0, react_1.useState)({
26
26
  type: 'loading',
27
27
  });
@@ -56,6 +56,6 @@ const ErrorLoader = ({ error }) => {
56
56
  if (state.type === 'no-record') {
57
57
  return ((0, jsx_runtime_1.jsxs)("div", { style: container, children: [(0, jsx_runtime_1.jsx)(ErrorTitle_1.ErrorTitle, { symbolicating: false, name: error.name, message: error.message }), (0, jsx_runtime_1.jsx)("div", { style: errorWhileErrorStyle, children: "Check the Terminal and browser console for error messages." })] }));
58
58
  }
59
- return ((0, jsx_runtime_1.jsx)("div", { style: container, children: (0, jsx_runtime_1.jsx)(ErrorDisplay_1.ErrorDisplay, { display: state.record }) }));
59
+ return ((0, jsx_runtime_1.jsx)("div", { style: container, children: (0, jsx_runtime_1.jsx)(ErrorDisplay_1.ErrorDisplay, { keyboardShortcuts: keyboardShortcuts, display: state.record }) }));
60
60
  };
61
61
  exports.ErrorLoader = ErrorLoader;
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ export declare const ErrorMessage: React.FC<{
3
+ message: string;
4
+ }>;