@remotion/cli 3.0.28 → 3.0.31

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 (401) 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/editor/components/CompositionManager.d.ts +4 -0
  6. package/dist/editor/components/CompositionManager.js +60 -0
  7. package/dist/editor/components/CopyButton.js +1 -1
  8. package/dist/editor/components/Editor.js +2 -1
  9. package/dist/editor/components/GlobalKeybindings.js +26 -11
  10. package/dist/editor/components/KeyboardShortcutsModal.js +1 -1
  11. package/dist/editor/components/Menu/MenuItem.d.ts +1 -1
  12. package/dist/editor/components/MenuToolbar.js +24 -2
  13. package/dist/editor/components/NewComposition/MenuContent.js +42 -7
  14. package/dist/editor/components/Notifications/ColorDot.d.ts +4 -0
  15. package/dist/editor/components/Notifications/ColorDot.js +22 -0
  16. package/dist/editor/components/Notifications/Notification.d.ts +8 -0
  17. package/dist/editor/components/Notifications/Notification.js +31 -0
  18. package/dist/editor/components/Notifications/NotificationCenter.d.ts +13 -0
  19. package/dist/editor/components/Notifications/NotificationCenter.js +39 -0
  20. package/dist/editor/components/PlayPause.js +53 -7
  21. package/dist/editor/components/PlaybackKeyboardShortcutsManager.js +18 -3
  22. package/dist/editor/components/TimelineInOutToggle.js +21 -6
  23. package/dist/editor/components/UpdateModal/UpdateModal.js +1 -1
  24. package/dist/editor/helpers/copy-text.d.ts +1 -1
  25. package/dist/editor/helpers/copy-text.js +5 -4
  26. package/dist/editor/helpers/pick-color.d.ts +1 -0
  27. package/dist/editor/helpers/pick-color.js +36 -0
  28. package/dist/editor/helpers/use-keybinding.d.ts +6 -1
  29. package/dist/editor/helpers/use-keybinding.js +10 -5
  30. package/dist/editor/state/keybindings.js +3 -1
  31. package/dist/editor/state/z-index.js +6 -1
  32. package/dist/get-cli-options.js +3 -1
  33. package/dist/preview-server/error-overlay/remotion-overlay/AskOnDiscord.d.ts +3 -1
  34. package/dist/preview-server/error-overlay/remotion-overlay/AskOnDiscord.js +20 -2
  35. package/dist/preview-server/error-overlay/remotion-overlay/Button.js +4 -4
  36. package/dist/preview-server/error-overlay/remotion-overlay/ErrorDisplay.d.ts +1 -0
  37. package/dist/preview-server/error-overlay/remotion-overlay/ErrorDisplay.js +5 -2
  38. package/dist/preview-server/error-overlay/remotion-overlay/ErrorLoader.d.ts +1 -0
  39. package/dist/preview-server/error-overlay/remotion-overlay/ErrorLoader.js +2 -2
  40. package/dist/preview-server/error-overlay/remotion-overlay/ErrorMessage.d.ts +4 -0
  41. package/dist/preview-server/error-overlay/remotion-overlay/ErrorMessage.js +67 -0
  42. package/dist/preview-server/error-overlay/remotion-overlay/ErrorTitle.js +5 -9
  43. package/dist/preview-server/error-overlay/remotion-overlay/HelpLink.d.ts +6 -0
  44. package/dist/preview-server/error-overlay/remotion-overlay/HelpLink.js +31 -0
  45. package/dist/preview-server/error-overlay/remotion-overlay/OpenInEditor.d.ts +1 -0
  46. package/dist/preview-server/error-overlay/remotion-overlay/OpenInEditor.js +20 -2
  47. package/dist/preview-server/error-overlay/remotion-overlay/Overlay.js +8 -7
  48. package/dist/preview-server/error-overlay/remotion-overlay/SearchGitHubIssues.d.ts +1 -0
  49. package/dist/preview-server/error-overlay/remotion-overlay/SearchGitHubIssues.js +20 -2
  50. package/dist/preview-server/error-overlay/remotion-overlay/ShortcutHint.d.ts +5 -0
  51. package/dist/preview-server/error-overlay/remotion-overlay/ShortcutHint.js +16 -0
  52. package/dist/preview-server/error-overlay/remotion-overlay/StackFrame.js +1 -1
  53. package/dist/preview-server/error-overlay/remotion-overlay/carets.d.ts +4 -2
  54. package/dist/preview-server/error-overlay/remotion-overlay/carets.js +2 -2
  55. package/dist/preview-server/error-overlay/remotion-overlay/get-help-link.d.ts +5 -0
  56. package/dist/preview-server/error-overlay/remotion-overlay/get-help-link.js +19 -0
  57. package/dist/preview-server/fast-refresh/helpers.d.ts +39 -0
  58. package/dist/preview-server/fast-refresh/helpers.js +145 -0
  59. package/dist/preview-server/fast-refresh/index.d.ts +30 -0
  60. package/dist/preview-server/fast-refresh/index.js +86 -0
  61. package/dist/preview-server/fast-refresh/loader.d.ts +35 -0
  62. package/dist/preview-server/fast-refresh/loader.js +81 -0
  63. package/dist/preview-server/fast-refresh/runtime.d.ts +35 -0
  64. package/dist/preview-server/fast-refresh/runtime.js +32 -0
  65. package/dist/preview-server/static-preview.d.ts +1 -0
  66. package/dist/preview-server/static-preview.js +40 -0
  67. package/dist/preview-server/webpack-cache.d.ts +12 -0
  68. package/dist/preview-server/webpack-cache.js +66 -0
  69. package/package.json +7 -7
  70. package/dist/ansi/ansi-diff.d.ts.map +0 -1
  71. package/dist/ansi/ansi-diff.js.map +0 -1
  72. package/dist/ansi/ansi-regex.d.ts.map +0 -1
  73. package/dist/ansi/ansi-regex.js.map +0 -1
  74. package/dist/ansi/ansi-split.d.ts.map +0 -1
  75. package/dist/ansi/ansi-split.js.map +0 -1
  76. package/dist/check-version.d.ts.map +0 -1
  77. package/dist/check-version.js.map +0 -1
  78. package/dist/code-frame.d.ts.map +0 -1
  79. package/dist/code-frame.js.map +0 -1
  80. package/dist/compositions.d.ts.map +0 -1
  81. package/dist/compositions.js.map +0 -1
  82. package/dist/download-progress.d.ts.map +0 -1
  83. package/dist/download-progress.js.map +0 -1
  84. package/dist/editor/components/AudioWaveform.d.ts.map +0 -1
  85. package/dist/editor/components/AudioWaveform.js.map +0 -1
  86. package/dist/editor/components/AudioWaveformBar.d.ts.map +0 -1
  87. package/dist/editor/components/AudioWaveformBar.js.map +0 -1
  88. package/dist/editor/components/Canvas.d.ts.map +0 -1
  89. package/dist/editor/components/Canvas.js.map +0 -1
  90. package/dist/editor/components/CheckboardToggle.d.ts.map +0 -1
  91. package/dist/editor/components/CheckboardToggle.js.map +0 -1
  92. package/dist/editor/components/ClipboardIcon.d.ts.map +0 -1
  93. package/dist/editor/components/ClipboardIcon.js.map +0 -1
  94. package/dist/editor/components/CompositionSelector.d.ts.map +0 -1
  95. package/dist/editor/components/CompositionSelector.js.map +0 -1
  96. package/dist/editor/components/CompositionSelectorItem.d.ts.map +0 -1
  97. package/dist/editor/components/CompositionSelectorItem.js.map +0 -1
  98. package/dist/editor/components/ControlButton.d.ts.map +0 -1
  99. package/dist/editor/components/ControlButton.js.map +0 -1
  100. package/dist/editor/components/CopyButton.d.ts.map +0 -1
  101. package/dist/editor/components/CopyButton.js.map +0 -1
  102. package/dist/editor/components/CurrentComposition.d.ts.map +0 -1
  103. package/dist/editor/components/CurrentComposition.js.map +0 -1
  104. package/dist/editor/components/Editor.d.ts.map +0 -1
  105. package/dist/editor/components/Editor.js.map +0 -1
  106. package/dist/editor/components/EditorContent.d.ts.map +0 -1
  107. package/dist/editor/components/EditorContent.js.map +0 -1
  108. package/dist/editor/components/FpsCounter.d.ts.map +0 -1
  109. package/dist/editor/components/FpsCounter.js.map +0 -1
  110. package/dist/editor/components/FramePersistor.d.ts.map +0 -1
  111. package/dist/editor/components/FramePersistor.js.map +0 -1
  112. package/dist/editor/components/GlobalKeybindings.d.ts.map +0 -1
  113. package/dist/editor/components/GlobalKeybindings.js.map +0 -1
  114. package/dist/editor/components/KeyboardShortcutsModal.d.ts.map +0 -1
  115. package/dist/editor/components/KeyboardShortcutsModal.js.map +0 -1
  116. package/dist/editor/components/LoadingIndicator.d.ts.map +0 -1
  117. package/dist/editor/components/LoadingIndicator.js.map +0 -1
  118. package/dist/editor/components/LoopToggle.d.ts.map +0 -1
  119. package/dist/editor/components/LoopToggle.js.map +0 -1
  120. package/dist/editor/components/Menu/MenuDivider.d.ts.map +0 -1
  121. package/dist/editor/components/Menu/MenuDivider.js.map +0 -1
  122. package/dist/editor/components/Menu/MenuItem.d.ts.map +0 -1
  123. package/dist/editor/components/Menu/MenuItem.js.map +0 -1
  124. package/dist/editor/components/Menu/MenuSubItem.d.ts.map +0 -1
  125. package/dist/editor/components/Menu/MenuSubItem.js.map +0 -1
  126. package/dist/editor/components/Menu/SubMenu.d.ts.map +0 -1
  127. package/dist/editor/components/Menu/SubMenu.js.map +0 -1
  128. package/dist/editor/components/Menu/portals.d.ts.map +0 -1
  129. package/dist/editor/components/Menu/portals.js.map +0 -1
  130. package/dist/editor/components/Menu/styles.d.ts.map +0 -1
  131. package/dist/editor/components/Menu/styles.js.map +0 -1
  132. package/dist/editor/components/MenuToolbar.d.ts.map +0 -1
  133. package/dist/editor/components/MenuToolbar.js.map +0 -1
  134. package/dist/editor/components/ModalContainer.d.ts.map +0 -1
  135. package/dist/editor/components/ModalContainer.js.map +0 -1
  136. package/dist/editor/components/ModalHeader.d.ts.map +0 -1
  137. package/dist/editor/components/ModalHeader.js.map +0 -1
  138. package/dist/editor/components/MuteToggle.d.ts.map +0 -1
  139. package/dist/editor/components/MuteToggle.js.map +0 -1
  140. package/dist/editor/components/NewComposition/CancelButton.d.ts.map +0 -1
  141. package/dist/editor/components/NewComposition/CancelButton.js.map +0 -1
  142. package/dist/editor/components/NewComposition/ComboBox.d.ts.map +0 -1
  143. package/dist/editor/components/NewComposition/ComboBox.js.map +0 -1
  144. package/dist/editor/components/NewComposition/CopyHint.d.ts.map +0 -1
  145. package/dist/editor/components/NewComposition/CopyHint.js.map +0 -1
  146. package/dist/editor/components/NewComposition/InputDragger.d.ts.map +0 -1
  147. package/dist/editor/components/NewComposition/InputDragger.js.map +0 -1
  148. package/dist/editor/components/NewComposition/MenuContent.d.ts.map +0 -1
  149. package/dist/editor/components/NewComposition/MenuContent.js.map +0 -1
  150. package/dist/editor/components/NewComposition/NewCompAspectRatio.d.ts.map +0 -1
  151. package/dist/editor/components/NewComposition/NewCompAspectRatio.js.map +0 -1
  152. package/dist/editor/components/NewComposition/NewCompCode.d.ts.map +0 -1
  153. package/dist/editor/components/NewComposition/NewCompCode.js.map +0 -1
  154. package/dist/editor/components/NewComposition/NewCompDuration.d.ts.map +0 -1
  155. package/dist/editor/components/NewComposition/NewCompDuration.js.map +0 -1
  156. package/dist/editor/components/NewComposition/NewComposition.d.ts.map +0 -1
  157. package/dist/editor/components/NewComposition/NewComposition.js.map +0 -1
  158. package/dist/editor/components/NewComposition/RemInput.d.ts.map +0 -1
  159. package/dist/editor/components/NewComposition/RemInput.js.map +0 -1
  160. package/dist/editor/components/NewComposition/ToggleAspectRatio.d.ts.map +0 -1
  161. package/dist/editor/components/NewComposition/ToggleAspectRatio.js.map +0 -1
  162. package/dist/editor/components/NewComposition/ValidationMessage.d.ts.map +0 -1
  163. package/dist/editor/components/NewComposition/ValidationMessage.js.map +0 -1
  164. package/dist/editor/components/NewComposition/new-comp-layout.d.ts.map +0 -1
  165. package/dist/editor/components/NewComposition/new-comp-layout.js.map +0 -1
  166. package/dist/editor/components/NewComposition/render-aspect-ratio.d.ts.map +0 -1
  167. package/dist/editor/components/NewComposition/render-aspect-ratio.js.map +0 -1
  168. package/dist/editor/components/PlayPause.d.ts.map +0 -1
  169. package/dist/editor/components/PlayPause.js.map +0 -1
  170. package/dist/editor/components/PlaybackKeyboardShortcutsManager.d.ts.map +0 -1
  171. package/dist/editor/components/PlaybackKeyboardShortcutsManager.js.map +0 -1
  172. package/dist/editor/components/PlaybackRatePersistor.d.ts.map +0 -1
  173. package/dist/editor/components/PlaybackRatePersistor.js.map +0 -1
  174. package/dist/editor/components/PlaybackRateSelector.d.ts.map +0 -1
  175. package/dist/editor/components/PlaybackRateSelector.js.map +0 -1
  176. package/dist/editor/components/Preview.d.ts.map +0 -1
  177. package/dist/editor/components/Preview.js.map +0 -1
  178. package/dist/editor/components/PreviewToolbar.d.ts.map +0 -1
  179. package/dist/editor/components/PreviewToolbar.js.map +0 -1
  180. package/dist/editor/components/RichTimelineToggle.d.ts.map +0 -1
  181. package/dist/editor/components/RichTimelineToggle.js.map +0 -1
  182. package/dist/editor/components/SizeSelector.d.ts.map +0 -1
  183. package/dist/editor/components/SizeSelector.js.map +0 -1
  184. package/dist/editor/components/Splitter/SplitterContainer.d.ts.map +0 -1
  185. package/dist/editor/components/Splitter/SplitterContainer.js.map +0 -1
  186. package/dist/editor/components/Splitter/SplitterContext.d.ts.map +0 -1
  187. package/dist/editor/components/Splitter/SplitterContext.js.map +0 -1
  188. package/dist/editor/components/Splitter/SplitterElement.d.ts.map +0 -1
  189. package/dist/editor/components/Splitter/SplitterElement.js.map +0 -1
  190. package/dist/editor/components/Splitter/SplitterHandle.d.ts.map +0 -1
  191. package/dist/editor/components/Splitter/SplitterHandle.js.map +0 -1
  192. package/dist/editor/components/Thumbnail.d.ts.map +0 -1
  193. package/dist/editor/components/Thumbnail.js.map +0 -1
  194. package/dist/editor/components/TimeValue.d.ts.map +0 -1
  195. package/dist/editor/components/TimeValue.js.map +0 -1
  196. package/dist/editor/components/Timeline/LoopedIndicator.d.ts.map +0 -1
  197. package/dist/editor/components/Timeline/LoopedIndicator.js.map +0 -1
  198. package/dist/editor/components/Timeline/LoopedTimelineIndicators.d.ts.map +0 -1
  199. package/dist/editor/components/Timeline/LoopedTimelineIndicators.js.map +0 -1
  200. package/dist/editor/components/Timeline/MaxTimelineTracks.d.ts.map +0 -1
  201. package/dist/editor/components/Timeline/MaxTimelineTracks.js.map +0 -1
  202. package/dist/editor/components/Timeline/Timeline.d.ts.map +0 -1
  203. package/dist/editor/components/Timeline/Timeline.js.map +0 -1
  204. package/dist/editor/components/Timeline/TimelineCollapseToggle.d.ts.map +0 -1
  205. package/dist/editor/components/Timeline/TimelineCollapseToggle.js.map +0 -1
  206. package/dist/editor/components/Timeline/TimelineDragHandler.d.ts.map +0 -1
  207. package/dist/editor/components/Timeline/TimelineDragHandler.js.map +0 -1
  208. package/dist/editor/components/Timeline/TimelineInOutPointer.d.ts.map +0 -1
  209. package/dist/editor/components/Timeline/TimelineInOutPointer.js.map +0 -1
  210. package/dist/editor/components/Timeline/TimelineInOutPointerHandle.d.ts.map +0 -1
  211. package/dist/editor/components/Timeline/TimelineInOutPointerHandle.js.map +0 -1
  212. package/dist/editor/components/Timeline/TimelineList.d.ts.map +0 -1
  213. package/dist/editor/components/Timeline/TimelineList.js.map +0 -1
  214. package/dist/editor/components/Timeline/TimelineListItem.d.ts.map +0 -1
  215. package/dist/editor/components/Timeline/TimelineListItem.js.map +0 -1
  216. package/dist/editor/components/Timeline/TimelineSequence.d.ts.map +0 -1
  217. package/dist/editor/components/Timeline/TimelineSequence.js.map +0 -1
  218. package/dist/editor/components/Timeline/TimelineSequenceFrame.d.ts.map +0 -1
  219. package/dist/editor/components/Timeline/TimelineSequenceFrame.js.map +0 -1
  220. package/dist/editor/components/Timeline/TimelineSlider.d.ts.map +0 -1
  221. package/dist/editor/components/Timeline/TimelineSlider.js.map +0 -1
  222. package/dist/editor/components/Timeline/TimelineSliderHandle.d.ts.map +0 -1
  223. package/dist/editor/components/Timeline/TimelineSliderHandle.js.map +0 -1
  224. package/dist/editor/components/Timeline/TimelineTracks.d.ts.map +0 -1
  225. package/dist/editor/components/Timeline/TimelineTracks.js.map +0 -1
  226. package/dist/editor/components/Timeline/TimelineVideoInfo.d.ts.map +0 -1
  227. package/dist/editor/components/Timeline/TimelineVideoInfo.js.map +0 -1
  228. package/dist/editor/components/Timeline/is-collapsed.d.ts.map +0 -1
  229. package/dist/editor/components/Timeline/is-collapsed.js.map +0 -1
  230. package/dist/editor/components/Timeline/timeline-refs.d.ts.map +0 -1
  231. package/dist/editor/components/Timeline/timeline-refs.js.map +0 -1
  232. package/dist/editor/components/Timeline/timeline-state-reducer.d.ts.map +0 -1
  233. package/dist/editor/components/Timeline/timeline-state-reducer.js.map +0 -1
  234. package/dist/editor/components/TimelineInOutToggle.d.ts.map +0 -1
  235. package/dist/editor/components/TimelineInOutToggle.js.map +0 -1
  236. package/dist/editor/components/TopPanel.d.ts.map +0 -1
  237. package/dist/editor/components/TopPanel.js.map +0 -1
  238. package/dist/editor/components/UpdateCheck.d.ts.map +0 -1
  239. package/dist/editor/components/UpdateCheck.js.map +0 -1
  240. package/dist/editor/components/UpdateModal/UpdateModal.d.ts.map +0 -1
  241. package/dist/editor/components/UpdateModal/UpdateModal.js.map +0 -1
  242. package/dist/editor/components/layout.d.ts.map +0 -1
  243. package/dist/editor/components/layout.js.map +0 -1
  244. package/dist/editor/helpers/calculate-timeline.d.ts.map +0 -1
  245. package/dist/editor/helpers/calculate-timeline.js.map +0 -1
  246. package/dist/editor/helpers/checkerboard-background.d.ts.map +0 -1
  247. package/dist/editor/helpers/checkerboard-background.js.map +0 -1
  248. package/dist/editor/helpers/colors.d.ts.map +0 -1
  249. package/dist/editor/helpers/colors.js.map +0 -1
  250. package/dist/editor/helpers/copy-text.d.ts.map +0 -1
  251. package/dist/editor/helpers/copy-text.js.map +0 -1
  252. package/dist/editor/helpers/create-folder-tree.d.ts.map +0 -1
  253. package/dist/editor/helpers/create-folder-tree.js.map +0 -1
  254. package/dist/editor/helpers/get-left-of-timeline-slider.d.ts.map +0 -1
  255. package/dist/editor/helpers/get-left-of-timeline-slider.js.map +0 -1
  256. package/dist/editor/helpers/get-sequence-visible-range.d.ts.map +0 -1
  257. package/dist/editor/helpers/get-sequence-visible-range.js.map +0 -1
  258. package/dist/editor/helpers/get-timeline-nestedness.d.ts.map +0 -1
  259. package/dist/editor/helpers/get-timeline-nestedness.js.map +0 -1
  260. package/dist/editor/helpers/get-timeline-sequence-hash.d.ts.map +0 -1
  261. package/dist/editor/helpers/get-timeline-sequence-hash.js.map +0 -1
  262. package/dist/editor/helpers/get-timeline-sequence-layout.d.ts.map +0 -1
  263. package/dist/editor/helpers/get-timeline-sequence-layout.js.map +0 -1
  264. package/dist/editor/helpers/get-timeline-sequence-sort-key.d.ts.map +0 -1
  265. package/dist/editor/helpers/get-timeline-sequence-sort-key.js.map +0 -1
  266. package/dist/editor/helpers/is-composition-still.d.ts.map +0 -1
  267. package/dist/editor/helpers/is-composition-still.js.map +0 -1
  268. package/dist/editor/helpers/is-current-selected-still.d.ts.map +0 -1
  269. package/dist/editor/helpers/is-current-selected-still.js.map +0 -1
  270. package/dist/editor/helpers/noop.d.ts.map +0 -1
  271. package/dist/editor/helpers/noop.js.map +0 -1
  272. package/dist/editor/helpers/persist-open-folders.d.ts.map +0 -1
  273. package/dist/editor/helpers/persist-open-folders.js.map +0 -1
  274. package/dist/editor/helpers/timeline-layout.d.ts.map +0 -1
  275. package/dist/editor/helpers/timeline-layout.js.map +0 -1
  276. package/dist/editor/helpers/use-keybinding.d.ts.map +0 -1
  277. package/dist/editor/helpers/use-keybinding.js.map +0 -1
  278. package/dist/editor/helpers/validate-new-comp-data.d.ts.map +0 -1
  279. package/dist/editor/helpers/validate-new-comp-data.js.map +0 -1
  280. package/dist/editor/icons/Checkmark.d.ts.map +0 -1
  281. package/dist/editor/icons/Checkmark.js.map +0 -1
  282. package/dist/editor/icons/caret.d.ts.map +0 -1
  283. package/dist/editor/icons/caret.js.map +0 -1
  284. package/dist/editor/icons/film.d.ts.map +0 -1
  285. package/dist/editor/icons/film.js.map +0 -1
  286. package/dist/editor/icons/folder.d.ts.map +0 -1
  287. package/dist/editor/icons/folder.js.map +0 -1
  288. package/dist/editor/icons/keys.d.ts.map +0 -1
  289. package/dist/editor/icons/keys.js.map +0 -1
  290. package/dist/editor/icons/lock.d.ts.map +0 -1
  291. package/dist/editor/icons/lock.js.map +0 -1
  292. package/dist/editor/icons/media-volume.d.ts.map +0 -1
  293. package/dist/editor/icons/media-volume.js.map +0 -1
  294. package/dist/editor/icons/pause.d.ts.map +0 -1
  295. package/dist/editor/icons/pause.js.map +0 -1
  296. package/dist/editor/icons/play.d.ts.map +0 -1
  297. package/dist/editor/icons/play.js.map +0 -1
  298. package/dist/editor/icons/step-back.d.ts.map +0 -1
  299. package/dist/editor/icons/step-back.js.map +0 -1
  300. package/dist/editor/icons/step-forward.d.ts.map +0 -1
  301. package/dist/editor/icons/step-forward.js.map +0 -1
  302. package/dist/editor/icons/still.d.ts.map +0 -1
  303. package/dist/editor/icons/still.js.map +0 -1
  304. package/dist/editor/icons/timeline.d.ts.map +0 -1
  305. package/dist/editor/icons/timeline.js.map +0 -1
  306. package/dist/editor/icons/timelineInOutPointer.d.ts.map +0 -1
  307. package/dist/editor/icons/timelineInOutPointer.js.map +0 -1
  308. package/dist/editor/state/aspect-ratio-locked.d.ts.map +0 -1
  309. package/dist/editor/state/aspect-ratio-locked.js.map +0 -1
  310. package/dist/editor/state/checkerboard.d.ts.map +0 -1
  311. package/dist/editor/state/checkerboard.js.map +0 -1
  312. package/dist/editor/state/highest-z-index.d.ts.map +0 -1
  313. package/dist/editor/state/highest-z-index.js.map +0 -1
  314. package/dist/editor/state/input-dragger-click-lock.d.ts.map +0 -1
  315. package/dist/editor/state/input-dragger-click-lock.js.map +0 -1
  316. package/dist/editor/state/keybindings.d.ts.map +0 -1
  317. package/dist/editor/state/keybindings.js.map +0 -1
  318. package/dist/editor/state/loop.d.ts.map +0 -1
  319. package/dist/editor/state/loop.js.map +0 -1
  320. package/dist/editor/state/marks.d.ts.map +0 -1
  321. package/dist/editor/state/marks.js.map +0 -1
  322. package/dist/editor/state/modals.d.ts.map +0 -1
  323. package/dist/editor/state/modals.js.map +0 -1
  324. package/dist/editor/state/mute.d.ts.map +0 -1
  325. package/dist/editor/state/mute.js.map +0 -1
  326. package/dist/editor/state/playbackrate.d.ts.map +0 -1
  327. package/dist/editor/state/playbackrate.js.map +0 -1
  328. package/dist/editor/state/preview-size.d.ts.map +0 -1
  329. package/dist/editor/state/preview-size.js.map +0 -1
  330. package/dist/editor/state/render-frame.d.ts.map +0 -1
  331. package/dist/editor/state/render-frame.js.map +0 -1
  332. package/dist/editor/state/rich-timeline.d.ts.map +0 -1
  333. package/dist/editor/state/rich-timeline.js.map +0 -1
  334. package/dist/editor/state/timeline-ref.d.ts.map +0 -1
  335. package/dist/editor/state/timeline-ref.js.map +0 -1
  336. package/dist/editor/state/timeline.d.ts.map +0 -1
  337. package/dist/editor/state/timeline.js.map +0 -1
  338. package/dist/editor/state/z-index.d.ts.map +0 -1
  339. package/dist/editor/state/z-index.js.map +0 -1
  340. package/dist/get-cli-options.d.ts.map +0 -1
  341. package/dist/get-cli-options.js.map +0 -1
  342. package/dist/get-composition-id.d.ts.map +0 -1
  343. package/dist/get-composition-id.js.map +0 -1
  344. package/dist/get-config-file-name.d.ts.map +0 -1
  345. package/dist/get-config-file-name.js.map +0 -1
  346. package/dist/get-env.d.ts.map +0 -1
  347. package/dist/get-env.js.map +0 -1
  348. package/dist/get-filename.d.ts.map +0 -1
  349. package/dist/get-filename.js.map +0 -1
  350. package/dist/get-input-props.d.ts.map +0 -1
  351. package/dist/get-input-props.js.map +0 -1
  352. package/dist/handle-common-errors.d.ts.map +0 -1
  353. package/dist/handle-common-errors.js.map +0 -1
  354. package/dist/image-formats.d.ts.map +0 -1
  355. package/dist/image-formats.js.map +0 -1
  356. package/dist/index.d.ts.map +0 -1
  357. package/dist/index.js.map +0 -1
  358. package/dist/initialize-render-cli.d.ts.map +0 -1
  359. package/dist/initialize-render-cli.js.map +0 -1
  360. package/dist/is-javascript.d.ts.map +0 -1
  361. package/dist/is-javascript.js.map +0 -1
  362. package/dist/lambda-command.d.ts.map +0 -1
  363. package/dist/lambda-command.js.map +0 -1
  364. package/dist/load-config.d.ts.map +0 -1
  365. package/dist/load-config.js.map +0 -1
  366. package/dist/log.d.ts.map +0 -1
  367. package/dist/log.js.map +0 -1
  368. package/dist/make-progress-bar.d.ts.map +0 -1
  369. package/dist/make-progress-bar.js.map +0 -1
  370. package/dist/parse-command-line.d.ts.map +0 -1
  371. package/dist/parse-command-line.js.map +0 -1
  372. package/dist/preview.d.ts.map +0 -1
  373. package/dist/preview.js.map +0 -1
  374. package/dist/previewEntry.d.ts.map +0 -1
  375. package/dist/previewEntry.js.map +0 -1
  376. package/dist/print-error.d.ts.map +0 -1
  377. package/dist/print-error.js.map +0 -1
  378. package/dist/print-help.d.ts.map +0 -1
  379. package/dist/print-help.js.map +0 -1
  380. package/dist/progress-bar.d.ts.map +0 -1
  381. package/dist/progress-bar.js.map +0 -1
  382. package/dist/render.d.ts.map +0 -1
  383. package/dist/render.js.map +0 -1
  384. package/dist/resolve-from.d.ts.map +0 -1
  385. package/dist/resolve-from.js.map +0 -1
  386. package/dist/setup-cache.d.ts.map +0 -1
  387. package/dist/setup-cache.js.map +0 -1
  388. package/dist/step.d.ts.map +0 -1
  389. package/dist/step.js.map +0 -1
  390. package/dist/still.d.ts.map +0 -1
  391. package/dist/still.js.map +0 -1
  392. package/dist/upgrade.d.ts.map +0 -1
  393. package/dist/upgrade.js.map +0 -1
  394. package/dist/user-passed-output-location.d.ts.map +0 -1
  395. package/dist/user-passed-output-location.js.map +0 -1
  396. package/dist/validate-ffmpeg-version.d.ts.map +0 -1
  397. package/dist/validate-ffmpeg-version.js.map +0 -1
  398. package/dist/versions.d.ts.map +0 -1
  399. package/dist/versions.js.map +0 -1
  400. package/dist/warn-about-ffmpeg-version.d.ts.map +0 -1
  401. package/dist/warn-about-ffmpeg-version.js.map +0 -1
@@ -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
  };
@@ -152,9 +152,11 @@ 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 parallelism = remotion_1.Internals.getConcurrency();
156
+ renderer_1.RenderInternals.validateConcurrency(parallelism, 'concurrency');
155
157
  return {
156
158
  puppeteerTimeout: remotion_1.Internals.getCurrentPuppeteerTimeout(),
157
- parallelism: remotion_1.Internals.getConcurrency(),
159
+ parallelism,
158
160
  frameRange,
159
161
  shouldOutputImageSequence,
160
162
  codec,
@@ -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
+ }>;
@@ -0,0 +1,67 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ErrorMessage = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const player_1 = require("@remotion/player");
6
+ const react_1 = require("react");
7
+ const colors_1 = require("../../../editor/helpers/colors");
8
+ const carets_1 = require("./carets");
9
+ const fontSize = 24;
10
+ const lineHeight = 1.5;
11
+ const maxLines = 2;
12
+ const buttonSize = 32;
13
+ const maskImage = 'linear-gradient(to bottom, white 60%, transparent)';
14
+ const container = {
15
+ position: 'relative',
16
+ marginBottom: 15,
17
+ };
18
+ const messageContainer = {
19
+ fontSize,
20
+ lineHeight,
21
+ overflow: 'hidden',
22
+ };
23
+ const moreLine = {
24
+ width: '100%',
25
+ display: 'flex',
26
+ justifyContent: 'center',
27
+ position: 'absolute',
28
+ border: `1px solid ${colors_1.INPUT_BORDER_COLOR_HOVERED}`,
29
+ height: 0,
30
+ marginTop: 4,
31
+ };
32
+ const moreButton = {
33
+ height: buttonSize,
34
+ width: buttonSize,
35
+ borderRadius: buttonSize / 2,
36
+ backgroundColor: colors_1.INPUT_BACKGROUND,
37
+ border: `1px solid ${colors_1.INPUT_BORDER_COLOR_UNHOVERED}`,
38
+ marginTop: -buttonSize / 2,
39
+ display: 'flex',
40
+ justifyContent: 'center',
41
+ alignItems: 'center',
42
+ cursor: 'pointer',
43
+ color: 'white',
44
+ };
45
+ const ErrorMessage = ({ message }) => {
46
+ const [expanded, setExpanded] = (0, react_1.useState)(false);
47
+ const ref = (0, react_1.useRef)(null);
48
+ const size = player_1.PlayerInternals.useElementSize(ref, {
49
+ shouldApplyCssTransforms: false,
50
+ triggerOnWindowResize: true,
51
+ });
52
+ const errorLines = size ? size.height / (lineHeight * fontSize) : null;
53
+ const style = (0, react_1.useMemo)(() => {
54
+ const isExpanded = expanded || (errorLines !== null && errorLines <= maxLines);
55
+ return {
56
+ ...messageContainer,
57
+ maxHeight: isExpanded ? undefined : fontSize * lineHeight * maxLines,
58
+ maskImage: isExpanded ? undefined : maskImage,
59
+ WebkitMaskImage: isExpanded ? undefined : maskImage,
60
+ };
61
+ }, [errorLines, expanded]);
62
+ const toggle = (0, react_1.useCallback)(() => {
63
+ setExpanded((e) => !e);
64
+ }, []);
65
+ return ((0, jsx_runtime_1.jsxs)("div", { style: container, children: [(0, jsx_runtime_1.jsx)("div", { style: style, children: (0, jsx_runtime_1.jsx)("div", { ref: ref, children: message }) }), errorLines !== null && errorLines > maxLines ? ((0, jsx_runtime_1.jsx)("div", { style: moreLine, children: (0, jsx_runtime_1.jsx)("button", { type: "button", onClick: toggle, style: moreButton, children: (0, jsx_runtime_1.jsx)(carets_1.CaretDown, { invert: expanded }) }) })) : null] }));
66
+ };
67
+ exports.ErrorMessage = ErrorMessage;
@@ -4,6 +4,7 @@ exports.ErrorTitle = void 0;
4
4
  const jsx_runtime_1 = require("react/jsx-runtime");
5
5
  const react_overlay_1 = require("../react-overlay");
6
6
  const DismissButton_1 = require("./DismissButton");
7
+ const ErrorMessage_1 = require("./ErrorMessage");
7
8
  const Symbolicating_1 = require("./Symbolicating");
8
9
  const title = {
9
10
  marginBottom: 8,
@@ -14,17 +15,12 @@ const title = {
14
15
  const left = {
15
16
  flex: 1,
16
17
  paddingRight: 14,
17
- lineHeight: 1.5,
18
- whiteSpace: 'pre',
19
- fontSize: '1.5em',
20
18
  fontWeight: 'bold',
21
- overflowX: 'auto',
19
+ maxWidth: '100%',
22
20
  };
23
21
  const errName = {
24
- fontSize: '0.8em',
25
- background: 'linear-gradient(90deg,#4290f5,#42e9f5)',
26
- WebkitBackgroundClip: 'text',
27
- WebkitTextFillColor: 'transparent',
22
+ fontSize: 18,
23
+ color: '#4290f5',
28
24
  display: 'inline-block',
29
25
  };
30
26
  const row = {
@@ -36,6 +32,6 @@ const spacer = {
36
32
  width: 5,
37
33
  };
38
34
  const ErrorTitle = ({ name, message, symbolicating }) => {
39
- return ((0, jsx_runtime_1.jsxs)("div", { style: title, children: [(0, jsx_runtime_1.jsxs)("div", { style: left, children: [(0, jsx_runtime_1.jsx)("span", { style: errName, children: name }), (0, jsx_runtime_1.jsx)("br", {}), (0, jsx_runtime_1.jsxs)("div", { style: row, children: [symbolicating ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(Symbolicating_1.Symbolicating, {}), (0, jsx_runtime_1.jsx)("div", { style: spacer })] })) : null, (0, jsx_runtime_1.jsx)("div", { children: message })] })] }), (0, react_overlay_1.didUnmountReactApp)() ? null : (0, jsx_runtime_1.jsx)(DismissButton_1.DismissButton, {})] }));
35
+ return ((0, jsx_runtime_1.jsxs)("div", { style: title, children: [(0, jsx_runtime_1.jsxs)("div", { style: left, children: [(0, jsx_runtime_1.jsx)("span", { style: errName, children: name }), (0, jsx_runtime_1.jsx)("br", {}), (0, jsx_runtime_1.jsxs)("div", { style: row, children: [symbolicating ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(Symbolicating_1.Symbolicating, {}), (0, jsx_runtime_1.jsx)("div", { style: spacer })] })) : null, (0, jsx_runtime_1.jsx)(ErrorMessage_1.ErrorMessage, { message: message })] })] }), (0, react_overlay_1.didUnmountReactApp)() ? null : (0, jsx_runtime_1.jsx)(DismissButton_1.DismissButton, {})] }));
40
36
  };
41
37
  exports.ErrorTitle = ErrorTitle;
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import type { THelpLink } from './get-help-link';
3
+ export declare const HelpLink: React.FC<{
4
+ canHaveKeyboardShortcuts: boolean;
5
+ link: THelpLink;
6
+ }>;
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.HelpLink = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const use_keybinding_1 = require("../../../editor/helpers/use-keybinding");
7
+ const Button_1 = require("./Button");
8
+ const ShortcutHint_1 = require("./ShortcutHint");
9
+ const HelpLink = ({ canHaveKeyboardShortcuts, link }) => {
10
+ const openLink = (0, react_1.useCallback)(() => {
11
+ window.open(link.url, '_blank');
12
+ }, [link]);
13
+ const { registerKeybinding } = (0, use_keybinding_1.useKeybinding)();
14
+ (0, react_1.useEffect)(() => {
15
+ if (!canHaveKeyboardShortcuts) {
16
+ return;
17
+ }
18
+ const onEditor = () => {
19
+ openLink();
20
+ };
21
+ const { unregister } = registerKeybinding({
22
+ event: 'keydown',
23
+ key: 'h',
24
+ callback: onEditor,
25
+ commandCtrlKey: true,
26
+ });
27
+ return () => unregister();
28
+ }, [canHaveKeyboardShortcuts, openLink, registerKeybinding]);
29
+ return ((0, jsx_runtime_1.jsxs)(Button_1.Button, { onClick: openLink, children: ["Help: ", '"', link.title, '"', canHaveKeyboardShortcuts ? ((0, jsx_runtime_1.jsx)(ShortcutHint_1.ShortcutHint, { keyToPress: "h", cmdOrCtrl: true })) : null] }));
30
+ };
31
+ exports.HelpLink = HelpLink;
@@ -2,4 +2,5 @@ import React from 'react';
2
2
  import type { SymbolicatedStackFrame } from '../react-overlay/utils/stack-frame';
3
3
  export declare const OpenInEditor: React.FC<{
4
4
  stack: SymbolicatedStackFrame;
5
+ canHaveKeyboardShortcuts: boolean;
5
6
  }>;