@remotion/cli 3.3.83 → 3.3.86

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 (282) hide show
  1. package/dist/editor/components/Splitter/SplitterElement.js +1 -0
  2. package/dist/editor/components/TimeValue.js +3 -4
  3. package/dist/editor/components/Timeline/TimelineListItem.js +9 -1
  4. package/package.json +6 -6
  5. package/dist/cloudrun-command.d.ts +0 -1
  6. package/dist/cloudrun-command.js +0 -27
  7. package/dist/codemods/update-default-props.d.ts +0 -5
  8. package/dist/codemods/update-default-props.js +0 -143
  9. package/dist/color-math.d.ts +0 -1
  10. package/dist/color-math.js +0 -12
  11. package/dist/config/jpeg-quality.d.ts +0 -2
  12. package/dist/config/jpeg-quality.js +0 -17
  13. package/dist/convert-entry-point-to-serve-url.d.ts +0 -1
  14. package/dist/convert-entry-point-to-serve-url.js +0 -15
  15. package/dist/editor/components/Checkbox.d.ts +0 -6
  16. package/dist/editor/components/Checkbox.js +0 -42
  17. package/dist/editor/components/CheckerboardProvider.d.ts +0 -4
  18. package/dist/editor/components/CheckerboardProvider.js +0 -24
  19. package/dist/editor/components/CollapsableOptions.d.ts +0 -6
  20. package/dist/editor/components/CollapsableOptions.js +0 -35
  21. package/dist/editor/components/CurrentCompositionSideEffects.d.ts +0 -3
  22. package/dist/editor/components/CurrentCompositionSideEffects.js +0 -51
  23. package/dist/editor/components/InlineAction.d.ts +0 -5
  24. package/dist/editor/components/InlineAction.js +0 -35
  25. package/dist/editor/components/MediaVolumeProvider.d.ts +0 -4
  26. package/dist/editor/components/MediaVolumeProvider.js +0 -25
  27. package/dist/editor/components/Modals.d.ts +0 -2
  28. package/dist/editor/components/Modals.js +0 -23
  29. package/dist/editor/components/ModalsProvider.d.ts +0 -4
  30. package/dist/editor/components/ModalsProvider.js +0 -17
  31. package/dist/editor/components/NewComposition/RemInputTypeColor.d.ts +0 -8
  32. package/dist/editor/components/NewComposition/RemInputTypeColor.js +0 -53
  33. package/dist/editor/components/NewComposition/RemTextarea.d.ts +0 -7
  34. package/dist/editor/components/NewComposition/RemTextarea.js +0 -92
  35. package/dist/editor/components/PlayerEmitterContext.d.ts +0 -4
  36. package/dist/editor/components/PlayerEmitterContext.js +0 -11
  37. package/dist/editor/components/RenderButton.d.ts +0 -6
  38. package/dist/editor/components/RenderButton.js +0 -73
  39. package/dist/editor/components/RenderModal/CliCopyButton.d.ts +0 -4
  40. package/dist/editor/components/RenderModal/CliCopyButton.js +0 -22
  41. package/dist/editor/components/RenderModal/CrfSetting.d.ts +0 -16
  42. package/dist/editor/components/RenderModal/CrfSetting.js +0 -43
  43. package/dist/editor/components/RenderModal/EnforceAudioTrackSetting.d.ts +0 -8
  44. package/dist/editor/components/RenderModal/EnforceAudioTrackSetting.js +0 -16
  45. package/dist/editor/components/RenderModal/EnvInput.d.ts +0 -11
  46. package/dist/editor/components/RenderModal/EnvInput.js +0 -74
  47. package/dist/editor/components/RenderModal/FrameRangeSetting.d.ts +0 -8
  48. package/dist/editor/components/RenderModal/FrameRangeSetting.js +0 -42
  49. package/dist/editor/components/RenderModal/GuiRenderStatus.d.ts +0 -5
  50. package/dist/editor/components/RenderModal/GuiRenderStatus.js +0 -78
  51. package/dist/editor/components/RenderModal/InfoBubble.d.ts +0 -5
  52. package/dist/editor/components/RenderModal/InfoBubble.js +0 -115
  53. package/dist/editor/components/RenderModal/InfoTooltip.d.ts +0 -5
  54. package/dist/editor/components/RenderModal/InfoTooltip.js +0 -40
  55. package/dist/editor/components/RenderModal/InlineEyeIcon.d.ts +0 -5
  56. package/dist/editor/components/RenderModal/InlineEyeIcon.js +0 -14
  57. package/dist/editor/components/RenderModal/InlineRemoveButton.d.ts +0 -4
  58. package/dist/editor/components/RenderModal/InlineRemoveButton.js +0 -12
  59. package/dist/editor/components/RenderModal/JpegQualitySetting.d.ts +0 -5
  60. package/dist/editor/components/RenderModal/JpegQualitySetting.js +0 -12
  61. package/dist/editor/components/RenderModal/MutedSetting.d.ts +0 -8
  62. package/dist/editor/components/RenderModal/MutedSetting.js +0 -16
  63. package/dist/editor/components/RenderModal/NumberOfLoopsSetting.d.ts +0 -5
  64. package/dist/editor/components/RenderModal/NumberOfLoopsSetting.js +0 -26
  65. package/dist/editor/components/RenderModal/NumberSetting.d.ts +0 -12
  66. package/dist/editor/components/RenderModal/NumberSetting.js +0 -29
  67. package/dist/editor/components/RenderModal/OptionExplainer.d.ts +0 -5
  68. package/dist/editor/components/RenderModal/OptionExplainer.js +0 -45
  69. package/dist/editor/components/RenderModal/RenderModal.d.ts +0 -34
  70. package/dist/editor/components/RenderModal/RenderModal.js +0 -567
  71. package/dist/editor/components/RenderModal/RenderModalAdvanced.d.ts +0 -26
  72. package/dist/editor/components/RenderModal/RenderModalAdvanced.js +0 -61
  73. package/dist/editor/components/RenderModal/RenderModalAudio.d.ts +0 -17
  74. package/dist/editor/components/RenderModal/RenderModalAudio.js +0 -46
  75. package/dist/editor/components/RenderModal/RenderModalBasic.d.ts +0 -23
  76. package/dist/editor/components/RenderModal/RenderModalBasic.js +0 -79
  77. package/dist/editor/components/RenderModal/RenderModalData.d.ts +0 -9
  78. package/dist/editor/components/RenderModal/RenderModalData.js +0 -107
  79. package/dist/editor/components/RenderModal/RenderModalEnvironmentVariables.d.ts +0 -5
  80. package/dist/editor/components/RenderModal/RenderModalEnvironmentVariables.js +0 -55
  81. package/dist/editor/components/RenderModal/RenderModalGif.d.ts +0 -9
  82. package/dist/editor/components/RenderModal/RenderModalGif.js +0 -19
  83. package/dist/editor/components/RenderModal/RenderModalHr.d.ts +0 -2
  84. package/dist/editor/components/RenderModal/RenderModalHr.js +0 -18
  85. package/dist/editor/components/RenderModal/RenderModalInput.d.ts +0 -10
  86. package/dist/editor/components/RenderModal/RenderModalInput.js +0 -13
  87. package/dist/editor/components/RenderModal/RenderModalJSONInputPropsEditor.d.ts +0 -11
  88. package/dist/editor/components/RenderModal/RenderModalJSONInputPropsEditor.js +0 -118
  89. package/dist/editor/components/RenderModal/RenderModalPicture.d.ts +0 -28
  90. package/dist/editor/components/RenderModal/RenderModalPicture.js +0 -56
  91. package/dist/editor/components/RenderModal/RenderStatusModal.d.ts +0 -4
  92. package/dist/editor/components/RenderModal/RenderStatusModal.js +0 -72
  93. package/dist/editor/components/RenderModal/ScaleSetting.d.ts +0 -5
  94. package/dist/editor/components/RenderModal/ScaleSetting.js +0 -17
  95. package/dist/editor/components/RenderModal/SchemaEditor/SchemaEditor.d.ts +0 -12
  96. package/dist/editor/components/RenderModal/SchemaEditor/SchemaEditor.js +0 -72
  97. package/dist/editor/components/RenderModal/SchemaEditor/SchemaEmptyStateGraphic.d.ts +0 -2
  98. package/dist/editor/components/RenderModal/SchemaEditor/SchemaEmptyStateGraphic.js +0 -15
  99. package/dist/editor/components/RenderModal/SchemaEditor/SchemaLabel.d.ts +0 -15
  100. package/dist/editor/components/RenderModal/SchemaEditor/SchemaLabel.js +0 -40
  101. package/dist/editor/components/RenderModal/SchemaEditor/SchemaResetButton.d.ts +0 -4
  102. package/dist/editor/components/RenderModal/SchemaEditor/SchemaResetButton.js +0 -12
  103. package/dist/editor/components/RenderModal/SchemaEditor/SchemaSaveButton.d.ts +0 -4
  104. package/dist/editor/components/RenderModal/SchemaEditor/SchemaSaveButton.js +0 -12
  105. package/dist/editor/components/RenderModal/SchemaEditor/ZodArrayEditor.d.ts +0 -14
  106. package/dist/editor/components/RenderModal/SchemaEditor/ZodArrayEditor.js +0 -79
  107. package/dist/editor/components/RenderModal/SchemaEditor/ZodArrayItemEditor.d.ts +0 -13
  108. package/dist/editor/components/RenderModal/SchemaEditor/ZodArrayItemEditor.js +0 -28
  109. package/dist/editor/components/RenderModal/SchemaEditor/ZodBooleanEditor.d.ts +0 -12
  110. package/dist/editor/components/RenderModal/SchemaEditor/ZodBooleanEditor.js +0 -27
  111. package/dist/editor/components/RenderModal/SchemaEditor/ZodColorEditor.d.ts +0 -14
  112. package/dist/editor/components/RenderModal/SchemaEditor/ZodColorEditor.js +0 -108
  113. package/dist/editor/components/RenderModal/SchemaEditor/ZodDateEditor.d.ts +0 -14
  114. package/dist/editor/components/RenderModal/SchemaEditor/ZodDateEditor.js +0 -76
  115. package/dist/editor/components/RenderModal/SchemaEditor/ZodEffectEditor.d.ts +0 -14
  116. package/dist/editor/components/RenderModal/SchemaEditor/ZodEffectEditor.js +0 -51
  117. package/dist/editor/components/RenderModal/SchemaEditor/ZodEnumEditor.d.ts +0 -14
  118. package/dist/editor/components/RenderModal/SchemaEditor/ZodEnumEditor.js +0 -68
  119. package/dist/editor/components/RenderModal/SchemaEditor/ZodErrorMessages.d.ts +0 -5
  120. package/dist/editor/components/RenderModal/SchemaEditor/ZodErrorMessages.js +0 -23
  121. package/dist/editor/components/RenderModal/SchemaEditor/ZodNonEditableValue.d.ts +0 -8
  122. package/dist/editor/components/RenderModal/SchemaEditor/ZodNonEditableValue.js +0 -27
  123. package/dist/editor/components/RenderModal/SchemaEditor/ZodNumberEditor.d.ts +0 -14
  124. package/dist/editor/components/RenderModal/SchemaEditor/ZodNumberEditor.js +0 -89
  125. package/dist/editor/components/RenderModal/SchemaEditor/ZodObjectEditor.d.ts +0 -14
  126. package/dist/editor/components/RenderModal/SchemaEditor/ZodObjectEditor.js +0 -60
  127. package/dist/editor/components/RenderModal/SchemaEditor/ZodOrNullishEditor.d.ts +0 -15
  128. package/dist/editor/components/RenderModal/SchemaEditor/ZodOrNullishEditor.js +0 -45
  129. package/dist/editor/components/RenderModal/SchemaEditor/ZodStringEditor.d.ts +0 -14
  130. package/dist/editor/components/RenderModal/SchemaEditor/ZodStringEditor.js +0 -43
  131. package/dist/editor/components/RenderModal/SchemaEditor/ZodSwitch.d.ts +0 -14
  132. package/dist/editor/components/RenderModal/SchemaEditor/ZodSwitch.js +0 -69
  133. package/dist/editor/components/RenderModal/SchemaEditor/ZodUnionEditor.d.ts +0 -14
  134. package/dist/editor/components/RenderModal/SchemaEditor/ZodUnionEditor.js +0 -45
  135. package/dist/editor/components/RenderModal/SchemaEditor/create-zod-values.d.ts +0 -2
  136. package/dist/editor/components/RenderModal/SchemaEditor/create-zod-values.js +0 -153
  137. package/dist/editor/components/RenderModal/SchemaEditor/date-serialization.d.ts +0 -2
  138. package/dist/editor/components/RenderModal/SchemaEditor/date-serialization.js +0 -21
  139. package/dist/editor/components/RenderModal/SchemaEditor/get-schema-label.d.ts +0 -2
  140. package/dist/editor/components/RenderModal/SchemaEditor/get-schema-label.js +0 -15
  141. package/dist/editor/components/RenderModal/SchemaEditor/zod-types.d.ts +0 -1
  142. package/dist/editor/components/RenderModal/SchemaEditor/zod-types.js +0 -2
  143. package/dist/editor/components/RenderModal/human-readable-audio-codecs.d.ts +0 -2
  144. package/dist/editor/components/RenderModal/human-readable-audio-codecs.js +0 -18
  145. package/dist/editor/components/RenderModal/human-readable-codec.d.ts +0 -2
  146. package/dist/editor/components/RenderModal/human-readable-codec.js +0 -36
  147. package/dist/editor/components/RenderModal/layout.d.ts +0 -7
  148. package/dist/editor/components/RenderModal/layout.js +0 -46
  149. package/dist/editor/components/RenderModal/out-name-checker.d.ts +0 -15
  150. package/dist/editor/components/RenderModal/out-name-checker.js +0 -80
  151. package/dist/editor/components/RenderQueue/CircularProgress.d.ts +0 -5
  152. package/dist/editor/components/RenderQueue/CircularProgress.js +0 -18
  153. package/dist/editor/components/RenderQueue/RenderQueueError.d.ts +0 -5
  154. package/dist/editor/components/RenderQueue/RenderQueueError.js +0 -26
  155. package/dist/editor/components/RenderQueue/RenderQueueItem.d.ts +0 -5
  156. package/dist/editor/components/RenderQueue/RenderQueueItem.js +0 -40
  157. package/dist/editor/components/RenderQueue/RenderQueueItemCancelButton.d.ts +0 -5
  158. package/dist/editor/components/RenderQueue/RenderQueueItemCancelButton.js +0 -22
  159. package/dist/editor/components/RenderQueue/RenderQueueItemStatus.d.ts +0 -5
  160. package/dist/editor/components/RenderQueue/RenderQueueItemStatus.js +0 -43
  161. package/dist/editor/components/RenderQueue/RenderQueueOpenInFolder.d.ts +0 -5
  162. package/dist/editor/components/RenderQueue/RenderQueueOpenInFolder.js +0 -22
  163. package/dist/editor/components/RenderQueue/RenderQueueOutputName.d.ts +0 -5
  164. package/dist/editor/components/RenderQueue/RenderQueueOutputName.js +0 -26
  165. package/dist/editor/components/RenderQueue/RenderQueueProgressMessage.d.ts +0 -5
  166. package/dist/editor/components/RenderQueue/RenderQueueProgressMessage.js +0 -26
  167. package/dist/editor/components/RenderQueue/RenderQueueRemoveItem.d.ts +0 -5
  168. package/dist/editor/components/RenderQueue/RenderQueueRemoveItem.js +0 -33
  169. package/dist/editor/components/RenderQueue/RenderQueueRepeat.d.ts +0 -5
  170. package/dist/editor/components/RenderQueue/RenderQueueRepeat.js +0 -22
  171. package/dist/editor/components/RenderQueue/SuccessIcon.d.ts +0 -2
  172. package/dist/editor/components/RenderQueue/SuccessIcon.js +0 -14
  173. package/dist/editor/components/RenderQueue/actions.d.ts +0 -60
  174. package/dist/editor/components/RenderQueue/actions.js +0 -120
  175. package/dist/editor/components/RenderQueue/context.d.ts +0 -18
  176. package/dist/editor/components/RenderQueue/context.js +0 -49
  177. package/dist/editor/components/RenderQueue/index.d.ts +0 -2
  178. package/dist/editor/components/RenderQueue/index.js +0 -19
  179. package/dist/editor/components/RenderQueue/item-style.d.ts +0 -2
  180. package/dist/editor/components/RenderQueue/item-style.js +0 -21
  181. package/dist/editor/components/RenderToolbarIcon.d.ts +0 -2
  182. package/dist/editor/components/RenderToolbarIcon.js +0 -86
  183. package/dist/editor/components/RendersTab.d.ts +0 -6
  184. package/dist/editor/components/RendersTab.js +0 -43
  185. package/dist/editor/components/RightPanel.d.ts +0 -8
  186. package/dist/editor/components/RightPanel.js +0 -76
  187. package/dist/editor/components/SegmentedControl.d.ts +0 -16
  188. package/dist/editor/components/SegmentedControl.js +0 -63
  189. package/dist/editor/components/SetTimelineInOutProvider.d.ts +0 -4
  190. package/dist/editor/components/SetTimelineInOutProvider.js +0 -19
  191. package/dist/editor/components/SidebarCollapserControls.d.ts +0 -2
  192. package/dist/editor/components/SidebarCollapserControls.js +0 -122
  193. package/dist/editor/components/Tabs/index.d.ts +0 -12
  194. package/dist/editor/components/Tabs/index.js +0 -58
  195. package/dist/editor/components/Tabs/vertical.d.ts +0 -12
  196. package/dist/editor/components/Tabs/vertical.js +0 -57
  197. package/dist/editor/components/ZoomGesturesProvider.d.ts +0 -4
  198. package/dist/editor/components/ZoomGesturesProvider.js +0 -24
  199. package/dist/editor/helpers/client-id.d.ts +0 -17
  200. package/dist/editor/helpers/client-id.js +0 -46
  201. package/dist/editor/helpers/convert-env-variables.d.ts +0 -2
  202. package/dist/editor/helpers/convert-env-variables.js +0 -20
  203. package/dist/editor/helpers/prores-labels.d.ts +0 -2
  204. package/dist/editor/helpers/prores-labels.js +0 -25
  205. package/dist/editor/helpers/render-modal-sections.d.ts +0 -10
  206. package/dist/editor/helpers/render-modal-sections.js +0 -32
  207. package/dist/editor/helpers/use-breakpoint.d.ts +0 -1
  208. package/dist/editor/helpers/use-breakpoint.js +0 -17
  209. package/dist/editor/helpers/use-file-existence.d.ts +0 -1
  210. package/dist/editor/helpers/use-file-existence.js +0 -66
  211. package/dist/editor/icons/RenderStillIcon.d.ts +0 -3
  212. package/dist/editor/icons/RenderStillIcon.js +0 -8
  213. package/dist/editor/icons/audio.d.ts +0 -2
  214. package/dist/editor/icons/audio.js +0 -6
  215. package/dist/editor/icons/data.d.ts +0 -2
  216. package/dist/editor/icons/data.js +0 -8
  217. package/dist/editor/icons/file.d.ts +0 -2
  218. package/dist/editor/icons/file.js +0 -6
  219. package/dist/editor/icons/frame.d.ts +0 -2
  220. package/dist/editor/icons/frame.js +0 -6
  221. package/dist/editor/icons/gear.d.ts +0 -2
  222. package/dist/editor/icons/gear.js +0 -6
  223. package/dist/editor/icons/gif.d.ts +0 -2
  224. package/dist/editor/icons/gif.js +0 -6
  225. package/dist/editor/icons/render.d.ts +0 -8
  226. package/dist/editor/icons/render.js +0 -12
  227. package/dist/editor/icons/video.d.ts +0 -5
  228. package/dist/editor/icons/video.js +0 -8
  229. package/dist/ffmpeg.d.ts +0 -2
  230. package/dist/ffmpeg.js +0 -21
  231. package/dist/file-watcher.d.ts +0 -9
  232. package/dist/file-watcher.js +0 -35
  233. package/dist/get-default-out-name.d.ts +0 -5
  234. package/dist/get-default-out-name.js +0 -10
  235. package/dist/preview-server/api-routes.d.ts +0 -4
  236. package/dist/preview-server/api-routes.js +0 -21
  237. package/dist/preview-server/api-types.d.ts +0 -29
  238. package/dist/preview-server/api-types.js +0 -2
  239. package/dist/preview-server/file-existence-watchers.d.ts +0 -13
  240. package/dist/preview-server/file-existence-watchers.js +0 -62
  241. package/dist/preview-server/handler.d.ts +0 -9
  242. package/dist/preview-server/handler.js +0 -34
  243. package/dist/preview-server/parse-body.d.ts +0 -2
  244. package/dist/preview-server/parse-body.js +0 -16
  245. package/dist/preview-server/render-queue/get-default-video-contexts.d.ts +0 -10
  246. package/dist/preview-server/render-queue/get-default-video-contexts.js +0 -13
  247. package/dist/preview-server/render-queue/job.d.ts +0 -138
  248. package/dist/preview-server/render-queue/job.js +0 -2
  249. package/dist/preview-server/render-queue/make-retry-payload.d.ts +0 -3
  250. package/dist/preview-server/render-queue/make-retry-payload.js +0 -89
  251. package/dist/preview-server/render-queue/open-directory-in-finder.d.ts +0 -1
  252. package/dist/preview-server/render-queue/open-directory-in-finder.js +0 -43
  253. package/dist/preview-server/render-queue/process-still.d.ts +0 -8
  254. package/dist/preview-server/render-queue/process-still.js +0 -46
  255. package/dist/preview-server/render-queue/process-video.d.ts +0 -8
  256. package/dist/preview-server/render-queue/process-video.js +0 -63
  257. package/dist/preview-server/render-queue/queue.d.ts +0 -21
  258. package/dist/preview-server/render-queue/queue.js +0 -208
  259. package/dist/preview-server/routes/add-render.d.ts +0 -3
  260. package/dist/preview-server/routes/add-render.js +0 -76
  261. package/dist/preview-server/routes/can-update-default-props.d.ts +0 -4
  262. package/dist/preview-server/routes/can-update-default-props.js +0 -39
  263. package/dist/preview-server/routes/cancel-render.d.ts +0 -3
  264. package/dist/preview-server/routes/cancel-render.js +0 -9
  265. package/dist/preview-server/routes/open-in-file-explorer.d.ts +0 -3
  266. package/dist/preview-server/routes/open-in-file-explorer.js +0 -8
  267. package/dist/preview-server/routes/remove-render.d.ts +0 -3
  268. package/dist/preview-server/routes/remove-render.js +0 -9
  269. package/dist/preview-server/routes/subscribe-to-file-existence.d.ts +0 -3
  270. package/dist/preview-server/routes/subscribe-to-file-existence.js +0 -13
  271. package/dist/preview-server/routes/unsubscribe-from-file-existence.d.ts +0 -3
  272. package/dist/preview-server/routes/unsubscribe-from-file-existence.js +0 -13
  273. package/dist/preview-server/routes/update-default-props.d.ts +0 -3
  274. package/dist/preview-server/routes/update-default-props.js +0 -24
  275. package/dist/progress-types.d.ts +0 -32
  276. package/dist/progress-types.js +0 -17
  277. package/dist/render-flows/render.d.ts +0 -47
  278. package/dist/render-flows/render.js +0 -290
  279. package/dist/render-flows/still.d.ts +0 -29
  280. package/dist/render-flows/still.js +0 -168
  281. package/dist/required-chromium-options.d.ts +0 -3
  282. package/dist/required-chromium-options.js +0 -2
@@ -1,567 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.RenderModal = void 0;
4
- const jsx_runtime_1 = require("react/jsx-runtime");
5
- const client_1 = require("@remotion/renderer/client");
6
- const react_1 = require("react");
7
- const remotion_1 = require("remotion");
8
- const Button_1 = require("../../../preview-server/error-overlay/remotion-overlay/Button");
9
- const ShortcutHint_1 = require("../../../preview-server/error-overlay/remotion-overlay/ShortcutHint");
10
- const convert_env_variables_1 = require("../../helpers/convert-env-variables");
11
- const render_modal_sections_1 = require("../../helpers/render-modal-sections");
12
- const use_keybinding_1 = require("../../helpers/use-keybinding");
13
- const audio_1 = require("../../icons/audio");
14
- const data_1 = require("../../icons/data");
15
- const file_1 = require("../../icons/file");
16
- const frame_1 = require("../../icons/frame");
17
- const gear_1 = require("../../icons/gear");
18
- const gif_1 = require("../../icons/gif");
19
- const modals_1 = require("../../state/modals");
20
- const sidebar_1 = require("../../state/sidebar");
21
- const is_menu_item_1 = require("../Menu/is-menu-item");
22
- const ModalContainer_1 = require("../ModalContainer");
23
- const ModalHeader_1 = require("../ModalHeader");
24
- const actions_1 = require("../RenderQueue/actions");
25
- const RightPanel_1 = require("../RightPanel");
26
- const SegmentedControl_1 = require("../SegmentedControl");
27
- const vertical_1 = require("../Tabs/vertical");
28
- const CrfSetting_1 = require("./CrfSetting");
29
- const out_name_checker_1 = require("./out-name-checker");
30
- const RenderModalAdvanced_1 = require("./RenderModalAdvanced");
31
- const RenderModalAudio_1 = require("./RenderModalAudio");
32
- const RenderModalBasic_1 = require("./RenderModalBasic");
33
- const RenderModalData_1 = require("./RenderModalData");
34
- const RenderModalGif_1 = require("./RenderModalGif");
35
- const RenderModalPicture_1 = require("./RenderModalPicture");
36
- const initialState = { type: 'idle' };
37
- const reducer = (state, action) => {
38
- if (action.type === 'start') {
39
- return {
40
- type: 'load',
41
- };
42
- }
43
- if (action.type === 'fail') {
44
- return {
45
- type: 'error',
46
- };
47
- }
48
- if (action.type === 'succeed') {
49
- return {
50
- type: 'success',
51
- };
52
- }
53
- return state;
54
- };
55
- const container = {
56
- display: 'flex',
57
- flexDirection: 'row',
58
- alignItems: 'center',
59
- padding: '12px 16px',
60
- width: '100%',
61
- borderBottom: '1px solid black',
62
- };
63
- const rightPanel = {
64
- height: 600,
65
- width: 650,
66
- display: 'flex',
67
- };
68
- const horizontalLayout = {
69
- display: 'flex',
70
- flexDirection: 'row',
71
- };
72
- const leftSidebar = {
73
- padding: 12,
74
- };
75
- const horizontalTab = {
76
- width: 250,
77
- display: 'flex',
78
- flexDirection: 'row',
79
- alignItems: 'center',
80
- textAlign: 'left',
81
- fontSize: 16,
82
- fontWeight: 'bold',
83
- paddingLeft: 15,
84
- paddingTop: 12,
85
- paddingBottom: 12,
86
- };
87
- const iconContainer = {
88
- width: 20,
89
- height: 20,
90
- marginRight: 15,
91
- display: 'inline-flex',
92
- justifyContent: 'center',
93
- alignItems: 'center',
94
- };
95
- const icon = {
96
- color: 'currentcolor',
97
- height: 20,
98
- };
99
- const buttonStyle = {
100
- backgroundColor: 'var(--blue)',
101
- color: 'white',
102
- };
103
- const flexer = {
104
- flex: 1,
105
- };
106
- // TODO: Copy edited props from Props editor to Render modal
107
- const RenderModal = ({ compositionId, initialFrame, initialVideoImageFormat, initialStillImageFormat, initialJpegQuality, initialScale, initialVerbose, initialOutName, initialRenderType, initialVideoCodecForAudioTab, initialVideoCodecForVideoTab, initialConcurrency, maxConcurrency, minConcurrency, initialMuted, initialEnforceAudioTrack, initialProResProfile, initialPixelFormat, initialVideoBitrate, initialAudioBitrate, initialEveryNthFrame, initialNumberOfGifLoops, initialDelayRenderTimeout, initialAudioCodec, initialEnvVariables, initialDisableWebSecurity, initialGl, initialHeadless, initialIgnoreCertificateErrors, }) => {
108
- const { setSelectedModal } = (0, react_1.useContext)(modals_1.ModalsContext);
109
- const onQuit = (0, react_1.useCallback)(() => {
110
- setSelectedModal(null);
111
- }, [setSelectedModal]);
112
- const isMounted = (0, react_1.useRef)(true);
113
- const [state, dispatch] = (0, react_1.useReducer)(reducer, initialState);
114
- const [unclampedFrame, setFrame] = (0, react_1.useState)(() => initialFrame);
115
- const [stillImageFormat, setStillImageFormat] = (0, react_1.useState)(() => initialStillImageFormat);
116
- const [videoImageFormat, setVideoImageFormat] = (0, react_1.useState)(() => initialVideoImageFormat);
117
- const [concurrency, setConcurrency] = (0, react_1.useState)(() => initialConcurrency);
118
- const [videoCodecForVideoTab, setVideoCodecForVideoTab] = (0, react_1.useState)(() => initialVideoCodecForVideoTab);
119
- const [userSelectedAudioCodec, setUserSelectedAudioCodec] = (0, react_1.useState)(() => initialAudioCodec);
120
- const [envVariables, setEnvVariables] = (0, react_1.useState)(() => (0, convert_env_variables_1.envVariablesObjectToArray)(initialEnvVariables).filter(([key]) => key !== 'NODE_ENV'));
121
- const [videoCodecForAudioTab, setVideoCodecForAudioTab] = (0, react_1.useState)(() => initialVideoCodecForAudioTab);
122
- const [mutedState, setMuted] = (0, react_1.useState)(() => initialMuted);
123
- const [enforceAudioTrackState, setEnforceAudioTrackState] = (0, react_1.useState)(() => initialEnforceAudioTrack);
124
- const [renderMode, setRenderModeState] = (0, react_1.useState)(initialRenderType);
125
- const [jpegQuality, setJpegQuality] = (0, react_1.useState)(() => initialJpegQuality);
126
- const [scale, setScale] = (0, react_1.useState)(() => initialScale);
127
- const [verbose, setVerboseLogging] = (0, react_1.useState)(() => initialVerbose);
128
- const [disallowParallelEncoding, setDisallowParallelEncoding] = (0, react_1.useState)(false);
129
- const [disableWebSecurity, setDisableWebSecurity] = (0, react_1.useState)(() => initialDisableWebSecurity);
130
- const [headless, setHeadless] = (0, react_1.useState)(() => initialHeadless);
131
- const [ignoreCertificateErrors, setIgnoreCertificateErrors] = (0, react_1.useState)(() => initialIgnoreCertificateErrors);
132
- const [openGlOption, setOpenGlOption] = (0, react_1.useState)(() => initialGl !== null && initialGl !== void 0 ? initialGl : 'default');
133
- const chromiumOptions = (0, react_1.useMemo)(() => {
134
- return {
135
- headless,
136
- disableWebSecurity,
137
- ignoreCertificateErrors,
138
- gl: openGlOption === 'default' ? null : openGlOption,
139
- };
140
- }, [headless, disableWebSecurity, ignoreCertificateErrors, openGlOption]);
141
- const [outName, setOutName] = (0, react_1.useState)(() => initialOutName);
142
- const [endFrameOrNull, setEndFrame] = (0, react_1.useState)(() => null);
143
- const [startFrameOrNull, setStartFrame] = (0, react_1.useState)(() => null);
144
- const [proResProfileSetting, setProResProfile] = (0, react_1.useState)(() => initialProResProfile);
145
- const [pixelFormat, setPixelFormat] = (0, react_1.useState)(() => initialPixelFormat);
146
- const [qualityControlType, setQualityControl] = (0, react_1.useState)(() => initialVideoBitrate === null ? 'crf' : 'bitrate');
147
- const [shouldHaveCustomTargetAudioBitrate, setShouldHaveCustomTargetAudioBitrate,] = (0, react_1.useState)(() => initialAudioBitrate !== null);
148
- const [customTargetAudioBitrate, setCustomTargetAudioBitrateValue] = (0, react_1.useState)(() => initialAudioBitrate !== null && initialAudioBitrate !== void 0 ? initialAudioBitrate : '320K');
149
- const [customTargetVideoBitrate, setCustomTargetVideoBitrateValue] = (0, react_1.useState)(() => initialVideoBitrate !== null && initialVideoBitrate !== void 0 ? initialVideoBitrate : '1M');
150
- const [limitNumberOfGifLoops, setLimitNumberOfGifLoops] = (0, react_1.useState)(() => initialNumberOfGifLoops !== null);
151
- const [numberOfGifLoopsSetting, setNumberOfGifLoopsSetting] = (0, react_1.useState)(() => initialNumberOfGifLoops !== null && initialNumberOfGifLoops !== void 0 ? initialNumberOfGifLoops : 1);
152
- const [delayRenderTimeout, setDelayRenderTimeout] = (0, react_1.useState)(() => initialDelayRenderTimeout);
153
- const codec = (0, react_1.useMemo)(() => {
154
- if (renderMode === 'audio') {
155
- return videoCodecForAudioTab;
156
- }
157
- return videoCodecForVideoTab;
158
- }, [videoCodecForAudioTab, renderMode, videoCodecForVideoTab]);
159
- const numberOfGifLoops = (0, react_1.useMemo)(() => {
160
- if (codec === 'gif' && limitNumberOfGifLoops) {
161
- return numberOfGifLoopsSetting;
162
- }
163
- return null;
164
- }, [codec, limitNumberOfGifLoops, numberOfGifLoopsSetting]);
165
- const audioBitrate = (0, react_1.useMemo)(() => {
166
- if (shouldHaveCustomTargetAudioBitrate) {
167
- return customTargetAudioBitrate;
168
- }
169
- return null;
170
- }, [customTargetAudioBitrate, shouldHaveCustomTargetAudioBitrate]);
171
- const videoBitrate = (0, react_1.useMemo)(() => {
172
- if (qualityControlType === 'bitrate') {
173
- return customTargetVideoBitrate;
174
- }
175
- return null;
176
- }, [customTargetVideoBitrate, qualityControlType]);
177
- const { crf, maxCrf, minCrf, setCrf, shouldDisplayOption: shouldDisplayCrfOption, } = (0, CrfSetting_1.useCrfState)(codec);
178
- const dispatchIfMounted = (0, react_1.useCallback)((payload) => {
179
- if (isMounted.current === false)
180
- return;
181
- dispatch(payload);
182
- }, []);
183
- const muted = (0, react_1.useMemo)(() => {
184
- if (renderMode === 'video') {
185
- return mutedState;
186
- }
187
- return false;
188
- }, [mutedState, renderMode]);
189
- const enforceAudioTrack = (0, react_1.useMemo)(() => {
190
- if (renderMode === 'video') {
191
- return enforceAudioTrackState;
192
- }
193
- return false;
194
- }, [enforceAudioTrackState, renderMode]);
195
- const proResProfile = (0, react_1.useMemo)(() => {
196
- if (renderMode === 'video' && codec === 'prores') {
197
- return proResProfileSetting;
198
- }
199
- return null;
200
- }, [codec, proResProfileSetting, renderMode]);
201
- const { compositions } = (0, react_1.useContext)(remotion_1.Internals.CompositionManager);
202
- const currentComposition = (0, react_1.useMemo)(() => {
203
- for (const composition of compositions) {
204
- if (composition.id === compositionId) {
205
- return composition;
206
- }
207
- }
208
- return null;
209
- }, [compositionId, compositions]);
210
- if (currentComposition === null) {
211
- throw new Error('This composition does not exist');
212
- }
213
- const [inputProps, setInputProps] = (0, react_1.useState)(() => currentComposition.defaultProps);
214
- const endFrame = (0, react_1.useMemo)(() => {
215
- if (endFrameOrNull === null) {
216
- return currentComposition.durationInFrames - 1;
217
- }
218
- return Math.max(0, Math.min(currentComposition.durationInFrames - 1, endFrameOrNull));
219
- }, [currentComposition.durationInFrames, endFrameOrNull]);
220
- const startFrame = (0, react_1.useMemo)(() => {
221
- if (startFrameOrNull === null) {
222
- return 0;
223
- }
224
- return Math.max(0, Math.min(endFrame - 1, startFrameOrNull));
225
- }, [endFrame, startFrameOrNull]);
226
- const frame = (0, react_1.useMemo)(() => {
227
- const parsed = Math.floor(unclampedFrame);
228
- return Math.max(0, Math.min(currentComposition.durationInFrames - 1, parsed));
229
- }, [currentComposition.durationInFrames, unclampedFrame]);
230
- const getStringBeforeSuffix = (0, react_1.useCallback)((fileName) => {
231
- const dotPos = fileName.lastIndexOf('.');
232
- const bitBeforeDot = fileName.substring(0, dotPos);
233
- return bitBeforeDot;
234
- }, []);
235
- const deriveFinalAudioCodec = (0, react_1.useCallback)((passedVideoCodec, passedAudioCodec) => {
236
- if (passedAudioCodec !== null &&
237
- client_1.BrowserSafeApis.supportedAudioCodecs[passedVideoCodec].includes(passedAudioCodec)) {
238
- return passedAudioCodec;
239
- }
240
- return client_1.BrowserSafeApis.defaultAudioCodecs[passedVideoCodec]
241
- .compressed;
242
- }, []);
243
- const setDefaultOutName = (0, react_1.useCallback)((options) => {
244
- if (options.type === 'still') {
245
- setOutName((prev) => {
246
- const newFileName = getStringBeforeSuffix(prev) + '.' + options.imageFormat;
247
- return newFileName;
248
- });
249
- }
250
- else {
251
- setOutName((prev) => {
252
- const codecSuffix = client_1.BrowserSafeApis.getFileExtensionFromCodec(options.codec, deriveFinalAudioCodec(options.codec, options.audioCodec));
253
- const newFileName = getStringBeforeSuffix(prev) + '.' + codecSuffix;
254
- return newFileName;
255
- });
256
- }
257
- }, [deriveFinalAudioCodec, getStringBeforeSuffix]);
258
- const setAudioCodec = (0, react_1.useCallback)((newAudioCodec) => {
259
- setUserSelectedAudioCodec(newAudioCodec);
260
- setDefaultOutName({
261
- type: 'render',
262
- codec: videoCodecForVideoTab,
263
- audioCodec: newAudioCodec,
264
- });
265
- }, [setDefaultOutName, videoCodecForVideoTab]);
266
- const setCodec = (0, react_1.useCallback)((newCodec) => {
267
- if (renderMode === 'audio') {
268
- setVideoCodecForAudioTab(newCodec);
269
- }
270
- else {
271
- setVideoCodecForVideoTab(newCodec);
272
- }
273
- setDefaultOutName({
274
- type: 'render',
275
- codec: newCodec,
276
- audioCodec: deriveFinalAudioCodec(newCodec, userSelectedAudioCodec),
277
- });
278
- }, [
279
- userSelectedAudioCodec,
280
- deriveFinalAudioCodec,
281
- renderMode,
282
- setDefaultOutName,
283
- ]);
284
- const setStillFormat = (0, react_1.useCallback)((format) => {
285
- setStillImageFormat(format);
286
- setDefaultOutName({ type: 'still', imageFormat: format });
287
- }, [setDefaultOutName]);
288
- const { setSidebarCollapsedState } = (0, react_1.useContext)(sidebar_1.SidebarContext);
289
- const onClickStill = (0, react_1.useCallback)(() => {
290
- var _a;
291
- setSidebarCollapsedState({ left: null, right: 'expanded' });
292
- (0, RightPanel_1.persistSelectedPanel)('renders');
293
- (_a = RightPanel_1.rightSidebarTabs.current) === null || _a === void 0 ? void 0 : _a.selectRendersPanel();
294
- dispatchIfMounted({ type: 'start' });
295
- (0, actions_1.addStillRenderJob)({
296
- compositionId,
297
- outName,
298
- imageFormat: stillImageFormat,
299
- jpegQuality: stillImageFormat === 'jpeg' ? jpegQuality : null,
300
- frame,
301
- scale,
302
- verbose,
303
- chromiumOptions,
304
- delayRenderTimeout,
305
- envVariables: (0, convert_env_variables_1.envVariablesArrayToObject)(envVariables),
306
- inputProps,
307
- })
308
- .then(() => {
309
- dispatchIfMounted({ type: 'succeed' });
310
- setSelectedModal(null);
311
- })
312
- .catch(() => {
313
- dispatchIfMounted({ type: 'fail' });
314
- });
315
- }, [
316
- setSidebarCollapsedState,
317
- dispatchIfMounted,
318
- compositionId,
319
- outName,
320
- stillImageFormat,
321
- jpegQuality,
322
- frame,
323
- scale,
324
- verbose,
325
- chromiumOptions,
326
- delayRenderTimeout,
327
- envVariables,
328
- inputProps,
329
- setSelectedModal,
330
- ]);
331
- const [everyNthFrameSetting, setEveryNthFrameSetting] = (0, react_1.useState)(() => initialEveryNthFrame);
332
- const everyNthFrame = (0, react_1.useMemo)(() => {
333
- if (codec === 'gif') {
334
- return everyNthFrameSetting;
335
- }
336
- return 1;
337
- }, [codec, everyNthFrameSetting]);
338
- const audioCodec = deriveFinalAudioCodec(codec, userSelectedAudioCodec);
339
- const onClickVideo = (0, react_1.useCallback)(() => {
340
- var _a;
341
- setSidebarCollapsedState({ left: null, right: 'expanded' });
342
- (0, RightPanel_1.persistSelectedPanel)('renders');
343
- (_a = RightPanel_1.rightSidebarTabs.current) === null || _a === void 0 ? void 0 : _a.selectRendersPanel();
344
- dispatchIfMounted({ type: 'start' });
345
- (0, actions_1.addVideoRenderJob)({
346
- compositionId,
347
- outName,
348
- imageFormat: videoImageFormat,
349
- jpegQuality: stillImageFormat === 'jpeg' ? jpegQuality : null,
350
- scale,
351
- verbose,
352
- codec,
353
- concurrency,
354
- crf: qualityControlType === 'crf' ? crf : null,
355
- endFrame,
356
- startFrame,
357
- muted,
358
- enforceAudioTrack,
359
- proResProfile,
360
- pixelFormat,
361
- audioBitrate,
362
- videoBitrate,
363
- everyNthFrame,
364
- numberOfGifLoops,
365
- delayRenderTimeout,
366
- audioCodec,
367
- disallowParallelEncoding,
368
- chromiumOptions,
369
- envVariables: (0, convert_env_variables_1.envVariablesArrayToObject)(envVariables),
370
- inputProps,
371
- })
372
- .then(() => {
373
- dispatchIfMounted({ type: 'succeed' });
374
- setSelectedModal(null);
375
- })
376
- .catch(() => {
377
- dispatchIfMounted({ type: 'fail' });
378
- });
379
- }, [
380
- setSidebarCollapsedState,
381
- dispatchIfMounted,
382
- compositionId,
383
- outName,
384
- videoImageFormat,
385
- stillImageFormat,
386
- jpegQuality,
387
- scale,
388
- verbose,
389
- codec,
390
- concurrency,
391
- qualityControlType,
392
- crf,
393
- endFrame,
394
- startFrame,
395
- muted,
396
- enforceAudioTrack,
397
- proResProfile,
398
- pixelFormat,
399
- audioBitrate,
400
- videoBitrate,
401
- everyNthFrame,
402
- numberOfGifLoops,
403
- delayRenderTimeout,
404
- audioCodec,
405
- disallowParallelEncoding,
406
- chromiumOptions,
407
- envVariables,
408
- inputProps,
409
- setSelectedModal,
410
- ]);
411
- (0, react_1.useEffect)(() => {
412
- return () => {
413
- isMounted.current = false;
414
- };
415
- }, []);
416
- const imageFormatOptions = (0, react_1.useMemo)(() => {
417
- if (renderMode === 'still') {
418
- return [
419
- {
420
- label: 'PNG',
421
- onClick: () => setStillFormat('png'),
422
- key: 'png',
423
- selected: stillImageFormat === 'png',
424
- },
425
- {
426
- label: 'JPEG',
427
- onClick: () => setStillFormat('jpeg'),
428
- key: 'jpeg',
429
- selected: stillImageFormat === 'jpeg',
430
- },
431
- {
432
- label: 'PDF',
433
- onClick: () => setStillFormat('pdf'),
434
- key: 'pdf',
435
- selected: stillImageFormat === 'pdf',
436
- },
437
- {
438
- label: 'WebP',
439
- onClick: () => setStillFormat('webp'),
440
- key: 'webp',
441
- selected: stillImageFormat === 'webp',
442
- },
443
- ];
444
- }
445
- return [
446
- {
447
- label: 'PNG',
448
- onClick: () => setVideoImageFormat('png'),
449
- key: 'png',
450
- selected: videoImageFormat === 'png',
451
- },
452
- {
453
- label: 'JPEG',
454
- onClick: () => setVideoImageFormat('jpeg'),
455
- key: 'jpeg',
456
- selected: videoImageFormat === 'jpeg',
457
- },
458
- ];
459
- }, [stillImageFormat, renderMode, setStillFormat, videoImageFormat]);
460
- const setRenderMode = (0, react_1.useCallback)((newRenderMode) => {
461
- setRenderModeState(newRenderMode);
462
- if (newRenderMode === 'audio') {
463
- setDefaultOutName({
464
- type: 'render',
465
- codec: videoCodecForAudioTab,
466
- audioCodec: deriveFinalAudioCodec(videoCodecForAudioTab, userSelectedAudioCodec),
467
- });
468
- }
469
- if (newRenderMode === 'video') {
470
- setDefaultOutName({
471
- type: 'render',
472
- codec: videoCodecForVideoTab,
473
- audioCodec: deriveFinalAudioCodec(videoCodecForVideoTab, userSelectedAudioCodec),
474
- });
475
- }
476
- if (newRenderMode === 'still') {
477
- setDefaultOutName({ type: 'still', imageFormat: stillImageFormat });
478
- }
479
- }, [
480
- videoCodecForAudioTab,
481
- userSelectedAudioCodec,
482
- deriveFinalAudioCodec,
483
- setDefaultOutName,
484
- stillImageFormat,
485
- videoCodecForVideoTab,
486
- ]);
487
- const renderTabOptions = (0, react_1.useMemo)(() => {
488
- if ((currentComposition === null || currentComposition === void 0 ? void 0 : currentComposition.durationInFrames) < 2) {
489
- return [
490
- {
491
- label: 'Still',
492
- onClick: () => {
493
- setRenderMode('still');
494
- },
495
- key: 'still',
496
- selected: renderMode === 'still',
497
- },
498
- ];
499
- }
500
- return [
501
- {
502
- label: 'Still',
503
- onClick: () => {
504
- setRenderMode('still');
505
- },
506
- key: 'still',
507
- selected: renderMode === 'still',
508
- },
509
- {
510
- label: 'Video',
511
- onClick: () => {
512
- setRenderMode('video');
513
- },
514
- key: 'video',
515
- selected: renderMode === 'video',
516
- },
517
- {
518
- label: 'Audio',
519
- onClick: () => {
520
- setRenderMode('audio');
521
- },
522
- key: 'audio',
523
- selected: renderMode === 'audio',
524
- },
525
- ];
526
- }, [currentComposition === null || currentComposition === void 0 ? void 0 : currentComposition.durationInFrames, renderMode, setRenderMode]);
527
- const outnameValidation = (0, out_name_checker_1.validateOutnameGui)({
528
- outName,
529
- codec,
530
- audioCodec,
531
- renderMode,
532
- stillImageFormat,
533
- });
534
- const { tab, setTab, shownTabs } = (0, render_modal_sections_1.useRenderModalSections)(renderMode, codec);
535
- const { registerKeybinding } = (0, use_keybinding_1.useKeybinding)();
536
- const renderDisabled = state.type === 'load' || !outnameValidation.valid;
537
- const trigger = (0, react_1.useCallback)(() => {
538
- if (renderDisabled) {
539
- return;
540
- }
541
- if (renderMode === 'still') {
542
- onClickStill();
543
- }
544
- else {
545
- onClickVideo();
546
- }
547
- }, [onClickStill, onClickVideo, renderDisabled, renderMode]);
548
- (0, react_1.useEffect)(() => {
549
- registerKeybinding({
550
- callback() {
551
- trigger();
552
- },
553
- commandCtrlKey: true,
554
- key: 'Enter',
555
- event: 'keydown',
556
- preventDefault: true,
557
- triggerIfInputFieldFocused: false,
558
- });
559
- }, [registerKeybinding, trigger]);
560
- return ((0, jsx_runtime_1.jsxs)(ModalContainer_1.ModalContainer, { onOutsideClick: onQuit, onEscape: onQuit, children: [(0, jsx_runtime_1.jsx)(ModalHeader_1.NewCompHeader, { title: `Render ${compositionId}` }), (0, jsx_runtime_1.jsxs)("div", { style: container, children: [(0, jsx_runtime_1.jsx)(SegmentedControl_1.SegmentedControl, { items: renderTabOptions, needsWrapping: false }), (0, jsx_runtime_1.jsx)("div", { style: flexer }), (0, jsx_runtime_1.jsxs)(Button_1.Button, { autoFocus: true, onClick: trigger, disabled: renderDisabled, style: {
561
- ...buttonStyle,
562
- backgroundColor: outnameValidation.valid
563
- ? 'var(--blue)'
564
- : 'var(--blue-disabled)',
565
- }, children: [state.type === 'idle' ? `Render ${renderMode}` : 'Rendering...', (0, jsx_runtime_1.jsx)(ShortcutHint_1.ShortcutHint, { keyToPress: "\u21B5", cmdOrCtrl: true })] })] }), (0, jsx_runtime_1.jsxs)("div", { style: horizontalLayout, children: [(0, jsx_runtime_1.jsxs)("div", { style: leftSidebar, children: [shownTabs.includes('general') ? ((0, jsx_runtime_1.jsxs)(vertical_1.VerticalTab, { style: horizontalTab, selected: tab === 'general', onClick: () => setTab('general'), children: [(0, jsx_runtime_1.jsx)("div", { style: iconContainer, children: (0, jsx_runtime_1.jsx)(file_1.FileIcon, { style: icon }) }), "General"] })) : null, shownTabs.includes('data') ? ((0, jsx_runtime_1.jsxs)(vertical_1.VerticalTab, { style: horizontalTab, selected: tab === 'data', onClick: () => setTab('data'), children: [(0, jsx_runtime_1.jsx)("div", { style: iconContainer, children: (0, jsx_runtime_1.jsx)(data_1.DataIcon, { style: icon }) }), "Input Props"] })) : null, shownTabs.includes('picture') ? ((0, jsx_runtime_1.jsxs)(vertical_1.VerticalTab, { style: horizontalTab, selected: tab === 'picture', onClick: () => setTab('picture'), children: [(0, jsx_runtime_1.jsx)("div", { style: iconContainer, children: (0, jsx_runtime_1.jsx)(frame_1.PicIcon, { style: icon }) }), "Picture"] })) : null, shownTabs.includes('audio') ? ((0, jsx_runtime_1.jsxs)(vertical_1.VerticalTab, { style: horizontalTab, selected: tab === 'audio', onClick: () => setTab('audio'), children: [(0, jsx_runtime_1.jsx)("div", { style: iconContainer, children: (0, jsx_runtime_1.jsx)(audio_1.AudioIcon, { style: icon }) }), "Audio"] })) : null, shownTabs.includes('gif') ? ((0, jsx_runtime_1.jsxs)(vertical_1.VerticalTab, { style: horizontalTab, selected: tab === 'gif', onClick: () => setTab('gif'), children: [(0, jsx_runtime_1.jsx)("div", { style: iconContainer, children: (0, jsx_runtime_1.jsx)(gif_1.GifIcon, { style: icon }) }), "GIF"] })) : null, shownTabs.includes('advanced') ? ((0, jsx_runtime_1.jsxs)(vertical_1.VerticalTab, { style: horizontalTab, selected: tab === 'advanced', onClick: () => setTab('advanced'), children: [(0, jsx_runtime_1.jsx)("div", { style: iconContainer, children: (0, jsx_runtime_1.jsx)(gear_1.GearIcon, { style: icon }) }), "Other"] })) : null] }), (0, jsx_runtime_1.jsx)("div", { style: rightPanel, className: is_menu_item_1.VERTICAL_SCROLLBAR_CLASSNAME, children: tab === 'general' ? ((0, jsx_runtime_1.jsx)(RenderModalBasic_1.RenderModalBasic, { codec: codec, currentComposition: currentComposition, frame: frame, imageFormatOptions: imageFormatOptions, outName: outName, proResProfile: proResProfile, renderMode: renderMode, setVideoCodec: setCodec, setFrame: setFrame, setOutName: setOutName, setProResProfile: setProResProfile, endFrame: endFrame, setEndFrame: setEndFrame, setStartFrame: setStartFrame, startFrame: startFrame, validationMessage: outnameValidation.valid ? null : outnameValidation.error.message })) : tab === 'picture' ? ((0, jsx_runtime_1.jsx)(RenderModalPicture_1.RenderModalPicture, { renderMode: renderMode, scale: scale, setScale: setScale, pixelFormat: pixelFormat, setPixelFormat: setPixelFormat, imageFormatOptions: imageFormatOptions, crf: crf, setCrf: setCrf, customTargetVideoBitrate: customTargetVideoBitrate, maxCrf: maxCrf, minCrf: minCrf, jpegQuality: jpegQuality, qualityControlType: qualityControlType, setJpegQuality: setJpegQuality, setCustomTargetVideoBitrateValue: setCustomTargetVideoBitrateValue, setQualityControl: setQualityControl, shouldDisplayCrfOption: shouldDisplayCrfOption, videoImageFormat: videoImageFormat, stillImageFormat: stillImageFormat })) : tab === 'audio' ? ((0, jsx_runtime_1.jsx)(RenderModalAudio_1.RenderModalAudio, { muted: muted, renderMode: renderMode, setMuted: setMuted, codec: codec, audioCodec: audioCodec, setAudioCodec: setAudioCodec, enforceAudioTrack: enforceAudioTrack, setEnforceAudioTrackState: setEnforceAudioTrackState, customTargetAudioBitrate: customTargetAudioBitrate, setCustomTargetAudioBitrateValue: setCustomTargetAudioBitrateValue, setShouldHaveCustomTargetAudioBitrate: setShouldHaveCustomTargetAudioBitrate, shouldHaveCustomTargetAudioBitrate: shouldHaveCustomTargetAudioBitrate })) : tab === 'gif' ? ((0, jsx_runtime_1.jsx)(RenderModalGif_1.RenderModalGif, { everyNthFrame: everyNthFrame, limitNumberOfGifLoops: limitNumberOfGifLoops, numberOfGifLoopsSetting: numberOfGifLoopsSetting, setEveryNthFrameSetting: setEveryNthFrameSetting, setLimitNumberOfGifLoops: setLimitNumberOfGifLoops, setNumberOfGifLoopsSetting: setNumberOfGifLoopsSetting })) : tab === 'data' ? ((0, jsx_runtime_1.jsx)(RenderModalData_1.RenderModalData, { inputProps: inputProps, setInputProps: setInputProps, composition: currentComposition, compact: false, mayShowSaveButton: false })) : ((0, jsx_runtime_1.jsx)(RenderModalAdvanced_1.RenderModalAdvanced, { concurrency: concurrency, maxConcurrency: maxConcurrency, minConcurrency: minConcurrency, renderMode: renderMode, setConcurrency: setConcurrency, setVerboseLogging: setVerboseLogging, verbose: verbose, delayRenderTimeout: delayRenderTimeout, setDelayRenderTimeout: setDelayRenderTimeout, disallowParallelEncoding: disallowParallelEncoding, setDisallowParallelEncoding: setDisallowParallelEncoding, setDisableWebSecurity: setDisableWebSecurity, setIgnoreCertificateErrors: setIgnoreCertificateErrors, setHeadless: setHeadless, headless: headless, ignoreCertificateErrors: ignoreCertificateErrors, disableWebSecurity: disableWebSecurity, openGlOption: openGlOption, setOpenGlOption: setOpenGlOption, setEnvVariables: setEnvVariables, envVariables: envVariables })) })] })] }));
566
- };
567
- exports.RenderModal = RenderModal;
@@ -1,26 +0,0 @@
1
- import React from 'react';
2
- import type { UiOpenGlOptions } from '../../../required-chromium-options';
3
- export declare type RenderType = 'still' | 'video' | 'audio';
4
- export declare const RenderModalAdvanced: React.FC<{
5
- renderMode: RenderType;
6
- minConcurrency: number;
7
- maxConcurrency: number;
8
- setConcurrency: React.Dispatch<React.SetStateAction<number>>;
9
- concurrency: number;
10
- setVerboseLogging: React.Dispatch<React.SetStateAction<boolean>>;
11
- verbose: boolean;
12
- delayRenderTimeout: number;
13
- setDelayRenderTimeout: React.Dispatch<React.SetStateAction<number>>;
14
- disallowParallelEncoding: boolean;
15
- setDisallowParallelEncoding: React.Dispatch<React.SetStateAction<boolean>>;
16
- setDisableWebSecurity: React.Dispatch<React.SetStateAction<boolean>>;
17
- setIgnoreCertificateErrors: React.Dispatch<React.SetStateAction<boolean>>;
18
- setHeadless: React.Dispatch<React.SetStateAction<boolean>>;
19
- headless: boolean;
20
- ignoreCertificateErrors: boolean;
21
- disableWebSecurity: boolean;
22
- openGlOption: UiOpenGlOptions;
23
- setOpenGlOption: React.Dispatch<React.SetStateAction<UiOpenGlOptions>>;
24
- envVariables: [string, string][];
25
- setEnvVariables: React.Dispatch<React.SetStateAction<[string, string][]>>;
26
- }>;
@@ -1,61 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.RenderModalAdvanced = void 0;
4
- const jsx_runtime_1 = require("react/jsx-runtime");
5
- const react_1 = require("react");
6
- const Checkmark_1 = require("../../icons/Checkmark");
7
- const Checkbox_1 = require("../Checkbox");
8
- const is_menu_item_1 = require("../Menu/is-menu-item");
9
- const ComboBox_1 = require("../NewComposition/ComboBox");
10
- const layout_1 = require("./layout");
11
- const NumberSetting_1 = require("./NumberSetting");
12
- const RenderModalEnvironmentVariables_1 = require("./RenderModalEnvironmentVariables");
13
- const RenderModalHr_1 = require("./RenderModalHr");
14
- const container = {
15
- flex: 1,
16
- overflowY: 'auto',
17
- };
18
- const RenderModalAdvanced = ({ renderMode, maxConcurrency, minConcurrency, setConcurrency, concurrency, setVerboseLogging, verbose, delayRenderTimeout, setDelayRenderTimeout, disallowParallelEncoding, setDisallowParallelEncoding, setDisableWebSecurity, setIgnoreCertificateErrors, setHeadless, headless, ignoreCertificateErrors, disableWebSecurity, openGlOption, setOpenGlOption, setEnvVariables, envVariables, }) => {
19
- const extendedOpenGlOptions = (0, react_1.useMemo)(() => {
20
- return ['angle', 'egl', 'swangle', 'swiftshader', 'default'];
21
- }, []);
22
- const onVerboseLoggingChanged = (0, react_1.useCallback)((e) => {
23
- setVerboseLogging(e.target.checked);
24
- }, [setVerboseLogging]);
25
- const onDisallowParallelEncodingChanged = (0, react_1.useCallback)((e) => {
26
- setDisallowParallelEncoding(e.target.checked);
27
- }, [setDisallowParallelEncoding]);
28
- const onDisableWebSecurityChanged = (0, react_1.useCallback)((e) => {
29
- setDisableWebSecurity(e.target.checked);
30
- }, [setDisableWebSecurity]);
31
- const onIgnoreCertificatErrors = (0, react_1.useCallback)((e) => {
32
- setIgnoreCertificateErrors(e.target.checked);
33
- }, [setIgnoreCertificateErrors]);
34
- const onHeadless = (0, react_1.useCallback)((e) => {
35
- setHeadless(e.target.checked);
36
- }, [setHeadless]);
37
- const openGlOptions = (0, react_1.useMemo)(() => {
38
- return extendedOpenGlOptions.map((option) => {
39
- return {
40
- label: option === 'default' ? 'Default' : option,
41
- onClick: () => setOpenGlOption(option),
42
- key: option,
43
- leftItem: openGlOption === option ? (0, jsx_runtime_1.jsx)(Checkmark_1.Checkmark, {}) : null,
44
- id: option,
45
- keyHint: null,
46
- quickSwitcherLabel: null,
47
- subMenu: null,
48
- type: 'item',
49
- value: option,
50
- };
51
- });
52
- }, [extendedOpenGlOptions, openGlOption, setOpenGlOption]);
53
- return ((0, jsx_runtime_1.jsxs)("div", { style: container, className: is_menu_item_1.VERTICAL_SCROLLBAR_CLASSNAME, children: [renderMode === 'still' ? null : ((0, jsx_runtime_1.jsx)(NumberSetting_1.NumberSetting, { min: minConcurrency, max: maxConcurrency, step: 1, name: "Concurrency", formatter: (w) => `${w}x`, onValueChanged: setConcurrency, value: concurrency })), (0, jsx_runtime_1.jsx)(NumberSetting_1.NumberSetting
54
- // TODO: Should be right aligned
55
- // Also appears in packages/renderer/src/validate-puppeteer-timeout.ts
56
- , {
57
- // TODO: Should be right aligned
58
- // Also appears in packages/renderer/src/validate-puppeteer-timeout.ts
59
- min: 7000, max: 900000, name: "delayRender() timeout", onValueChanged: setDelayRenderTimeout, formatter: (w) => `${w}ms`, step: 1000, value: delayRenderTimeout }), (0, jsx_runtime_1.jsxs)("div", { style: layout_1.optionRow, children: [(0, jsx_runtime_1.jsx)("div", { style: layout_1.label, children: "No parallel encoding" }), (0, jsx_runtime_1.jsx)("div", { style: layout_1.rightRow, children: (0, jsx_runtime_1.jsx)(Checkbox_1.Checkbox, { checked: disallowParallelEncoding, onChange: onDisallowParallelEncodingChanged }) })] }), (0, jsx_runtime_1.jsxs)("div", { style: layout_1.optionRow, children: [(0, jsx_runtime_1.jsx)("div", { style: layout_1.label, children: "Verbose logging" }), (0, jsx_runtime_1.jsx)("div", { style: layout_1.rightRow, children: (0, jsx_runtime_1.jsx)(Checkbox_1.Checkbox, { checked: verbose, onChange: onVerboseLoggingChanged }) })] }), (0, jsx_runtime_1.jsx)(RenderModalHr_1.RenderModalHr, {}), (0, jsx_runtime_1.jsxs)("div", { style: layout_1.optionRow, children: [(0, jsx_runtime_1.jsx)("div", { style: layout_1.label, children: "Disable web security" }), (0, jsx_runtime_1.jsx)("div", { style: layout_1.rightRow, children: (0, jsx_runtime_1.jsx)(Checkbox_1.Checkbox, { checked: disableWebSecurity, onChange: onDisableWebSecurityChanged }) })] }), (0, jsx_runtime_1.jsxs)("div", { style: layout_1.optionRow, children: [(0, jsx_runtime_1.jsx)("div", { style: layout_1.label, children: "Ignore certificate errors " }), (0, jsx_runtime_1.jsx)("div", { style: layout_1.rightRow, children: (0, jsx_runtime_1.jsx)(Checkbox_1.Checkbox, { checked: ignoreCertificateErrors, onChange: onIgnoreCertificatErrors }) })] }), (0, jsx_runtime_1.jsxs)("div", { style: layout_1.optionRow, children: [(0, jsx_runtime_1.jsx)("div", { style: layout_1.label, children: "Headless mode" }), (0, jsx_runtime_1.jsx)("div", { style: layout_1.rightRow, children: (0, jsx_runtime_1.jsx)(Checkbox_1.Checkbox, { checked: headless, onChange: onHeadless }) })] }), (0, jsx_runtime_1.jsxs)("div", { style: layout_1.optionRow, children: [(0, jsx_runtime_1.jsx)("div", { style: layout_1.label, children: "OpenGL render backend" }), (0, jsx_runtime_1.jsx)("div", { style: layout_1.rightRow, children: (0, jsx_runtime_1.jsx)(ComboBox_1.Combobox, { values: openGlOptions, selectedId: openGlOption, title: "OpenGl option" }) })] }), (0, jsx_runtime_1.jsx)(RenderModalHr_1.RenderModalHr, {}), (0, jsx_runtime_1.jsx)(RenderModalEnvironmentVariables_1.RenderModalEnvironmentVariables, { envVariables: envVariables, setEnvVariables: setEnvVariables })] }));
60
- };
61
- exports.RenderModalAdvanced = RenderModalAdvanced;