@remotion/cli 3.0.16 → 3.0.19

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 (144) hide show
  1. package/dist/bundle-on-cli.d.ts +2 -0
  2. package/dist/bundle-on-cli.js +41 -0
  3. package/dist/bundle.d.ts +1 -0
  4. package/dist/bundle.js +31 -0
  5. package/dist/compositions.js +2 -1
  6. package/dist/download-progress.js +4 -1
  7. package/dist/editor/components/MenuBuildIndicator.d.ts +2 -0
  8. package/dist/editor/components/MenuBuildIndicator.js +26 -0
  9. package/dist/editor/components/Preview.js +9 -6
  10. package/dist/editor/components/TopPanel.js +1 -0
  11. package/dist/get-cli-options.d.ts +1 -0
  12. package/dist/get-cli-options.js +2 -0
  13. package/dist/get-latest-remotion-version.d.ts +1 -0
  14. package/dist/get-latest-remotion-version.js +31 -0
  15. package/dist/index.d.ts +1 -0
  16. package/dist/parse-command-line.d.ts +1 -0
  17. package/dist/parse-command-line.js +3 -0
  18. package/dist/prepare-entry-point.d.ts +11 -0
  19. package/dist/prepare-entry-point.js +36 -0
  20. package/dist/preview-server/dev-middleware/compatible-api.d.ts +9 -0
  21. package/dist/preview-server/dev-middleware/compatible-api.js +28 -0
  22. package/dist/preview-server/dev-middleware/get-paths.d.ts +7 -0
  23. package/dist/preview-server/dev-middleware/get-paths.js +19 -0
  24. package/dist/preview-server/dev-middleware/index.d.ts +3 -0
  25. package/dist/preview-server/dev-middleware/index.js +27 -0
  26. package/dist/preview-server/dev-middleware/is-color-supported.d.ts +1 -0
  27. package/dist/preview-server/dev-middleware/is-color-supported.js +37 -0
  28. package/dist/preview-server/dev-middleware/middleware.d.ts +10 -0
  29. package/dist/preview-server/dev-middleware/middleware.js +223 -0
  30. package/dist/preview-server/dev-middleware/range-parser.d.ts +15 -0
  31. package/dist/preview-server/dev-middleware/range-parser.js +96 -0
  32. package/dist/preview-server/dev-middleware/ready.d.ts +3 -0
  33. package/dist/preview-server/dev-middleware/ready.js +11 -0
  34. package/dist/preview-server/dev-middleware/setup-hooks.d.ts +2 -0
  35. package/dist/preview-server/dev-middleware/setup-hooks.js +42 -0
  36. package/dist/preview-server/dev-middleware/setup-output-filesystem.d.ts +2 -0
  37. package/dist/preview-server/dev-middleware/setup-output-filesystem.js +13 -0
  38. package/dist/preview-server/dev-middleware/types.d.ts +10 -0
  39. package/dist/preview-server/dev-middleware/types.js +2 -0
  40. package/dist/preview-server/error-overlay/entry-basic.d.ts +1 -0
  41. package/dist/preview-server/error-overlay/entry-basic.js +21 -0
  42. package/dist/preview-server/error-overlay/react-overlay/effects/format-warning.d.ts +11 -0
  43. package/dist/preview-server/error-overlay/react-overlay/effects/format-warning.js +41 -0
  44. package/dist/preview-server/error-overlay/react-overlay/effects/map-error-to-react-stack.d.ts +7 -0
  45. package/dist/preview-server/error-overlay/react-overlay/effects/map-error-to-react-stack.js +46 -0
  46. package/dist/preview-server/error-overlay/react-overlay/effects/proxy-console.d.ts +24 -0
  47. package/dist/preview-server/error-overlay/react-overlay/effects/proxy-console.js +64 -0
  48. package/dist/preview-server/error-overlay/react-overlay/effects/resolve-file-source.d.ts +3 -0
  49. package/dist/preview-server/error-overlay/react-overlay/effects/resolve-file-source.js +31 -0
  50. package/dist/preview-server/error-overlay/react-overlay/effects/stack-trace-limit.d.ts +3 -0
  51. package/dist/preview-server/error-overlay/react-overlay/effects/stack-trace-limit.js +43 -0
  52. package/dist/preview-server/error-overlay/react-overlay/effects/unhandled-error.d.ts +4 -0
  53. package/dist/preview-server/error-overlay/react-overlay/effects/unhandled-error.js +45 -0
  54. package/dist/preview-server/error-overlay/react-overlay/effects/unhandled-rejection.d.ts +4 -0
  55. package/dist/preview-server/error-overlay/react-overlay/effects/unhandled-rejection.js +41 -0
  56. package/dist/preview-server/error-overlay/react-overlay/index.d.ts +2 -0
  57. package/dist/preview-server/error-overlay/react-overlay/index.js +21 -0
  58. package/dist/preview-server/error-overlay/react-overlay/listen-to-runtime-errors.d.ts +8 -0
  59. package/dist/preview-server/error-overlay/react-overlay/listen-to-runtime-errors.js +79 -0
  60. package/dist/preview-server/error-overlay/react-overlay/utils/get-file-source.d.ts +1 -0
  61. package/dist/preview-server/error-overlay/react-overlay/utils/get-file-source.js +21 -0
  62. package/dist/preview-server/error-overlay/react-overlay/utils/get-lines-around.d.ts +14 -0
  63. package/dist/preview-server/error-overlay/react-overlay/utils/get-lines-around.js +24 -0
  64. package/dist/preview-server/error-overlay/react-overlay/utils/get-source-map.d.ts +13 -0
  65. package/dist/preview-server/error-overlay/react-overlay/utils/get-source-map.js +58 -0
  66. package/dist/preview-server/error-overlay/react-overlay/utils/get-stack-frames.d.ts +2 -0
  67. package/dist/preview-server/error-overlay/react-overlay/utils/get-stack-frames.js +27 -0
  68. package/dist/preview-server/error-overlay/react-overlay/utils/open-in-editor.d.ts +12 -0
  69. package/dist/preview-server/error-overlay/react-overlay/utils/open-in-editor.js +460 -0
  70. package/dist/preview-server/error-overlay/react-overlay/utils/parser.d.ts +2 -0
  71. package/dist/preview-server/error-overlay/react-overlay/utils/parser.js +117 -0
  72. package/dist/preview-server/error-overlay/react-overlay/utils/stack-frame.d.ts +40 -0
  73. package/dist/preview-server/error-overlay/react-overlay/utils/stack-frame.js +31 -0
  74. package/dist/preview-server/error-overlay/react-overlay/utils/unmapper.d.ts +2 -0
  75. package/dist/preview-server/error-overlay/react-overlay/utils/unmapper.js +64 -0
  76. package/dist/preview-server/error-overlay/remotion-overlay/AskOnDiscord.d.ts +2 -0
  77. package/dist/preview-server/error-overlay/remotion-overlay/AskOnDiscord.js +14 -0
  78. package/dist/preview-server/error-overlay/remotion-overlay/Button.d.ts +6 -0
  79. package/dist/preview-server/error-overlay/remotion-overlay/Button.js +24 -0
  80. package/dist/preview-server/error-overlay/remotion-overlay/CodeFrame.d.ts +6 -0
  81. package/dist/preview-server/error-overlay/remotion-overlay/CodeFrame.js +28 -0
  82. package/dist/preview-server/error-overlay/remotion-overlay/DismissButton.d.ts +2 -0
  83. package/dist/preview-server/error-overlay/remotion-overlay/DismissButton.js +23 -0
  84. package/dist/preview-server/error-overlay/remotion-overlay/ErrorDisplay.d.ts +5 -0
  85. package/dist/preview-server/error-overlay/remotion-overlay/ErrorDisplay.js +45 -0
  86. package/dist/preview-server/error-overlay/remotion-overlay/ErrorLoader.d.ts +4 -0
  87. package/dist/preview-server/error-overlay/remotion-overlay/ErrorLoader.js +61 -0
  88. package/dist/preview-server/error-overlay/remotion-overlay/ErrorTitle.d.ts +6 -0
  89. package/dist/preview-server/error-overlay/remotion-overlay/ErrorTitle.js +41 -0
  90. package/dist/preview-server/error-overlay/remotion-overlay/OpenInEditor.d.ts +5 -0
  91. package/dist/preview-server/error-overlay/remotion-overlay/OpenInEditor.js +91 -0
  92. package/dist/preview-server/error-overlay/remotion-overlay/Overlay.d.ts +14 -0
  93. package/dist/preview-server/error-overlay/remotion-overlay/Overlay.js +49 -0
  94. package/dist/preview-server/error-overlay/remotion-overlay/SearchGitHubIssues.d.ts +4 -0
  95. package/dist/preview-server/error-overlay/remotion-overlay/SearchGitHubIssues.js +13 -0
  96. package/dist/preview-server/error-overlay/remotion-overlay/StackFrame.d.ts +8 -0
  97. package/dist/preview-server/error-overlay/remotion-overlay/StackFrame.js +48 -0
  98. package/dist/preview-server/error-overlay/remotion-overlay/Symbolicating.d.ts +2 -0
  99. package/dist/preview-server/error-overlay/remotion-overlay/Symbolicating.js +8 -0
  100. package/dist/preview-server/error-overlay/remotion-overlay/carets.d.ts +3 -0
  101. package/dist/preview-server/error-overlay/remotion-overlay/carets.js +12 -0
  102. package/dist/preview-server/error-overlay/remotion-overlay/format-location.d.ts +1 -0
  103. package/dist/preview-server/error-overlay/remotion-overlay/format-location.js +10 -0
  104. package/dist/preview-server/error-overlay/remotion-overlay/index.d.ts +1 -0
  105. package/dist/preview-server/error-overlay/remotion-overlay/index.js +18 -0
  106. package/dist/preview-server/fast-refresh/helpers.d.ts +39 -0
  107. package/dist/preview-server/fast-refresh/helpers.js +145 -0
  108. package/dist/preview-server/fast-refresh/index.d.ts +30 -0
  109. package/dist/preview-server/fast-refresh/index.js +86 -0
  110. package/dist/preview-server/fast-refresh/loader.d.ts +35 -0
  111. package/dist/preview-server/fast-refresh/loader.js +81 -0
  112. package/dist/preview-server/fast-refresh/runtime.d.ts +35 -0
  113. package/dist/preview-server/fast-refresh/runtime.js +32 -0
  114. package/dist/preview-server/get-package-manager.d.ts +9 -0
  115. package/dist/preview-server/get-package-manager.js +40 -0
  116. package/dist/preview-server/hot-middleware/client.d.ts +19 -0
  117. package/dist/preview-server/hot-middleware/client.js +177 -0
  118. package/dist/preview-server/hot-middleware/index.d.ts +8 -0
  119. package/dist/preview-server/hot-middleware/index.js +150 -0
  120. package/dist/preview-server/hot-middleware/process-update.d.ts +12 -0
  121. package/dist/preview-server/hot-middleware/process-update.js +144 -0
  122. package/dist/preview-server/hot-middleware/strip-ansi.d.ts +1 -0
  123. package/dist/preview-server/hot-middleware/strip-ansi.js +21 -0
  124. package/dist/preview-server/hot-middleware/types.d.ts +27 -0
  125. package/dist/preview-server/hot-middleware/types.js +10 -0
  126. package/dist/preview-server/project-info.d.ts +5 -0
  127. package/dist/preview-server/project-info.js +22 -0
  128. package/dist/preview-server/routes.d.ts +2 -0
  129. package/dist/preview-server/routes.js +121 -0
  130. package/dist/preview-server/serve-static.d.ts +9 -0
  131. package/dist/preview-server/serve-static.js +77 -0
  132. package/dist/preview-server/start-server.d.ts +8 -0
  133. package/dist/preview-server/start-server.js +68 -0
  134. package/dist/preview-server/static-preview.d.ts +1 -0
  135. package/dist/preview-server/static-preview.js +40 -0
  136. package/dist/preview-server/update-available.d.ts +11 -0
  137. package/dist/preview-server/update-available.js +44 -0
  138. package/dist/preview-server/webpack-cache.d.ts +12 -0
  139. package/dist/preview-server/webpack-cache.js +66 -0
  140. package/dist/render.js +6 -1
  141. package/dist/still.js +2 -1
  142. package/dist/webpack-cache.d.ts +12 -0
  143. package/dist/webpack-cache.js +66 -0
  144. package/package.json +8 -9
@@ -0,0 +1,2 @@
1
+ import { RenderStep } from './step';
2
+ export declare const bundleOnCli: (fullPath: string, steps: RenderStep[]) => Promise<string>;
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.bundleOnCli = void 0;
4
+ const bundler_1 = require("@remotion/bundler");
5
+ const remotion_1 = require("remotion");
6
+ const log_1 = require("./log");
7
+ const parse_command_line_1 = require("./parse-command-line");
8
+ const progress_bar_1 = require("./progress-bar");
9
+ const bundleOnCli = async (fullPath, steps) => {
10
+ var _a;
11
+ const shouldCache = remotion_1.Internals.getWebpackCaching();
12
+ const cacheExistedBefore = bundler_1.BundlerInternals.cacheExists('production', null);
13
+ if (cacheExistedBefore && !shouldCache) {
14
+ log_1.Log.info('🧹 Cache disabled but found. Deleting... ');
15
+ await bundler_1.BundlerInternals.clearCache('production', null);
16
+ }
17
+ const bundleStartTime = Date.now();
18
+ const bundlingProgress = (0, progress_bar_1.createOverwriteableCliOutput)((0, parse_command_line_1.quietFlagProvided)());
19
+ const bundled = await (0, bundler_1.bundle)(fullPath, (progress) => {
20
+ bundlingProgress.update((0, progress_bar_1.makeBundlingProgress)({
21
+ progress: progress / 100,
22
+ steps,
23
+ doneIn: null,
24
+ }));
25
+ }, {
26
+ enableCaching: shouldCache,
27
+ webpackOverride: (_a = remotion_1.Internals.getWebpackOverrideFn()) !== null && _a !== void 0 ? _a : remotion_1.Internals.defaultOverrideFunction,
28
+ });
29
+ bundlingProgress.update((0, progress_bar_1.makeBundlingProgress)({
30
+ progress: 1,
31
+ steps,
32
+ doneIn: Date.now() - bundleStartTime,
33
+ }) + '\n');
34
+ log_1.Log.verbose('Bundled under', bundled);
35
+ const cacheExistedAfter = bundler_1.BundlerInternals.cacheExists('production', null);
36
+ if (cacheExistedAfter && !cacheExistedBefore) {
37
+ log_1.Log.info('⚡️ Cached bundle. Subsequent renders will be faster.');
38
+ }
39
+ return bundled;
40
+ };
41
+ exports.bundleOnCli = bundleOnCli;
@@ -0,0 +1 @@
1
+ export declare const bundleCommand: () => Promise<void>;
package/dist/bundle.js ADDED
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.bundleCommand = void 0;
4
+ const get_cli_options_1 = require("./get-cli-options");
5
+ const initialize_render_cli_1 = require("./initialize-render-cli");
6
+ const log_1 = require("./log");
7
+ const parse_command_line_1 = require("./parse-command-line");
8
+ const prepare_entry_point_1 = require("./prepare-entry-point");
9
+ const bundleCommand = async () => {
10
+ const file = parse_command_line_1.parsedCli._[1];
11
+ if (!file) {
12
+ log_1.Log.error('No entry point specified. Pass more arguments:');
13
+ log_1.Log.error(' npx remotion bundle [entry-point]');
14
+ log_1.Log.error('Documentation: https://www.remotion.dev/docs/render');
15
+ process.exit(1);
16
+ }
17
+ await (0, initialize_render_cli_1.initializeRenderCli)('bundle');
18
+ const { publicPath, bundleOutDir } = await (0, get_cli_options_1.getCliOptions)({
19
+ isLambda: false,
20
+ type: 'get-compositions-or-bundle',
21
+ });
22
+ const { urlOrBundle } = await (0, prepare_entry_point_1.prepareEntryPoint)({
23
+ file,
24
+ otherSteps: [],
25
+ outDir: bundleOutDir,
26
+ publicPath,
27
+ });
28
+ log_1.Log.info();
29
+ log_1.Log.info(urlOrBundle);
30
+ };
31
+ exports.bundleCommand = bundleCommand;
@@ -34,11 +34,12 @@ const listCompositionsCommand = async () => {
34
34
  }
35
35
  const fullPath = path_1.default.join(process.cwd(), file);
36
36
  await (0, get_config_file_name_1.loadConfig)();
37
- const { browserExecutable, ffmpegExecutable, chromiumOptions, envVariables, inputProps, puppeteerTimeout, port, } = await (0, get_cli_options_1.getCliOptions)({ isLambda: false, type: 'get-compositions' });
37
+ const { browserExecutable, ffmpegExecutable, ffprobeExecutable, chromiumOptions, envVariables, inputProps, puppeteerTimeout, port, } = await (0, get_cli_options_1.getCliOptions)({ isLambda: false, type: 'get-compositions' });
38
38
  const bundled = await (0, setup_cache_1.bundleOnCli)(fullPath, ['bundling']);
39
39
  const compositions = await (0, renderer_1.getCompositions)(bundled, {
40
40
  browserExecutable,
41
41
  ffmpegExecutable,
42
+ ffprobeExecutable,
42
43
  chromiumOptions,
43
44
  envVariables,
44
45
  inputProps,
@@ -8,10 +8,13 @@ const makeMultiDownloadProgress = (progresses) => {
8
8
  }
9
9
  if (progresses.length === 1) {
10
10
  const [progress] = progresses;
11
+ const truncatedFileName = progress.name.length >= 100
12
+ ? progress.name.substring(0, 97) + '...'
13
+ : progress.name;
11
14
  return [
12
15
  ` +`,
13
16
  (0, make_progress_bar_1.makeProgressBar)(progress.progress),
14
- `Downloading ${progress.name}`,
17
+ `Downloading ${truncatedFileName}`,
15
18
  ].join(' ');
16
19
  }
17
20
  return [
@@ -0,0 +1,2 @@
1
+ import React from 'react';
2
+ export declare const MenuBuildIndicator: React.FC;
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MenuBuildIndicator = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const cwd = {
7
+ fontSize: 13,
8
+ opacity: 0.8,
9
+ };
10
+ const MenuBuildIndicator = () => {
11
+ const [isBuilding, setIsBuilding] = (0, react_1.useState)(false);
12
+ (0, react_1.useEffect)(() => {
13
+ window.remotion_isBuilding = () => {
14
+ setIsBuilding(true);
15
+ };
16
+ window.remotion_finishedBuilding = () => {
17
+ setIsBuilding(false);
18
+ };
19
+ return () => {
20
+ window.remotion_isBuilding = undefined;
21
+ window.remotion_finishedBuilding = undefined;
22
+ };
23
+ }, []);
24
+ return ((0, jsx_runtime_1.jsx)("div", { style: cwd, title: window.remotion_cwd, children: isBuilding ? 'Building...' : window.remotion_projectName }));
25
+ };
26
+ exports.MenuBuildIndicator = MenuBuildIndicator;
@@ -8,7 +8,6 @@ const remotion_1 = require("remotion");
8
8
  const checkerboard_background_1 = require("../helpers/checkerboard-background");
9
9
  const checkerboard_1 = require("../state/checkerboard");
10
10
  const preview_size_1 = require("../state/preview-size");
11
- const LoadingIndicator_1 = require("./LoadingIndicator");
12
11
  const checkerboardSize = 49;
13
12
  const containerStyle = (options) => {
14
13
  return {
@@ -26,9 +25,8 @@ const containerStyle = (options) => {
26
25
  };
27
26
  };
28
27
  const Inner = ({ canvasSize }) => {
29
- var _a;
30
28
  const { size: previewSize } = (0, react_1.useContext)(preview_size_1.PreviewSizeContext);
31
- const video = remotion_1.Internals.useVideo();
29
+ const portalContainer = (0, react_1.useRef)(null);
32
30
  const config = (0, remotion_1.useVideoConfig)();
33
31
  const { checkerboard } = (0, react_1.useContext)(checkerboard_1.CheckerboardContext);
34
32
  const { centerX, centerY, yCorrection, xCorrection, scale } = player_1.PlayerInternals.calculateScale({
@@ -66,9 +64,14 @@ const Inner = ({ canvasSize }) => {
66
64
  xCorrection,
67
65
  yCorrection,
68
66
  ]);
69
- const Component = video ? video.component : null;
70
- const inputProps = (0, remotion_1.getInputProps)();
71
- return ((0, jsx_runtime_1.jsx)(react_1.Suspense, { fallback: (0, jsx_runtime_1.jsx)(LoadingIndicator_1.Loading, {}), children: (0, jsx_runtime_1.jsx)("div", { style: outer, children: (0, jsx_runtime_1.jsx)("div", { style: style, children: Component ? ((0, jsx_runtime_1.jsx)(Component, { ...((_a = video === null || video === void 0 ? void 0 : video.defaultProps) !== null && _a !== void 0 ? _a : {}), ...inputProps })) : null }) }) }));
67
+ (0, react_1.useEffect)(() => {
68
+ const { current } = portalContainer;
69
+ current === null || current === void 0 ? void 0 : current.appendChild(remotion_1.Internals.portalNode());
70
+ return () => {
71
+ current === null || current === void 0 ? void 0 : current.removeChild(remotion_1.Internals.portalNode());
72
+ };
73
+ }, []);
74
+ return ((0, jsx_runtime_1.jsx)("div", { style: outer, children: (0, jsx_runtime_1.jsx)("div", { ref: portalContainer, style: style }) }));
72
75
  };
73
76
  const VideoPreview = ({ canvasSize }) => {
74
77
  const config = remotion_1.Internals.useUnsafeVideoConfig();
@@ -16,6 +16,7 @@ const SplitterElement_1 = require("./Splitter/SplitterElement");
16
16
  const SplitterHandle_1 = require("./Splitter/SplitterHandle");
17
17
  const container = {
18
18
  height: '100%',
19
+ width: '100%',
19
20
  display: 'flex',
20
21
  flexDirection: 'column',
21
22
  flex: 1,
@@ -22,6 +22,7 @@ export declare const getCliOptions: (options: {
22
22
  stillFrame: number;
23
23
  browserExecutable: BrowserExecutable;
24
24
  ffmpegExecutable: import("remotion").FfmpegExecutable;
25
+ ffprobeExecutable: import("remotion").FfmpegExecutable;
25
26
  logLevel: "verbose" | "info" | "warn" | "error";
26
27
  scale: number;
27
28
  chromiumOptions: ChromiumOptions;
@@ -144,6 +144,7 @@ const getCliOptions = async (options) => {
144
144
  const proResProfile = getAndValidateProResProfile(codec);
145
145
  const browserExecutable = remotion_1.Internals.getBrowserExecutable();
146
146
  const ffmpegExecutable = remotion_1.Internals.getCustomFfmpegExecutable();
147
+ const ffprobeExecutable = remotion_1.Internals.getCustomFfprobeExecutable();
147
148
  const scale = remotion_1.Internals.getScale();
148
149
  const port = remotion_1.Internals.getServerPort();
149
150
  const chromiumOptions = {
@@ -173,6 +174,7 @@ const getCliOptions = async (options) => {
173
174
  stillFrame: remotion_1.Internals.getStillFrame(),
174
175
  browserExecutable,
175
176
  ffmpegExecutable,
177
+ ffprobeExecutable,
176
178
  logLevel: remotion_1.Internals.Logging.getLogLevel(),
177
179
  scale,
178
180
  chromiumOptions,
@@ -0,0 +1 @@
1
+ export declare const getLatestRemotionVersion: () => Promise<any>;
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.getLatestRemotionVersion = void 0;
7
+ const https_1 = __importDefault(require("https"));
8
+ const getPackageJsonForRemotion = () => {
9
+ return new Promise((resolve, reject) => {
10
+ const req = https_1.default.get('https://registry.npmjs.org/remotion', {
11
+ headers: {
12
+ accept: 'application/vnd.npm.install-v1+json; q=1.0, application/json; q=0.8, */*',
13
+ },
14
+ }, (res) => {
15
+ let data = '';
16
+ res.on('data', (d) => {
17
+ data += d;
18
+ });
19
+ res.on('end', () => resolve(data));
20
+ });
21
+ req.on('error', (error) => {
22
+ reject(error);
23
+ });
24
+ req.end();
25
+ });
26
+ };
27
+ const getLatestRemotionVersion = async () => {
28
+ const pkgJson = await getPackageJsonForRemotion();
29
+ return JSON.parse(pkgJson)['dist-tags'].latest;
30
+ };
31
+ exports.getLatestRemotionVersion = getLatestRemotionVersion;
package/dist/index.d.ts CHANGED
@@ -47,6 +47,7 @@ export declare const CliInternals: {
47
47
  stillFrame: number;
48
48
  browserExecutable: import("remotion").BrowserExecutable;
49
49
  ffmpegExecutable: import("remotion").FfmpegExecutable;
50
+ ffprobeExecutable: import("remotion").FfmpegExecutable;
50
51
  logLevel: "verbose" | "info" | "warn" | "error";
51
52
  scale: number;
52
53
  chromiumOptions: import("@remotion/renderer").ChromiumOptions;
@@ -3,6 +3,7 @@ import { BrowserExecutable, Codec, FfmpegExecutable, ImageFormat, OpenGlRenderer
3
3
  export declare type CommandLineOptions = {
4
4
  ['browser-executable']: BrowserExecutable;
5
5
  ['ffmpeg-executable']: FfmpegExecutable;
6
+ ['ffprobe-executable']: FfmpegExecutable;
6
7
  ['pixel-format']: PixelFormat;
7
8
  ['image-format']: ImageFormat;
8
9
  ['prores-profile']: ProResProfile;
@@ -42,6 +42,9 @@ const parseCommandLine = (type) => {
42
42
  if (exports.parsedCli['ffmpeg-executable']) {
43
43
  remotion_1.Config.Rendering.setFfmpegExecutable((0, path_1.resolve)(exports.parsedCli['ffmpeg-executable']));
44
44
  }
45
+ if (exports.parsedCli['ffprobe-executable']) {
46
+ remotion_1.Config.Rendering.setFfprobeExecutable((0, path_1.resolve)(exports.parsedCli['ffprobe-executable']));
47
+ }
45
48
  if (typeof exports.parsedCli['bundle-cache'] !== 'undefined') {
46
49
  remotion_1.Config.Bundling.setCachingEnabled(exports.parsedCli['bundle-cache'] !== 'false');
47
50
  }
@@ -0,0 +1,11 @@
1
+ import { RenderStep } from './step';
2
+ export declare const prepareEntryPoint: ({ file, otherSteps, publicPath, outDir, }: {
3
+ file: string;
4
+ otherSteps: RenderStep[];
5
+ outDir: string | null;
6
+ publicPath: string | null;
7
+ }) => Promise<{
8
+ urlOrBundle: string;
9
+ steps: RenderStep[];
10
+ shouldDelete: boolean;
11
+ }>;
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.prepareEntryPoint = void 0;
7
+ const renderer_1 = require("@remotion/renderer");
8
+ const promises_1 = require("fs/promises");
9
+ const path_1 = __importDefault(require("path"));
10
+ const process_1 = require("process");
11
+ const log_1 = require("./log");
12
+ const setup_cache_1 = require("./setup-cache");
13
+ const prepareEntryPoint = async ({ file, otherSteps, publicPath, outDir, }) => {
14
+ if (renderer_1.RenderInternals.isServeUrl(file)) {
15
+ return { urlOrBundle: file, steps: otherSteps, shouldDelete: false };
16
+ }
17
+ const joined = path_1.default.resolve(process.cwd(), file);
18
+ try {
19
+ const stats = await (0, promises_1.stat)(joined);
20
+ if (stats.isDirectory()) {
21
+ return { urlOrBundle: joined, steps: otherSteps, shouldDelete: false };
22
+ }
23
+ }
24
+ catch (err) {
25
+ log_1.Log.error(`No file or directory exists at ${joined}.`);
26
+ (0, process_1.exit)(1);
27
+ }
28
+ const urlOrBundle = await (0, setup_cache_1.bundleOnCli)({
29
+ fullPath: joined,
30
+ steps: ['bundling', ...otherSteps],
31
+ outDir,
32
+ publicPath,
33
+ });
34
+ return { urlOrBundle, steps: ['bundling', ...otherSteps], shouldDelete: true };
35
+ };
36
+ exports.prepareEntryPoint = prepareEntryPoint;
@@ -0,0 +1,9 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ /// <reference types="node" />
4
+ import { ReadStream } from 'fs';
5
+ import { IncomingMessage, ServerResponse } from 'http';
6
+ export declare function getHeaderFromRequest(req: IncomingMessage, name: string): string | string[] | undefined;
7
+ export declare function getHeaderFromResponse(res: ServerResponse, name: string): string | number | string[] | undefined;
8
+ export declare function setHeaderForResponse(res: ServerResponse, name: string, value: string | number): void;
9
+ export declare function send(req: IncomingMessage, res: ServerResponse, bufferOtStream: ReadStream | string | Buffer, byteLength: number): void;
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.send = exports.setHeaderForResponse = exports.getHeaderFromResponse = exports.getHeaderFromRequest = void 0;
4
+ function getHeaderFromRequest(req, name) {
5
+ return req.headers[name];
6
+ }
7
+ exports.getHeaderFromRequest = getHeaderFromRequest;
8
+ function getHeaderFromResponse(res, name) {
9
+ return res.getHeader(name);
10
+ }
11
+ exports.getHeaderFromResponse = getHeaderFromResponse;
12
+ function setHeaderForResponse(res, name, value) {
13
+ res.setHeader(name, typeof value === 'number' ? String(value) : value);
14
+ }
15
+ exports.setHeaderForResponse = setHeaderForResponse;
16
+ function send(req, res, bufferOtStream, byteLength) {
17
+ if (typeof bufferOtStream === 'string' || Buffer.isBuffer(bufferOtStream)) {
18
+ res.end(bufferOtStream);
19
+ return;
20
+ }
21
+ setHeaderForResponse(res, 'Content-Length', byteLength);
22
+ if (req.method === 'HEAD') {
23
+ res.end();
24
+ return;
25
+ }
26
+ bufferOtStream.pipe(res);
27
+ }
28
+ exports.send = send;
@@ -0,0 +1,7 @@
1
+ import { DevMiddlewareContext } from './types';
2
+ declare type PublicPath = {
3
+ outputPath: string;
4
+ publicPath: string;
5
+ };
6
+ export declare function getPaths(context: DevMiddlewareContext): PublicPath[];
7
+ export {};
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getPaths = void 0;
4
+ function getPaths(context) {
5
+ const { stats } = context;
6
+ const publicPaths = [];
7
+ if (!stats) {
8
+ return publicPaths;
9
+ }
10
+ const { compilation } = stats;
11
+ // The `output.path` is always present and always absolute
12
+ const outputPath = compilation.getPath(compilation.outputOptions.path || '');
13
+ const publicPath = compilation.outputOptions.publicPath
14
+ ? compilation.getPath(compilation.outputOptions.publicPath)
15
+ : '';
16
+ publicPaths.push({ outputPath, publicPath });
17
+ return publicPaths;
18
+ }
19
+ exports.getPaths = getPaths;
@@ -0,0 +1,3 @@
1
+ import { webpack } from '@remotion/bundler';
2
+ import { MiddleWare } from './middleware';
3
+ export declare const wdm: (compiler: webpack.Compiler) => MiddleWare;
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.wdm = void 0;
4
+ const middleware_1 = require("./middleware");
5
+ const setup_hooks_1 = require("./setup-hooks");
6
+ const setup_output_filesystem_1 = require("./setup-output-filesystem");
7
+ const wdm = (compiler) => {
8
+ const context = {
9
+ state: false,
10
+ stats: undefined,
11
+ callbacks: [],
12
+ compiler,
13
+ logger: compiler.getInfrastructureLogger('remotion'),
14
+ outputFileSystem: undefined,
15
+ };
16
+ (0, setup_hooks_1.setupHooks)(context);
17
+ (0, setup_output_filesystem_1.setupOutputFileSystem)(context);
18
+ const errorHandler = (error) => {
19
+ if (error) {
20
+ context.logger.error(error);
21
+ }
22
+ };
23
+ const watchOptions = context.compiler.options.watchOptions || {};
24
+ context.compiler.watch(watchOptions, errorHandler);
25
+ return (0, middleware_1.middleware)(context);
26
+ };
27
+ exports.wdm = wdm;
@@ -0,0 +1 @@
1
+ export declare const isColorSupported: boolean;
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var _a;
26
+ Object.defineProperty(exports, "__esModule", { value: true });
27
+ exports.isColorSupported = void 0;
28
+ const tty = __importStar(require("tty"));
29
+ const argv = process.argv || [];
30
+ const env = process.env || {};
31
+ const isDisabled = 'NO_COLOR' in env || argv.includes('--no-color');
32
+ const isForced = 'FORCE_COLOR' in env || argv.includes('--color');
33
+ const isWindows = process.platform === 'win32';
34
+ const isCompatibleTerminal = ((_a = tty === null || tty === void 0 ? void 0 : tty.isatty) === null || _a === void 0 ? void 0 : _a.call(tty, 1)) && env.TERM && env.TERM !== 'dumb';
35
+ const isCI = 'CI' in env &&
36
+ ('GITHUB_ACTIONS' in env || 'GITLAB_CI' in env || 'CIRCLECI' in env);
37
+ exports.isColorSupported = !isDisabled && (isForced || isWindows || isCompatibleTerminal || isCI);
@@ -0,0 +1,10 @@
1
+ /// <reference types="node" />
2
+ import { IncomingMessage, ServerResponse } from 'http';
3
+ import { DevMiddlewareContext } from './types';
4
+ export declare function getFilenameFromUrl(context: DevMiddlewareContext, url: string | undefined): string | undefined;
5
+ export declare function getValueContentRangeHeader(type: string, size: number, range?: {
6
+ start: number;
7
+ end: number;
8
+ }): string;
9
+ export declare type MiddleWare = (req: IncomingMessage, res: ServerResponse, next: () => void) => void;
10
+ export declare function middleware(context: DevMiddlewareContext): (req: IncomingMessage, res: ServerResponse, next: () => void) => void;