@remotion/renderer 3.3.77 → 3.3.78

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.
package/dist/client.d.ts CHANGED
@@ -1,9 +1,9 @@
1
1
  export declare const BrowserSafeApis: {
2
- getFileExtensionFromCodec: <T extends "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif">(codec: T, audioCodec: "pcm-16" | "aac" | "mp3" | "opus" | null) => import("./file-extensions").FileExtension;
2
+ getFileExtensionFromCodec: <T extends "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif">(codec: T, audioCodec: "mp3" | "aac" | "pcm-16" | "opus" | null) => import("./file-extensions").FileExtension;
3
3
  validCodecs: readonly ["h264", "h265", "vp8", "vp9", "mp3", "aac", "wav", "prores", "h264-mkv", "gif"];
4
- getDefaultCrfForCodec: (codec: "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif") => number;
5
- getValidCrfRanges: (codec: "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif") => [number, number];
6
- isAudioCodec: (codec: "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif" | undefined) => boolean;
4
+ getDefaultCrfForCodec: (codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif") => number;
5
+ getValidCrfRanges: (codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif") => [number, number];
6
+ isAudioCodec: (codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif" | undefined) => boolean;
7
7
  validPixelFormats: readonly ["yuv420p", "yuva420p", "yuv422p", "yuv444p", "yuv420p10le", "yuv422p10le", "yuv444p10le", "yuva444p10le"];
8
8
  DEFAULT_PIXEL_FORMAT: "yuv420p" | "yuva420p" | "yuv422p" | "yuv444p" | "yuv420p10le" | "yuv422p10le" | "yuv444p10le" | "yuva444p10le";
9
9
  supportedAudioCodecs: {
@@ -19,79 +19,79 @@ export declare const BrowserSafeApis: {
19
19
  readonly wav: readonly ["pcm-16"];
20
20
  };
21
21
  defaultFileExtensionMap: {
22
- aac: {
22
+ h264: {
23
23
  default: import("./file-extensions").FileExtension;
24
24
  forAudioCodec: {
25
- "pcm-16": {
25
+ aac: {
26
26
  possible: import("./file-extensions").FileExtension[];
27
27
  default: import("./file-extensions").FileExtension;
28
28
  };
29
- aac: {
29
+ "pcm-16": {
30
30
  possible: import("./file-extensions").FileExtension[];
31
31
  default: import("./file-extensions").FileExtension;
32
32
  };
33
33
  };
34
34
  };
35
- mp3: {
35
+ h265: {
36
36
  default: import("./file-extensions").FileExtension;
37
37
  forAudioCodec: {
38
- "pcm-16": {
38
+ aac: {
39
39
  possible: import("./file-extensions").FileExtension[];
40
40
  default: import("./file-extensions").FileExtension;
41
41
  };
42
- mp3: {
42
+ "pcm-16": {
43
43
  possible: import("./file-extensions").FileExtension[];
44
44
  default: import("./file-extensions").FileExtension;
45
45
  };
46
46
  };
47
47
  };
48
- h264: {
48
+ vp8: {
49
49
  default: import("./file-extensions").FileExtension;
50
50
  forAudioCodec: {
51
51
  "pcm-16": {
52
52
  possible: import("./file-extensions").FileExtension[];
53
53
  default: import("./file-extensions").FileExtension;
54
54
  };
55
- aac: {
55
+ opus: {
56
56
  possible: import("./file-extensions").FileExtension[];
57
57
  default: import("./file-extensions").FileExtension;
58
58
  };
59
59
  };
60
60
  };
61
- h265: {
61
+ vp9: {
62
62
  default: import("./file-extensions").FileExtension;
63
63
  forAudioCodec: {
64
64
  "pcm-16": {
65
65
  possible: import("./file-extensions").FileExtension[];
66
66
  default: import("./file-extensions").FileExtension;
67
67
  };
68
- aac: {
68
+ opus: {
69
69
  possible: import("./file-extensions").FileExtension[];
70
70
  default: import("./file-extensions").FileExtension;
71
71
  };
72
72
  };
73
73
  };
74
- vp8: {
74
+ mp3: {
75
75
  default: import("./file-extensions").FileExtension;
76
76
  forAudioCodec: {
77
- "pcm-16": {
77
+ mp3: {
78
78
  possible: import("./file-extensions").FileExtension[];
79
79
  default: import("./file-extensions").FileExtension;
80
80
  };
81
- opus: {
81
+ "pcm-16": {
82
82
  possible: import("./file-extensions").FileExtension[];
83
83
  default: import("./file-extensions").FileExtension;
84
84
  };
85
85
  };
86
86
  };
87
- vp9: {
87
+ aac: {
88
88
  default: import("./file-extensions").FileExtension;
89
89
  forAudioCodec: {
90
- "pcm-16": {
90
+ aac: {
91
91
  possible: import("./file-extensions").FileExtension[];
92
92
  default: import("./file-extensions").FileExtension;
93
93
  };
94
- opus: {
94
+ "pcm-16": {
95
95
  possible: import("./file-extensions").FileExtension[];
96
96
  default: import("./file-extensions").FileExtension;
97
97
  };
@@ -109,11 +109,11 @@ export declare const BrowserSafeApis: {
109
109
  prores: {
110
110
  default: import("./file-extensions").FileExtension;
111
111
  forAudioCodec: {
112
- "pcm-16": {
112
+ aac: {
113
113
  possible: import("./file-extensions").FileExtension[];
114
114
  default: import("./file-extensions").FileExtension;
115
115
  };
116
- aac: {
116
+ "pcm-16": {
117
117
  possible: import("./file-extensions").FileExtension[];
118
118
  default: import("./file-extensions").FileExtension;
119
119
  };
@@ -134,21 +134,13 @@ export declare const BrowserSafeApis: {
134
134
  };
135
135
  };
136
136
  defaultAudioCodecs: {
137
- aac: {
138
- compressed: "pcm-16" | "aac" | null;
139
- lossless: "pcm-16" | "aac" | null;
140
- };
141
- mp3: {
142
- compressed: "pcm-16" | "mp3" | null;
143
- lossless: "pcm-16" | "mp3" | null;
144
- };
145
137
  h264: {
146
- compressed: "pcm-16" | "aac" | null;
147
- lossless: "pcm-16" | "aac" | null;
138
+ compressed: "aac" | "pcm-16" | null;
139
+ lossless: "aac" | "pcm-16" | null;
148
140
  };
149
141
  h265: {
150
- compressed: "pcm-16" | "aac" | null;
151
- lossless: "pcm-16" | "aac" | null;
142
+ compressed: "aac" | "pcm-16" | null;
143
+ lossless: "aac" | "pcm-16" | null;
152
144
  };
153
145
  vp8: {
154
146
  compressed: "pcm-16" | "opus" | null;
@@ -158,13 +150,21 @@ export declare const BrowserSafeApis: {
158
150
  compressed: "pcm-16" | "opus" | null;
159
151
  lossless: "pcm-16" | "opus" | null;
160
152
  };
153
+ mp3: {
154
+ compressed: "mp3" | "pcm-16" | null;
155
+ lossless: "mp3" | "pcm-16" | null;
156
+ };
157
+ aac: {
158
+ compressed: "aac" | "pcm-16" | null;
159
+ lossless: "aac" | "pcm-16" | null;
160
+ };
161
161
  wav: {
162
162
  compressed: "pcm-16" | null;
163
163
  lossless: "pcm-16" | null;
164
164
  };
165
165
  prores: {
166
- compressed: "pcm-16" | "aac" | null;
167
- lossless: "pcm-16" | "aac" | null;
166
+ compressed: "aac" | "pcm-16" | null;
167
+ lossless: "aac" | "pcm-16" | null;
168
168
  };
169
169
  "h264-mkv": {
170
170
  compressed: "pcm-16" | null;
@@ -175,5 +175,5 @@ export declare const BrowserSafeApis: {
175
175
  lossless: null;
176
176
  };
177
177
  };
178
- defaultCodecsForFileExtension: Record<import("./file-extensions").FileExtension, "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif">;
178
+ defaultCodecsForFileExtension: Record<import("./file-extensions").FileExtension, "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif">;
179
179
  };
@@ -0,0 +1,7 @@
1
+ import type { FfmpegExecutable } from './ffmpeg-executable';
2
+ export declare const convertToPcm: ({ ffmpegExecutable, input, outName, remotionRoot, }: {
3
+ ffmpegExecutable: FfmpegExecutable;
4
+ input: string;
5
+ outName: string;
6
+ remotionRoot: string;
7
+ }) => Promise<void>;
@@ -0,0 +1,21 @@
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.convertToPcm = void 0;
7
+ const execa_1 = __importDefault(require("execa"));
8
+ const ffmpeg_flags_1 = require("./ffmpeg-flags");
9
+ const sample_rate_1 = require("./sample-rate");
10
+ const convertToPcm = async ({ ffmpegExecutable, input, outName, remotionRoot, }) => {
11
+ await (0, execa_1.default)(await (0, ffmpeg_flags_1.getExecutableBinary)(ffmpegExecutable, remotionRoot, 'ffmpeg'), [
12
+ '-i',
13
+ input,
14
+ '-c:a',
15
+ 'pcm_s16le',
16
+ '-ar',
17
+ String(sample_rate_1.DEFAULT_SAMPLE_RATE),
18
+ outName,
19
+ ]);
20
+ };
21
+ exports.convertToPcm = convertToPcm;
@@ -7,9 +7,6 @@ export declare const createFfmpegComplexFilter: ({ filters, downloadMap, ffmpegE
7
7
  ffmpegExecutable: FfmpegExecutable;
8
8
  remotionRoot: string;
9
9
  }) => Promise<{
10
- complexFilterFlag: [
11
- string,
12
- string
13
- ] | null;
10
+ complexFilterFlag: [string, string] | null;
14
11
  cleanup: () => void;
15
12
  }>;
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import type { OffthreadVideoImageFormat } from 'remotion';
2
3
  import type { DownloadMap } from './assets/download-map';
3
4
  import type { FfmpegExecutable } from './ffmpeg-executable';
@@ -1,6 +1,6 @@
1
1
  import type { AudioCodec } from './audio-codec';
2
2
  import type { Codec } from './codec';
3
3
  import type { FileExtension } from './file-extensions';
4
- export declare const getFileExtensionFromCodec: <T extends "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif">(codec: T, audioCodec: AudioCodec | null) => FileExtension;
5
- export declare const makeFileExtensionMap: () => Record<string, ("aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif")[]>;
4
+ export declare const getFileExtensionFromCodec: <T extends "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif">(codec: T, audioCodec: AudioCodec | null) => FileExtension;
5
+ export declare const makeFileExtensionMap: () => Record<string, ("h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif")[]>;
6
6
  export declare const defaultCodecsForFileExtension: Record<FileExtension, Codec>;
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import type { OffthreadVideoImageFormat } from 'remotion';
2
3
  import type { SpecialVCodecForTransparency } from './assets/download-map';
3
4
  import type { FfmpegExecutable } from './ffmpeg-executable';
@@ -7,10 +8,7 @@ export declare const getFrameOfVideoSlow: ({ src, duration, ffmpegExecutable, im
7
8
  duration: number;
8
9
  imageFormat: OffthreadVideoImageFormat;
9
10
  specialVCodecForTransparency: SpecialVCodecForTransparency;
10
- needsResize: [
11
- number,
12
- number
13
- ] | null;
11
+ needsResize: [number, number] | null;
14
12
  offset: number;
15
13
  fps: number | null;
16
14
  remotionRoot: string;
package/dist/index.d.ts CHANGED
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import execa from 'execa';
2
3
  import { SymbolicateableError } from './error-handling/symbolicateable-error';
3
4
  import { mimeContentType, mimeLookup } from './mime-types';
@@ -59,9 +60,9 @@ export declare const RenderInternals: {
59
60
  width: number;
60
61
  height: number;
61
62
  scale: number;
62
- codec: "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif";
63
+ codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif";
63
64
  }) => void;
64
- getFileExtensionFromCodec: <T extends "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif">(codec: T, audioCodec: "pcm-16" | "aac" | "mp3" | "opus" | null) => import("./file-extensions").FileExtension;
65
+ getFileExtensionFromCodec: <T extends "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif">(codec: T, audioCodec: "mp3" | "aac" | "pcm-16" | "opus" | null) => import("./file-extensions").FileExtension;
65
66
  tmpDir: (str: string) => string;
66
67
  deleteDirectory: (directory: string) => void;
67
68
  isServeUrl: (potentialUrl: string) => boolean;
@@ -111,24 +112,24 @@ export declare const RenderInternals: {
111
112
  };
112
113
  registerErrorSymbolicationLock: () => number;
113
114
  unlockErrorSymbolicationLock: (id: number) => void;
114
- canUseParallelEncoding: (codec: "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif") => boolean;
115
+ canUseParallelEncoding: (codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif") => boolean;
115
116
  mimeContentType: typeof mimeContentType;
116
117
  mimeLookup: typeof mimeLookup;
117
118
  validateConcurrency: (value: unknown, setting: string) => void;
118
119
  validPixelFormats: readonly ["yuv420p", "yuva420p", "yuv422p", "yuv444p", "yuv420p10le", "yuv422p10le", "yuv444p10le", "yuva444p10le"];
119
120
  DEFAULT_BROWSER: import("./browser").Browser;
120
121
  validateFrameRange: (frameRange: import("./frame-range").FrameRange | null) => void;
121
- DEFAULT_OPENGL_RENDERER: "swangle" | "angle" | "egl" | "swiftshader" | null;
122
- validateOpenGlRenderer: (option: "swangle" | "angle" | "egl" | "swiftshader" | null) => "swangle" | "angle" | "egl" | "swiftshader" | null;
122
+ DEFAULT_OPENGL_RENDERER: "angle" | "swangle" | "egl" | "swiftshader" | null;
123
+ validateOpenGlRenderer: (option: "angle" | "swangle" | "egl" | "swiftshader" | null) => "angle" | "swangle" | "egl" | "swiftshader" | null;
123
124
  validImageFormats: readonly ["png", "jpeg", "none"];
124
125
  validCodecs: readonly ["h264", "h265", "vp8", "vp9", "mp3", "aac", "wav", "prores", "h264-mkv", "gif"];
125
126
  DEFAULT_PIXEL_FORMAT: "yuv420p" | "yuva420p" | "yuv422p" | "yuv444p" | "yuv420p10le" | "yuv422p10le" | "yuv444p10le" | "yuva444p10le";
126
127
  validateQuality: (q: number | undefined) => void;
127
128
  DEFAULT_TIMEOUT: number;
128
- DEFAULT_CODEC: "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif";
129
- isAudioCodec: (codec: "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif" | undefined) => boolean;
129
+ DEFAULT_CODEC: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif";
130
+ isAudioCodec: (codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif" | undefined) => boolean;
130
131
  logLevels: readonly ["verbose", "info", "warn", "error"];
131
- isEqualOrBelowLogLevel: (currentLevel: "verbose" | "info" | "warn" | "error", level: "verbose" | "info" | "warn" | "error") => boolean;
132
+ isEqualOrBelowLogLevel: (currentLevel: "error" | "verbose" | "info" | "warn", level: "error" | "verbose" | "info" | "warn") => boolean;
132
133
  isValidLogLevel: (level: string) => boolean;
133
134
  perf: typeof perf;
134
135
  makeDownloadMap: () => import("./assets/download-map").DownloadMap;
@@ -150,92 +151,92 @@ export declare const RenderInternals: {
150
151
  output: string;
151
152
  onProgress: (p: number) => void;
152
153
  numberOfFrames: number;
153
- codec: "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif";
154
+ codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif";
154
155
  fps: number;
155
156
  numberOfGifLoops: number | null;
156
157
  remotionRoot: string;
157
158
  ffmpegExecutable: import("./ffmpeg-executable").FfmpegExecutable;
158
- audioCodec: "pcm-16" | "aac" | "mp3" | "opus" | null;
159
+ audioCodec: "mp3" | "aac" | "pcm-16" | "opus" | null;
159
160
  }) => Promise<void>;
160
161
  getDefaultAudioCodec: ({ codec, preferLossless, }: {
161
- codec: "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif";
162
+ codec: "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif";
162
163
  preferLossless: boolean;
163
- }) => "pcm-16" | "aac" | "mp3" | "opus" | null;
164
+ }) => "mp3" | "aac" | "pcm-16" | "opus" | null;
164
165
  validAudioCodecs: readonly ["pcm-16", "aac", "mp3", "opus"];
165
166
  defaultFileExtensionMap: {
166
- aac: {
167
+ h264: {
167
168
  default: import("./file-extensions").FileExtension;
168
169
  forAudioCodec: {
169
- "pcm-16": {
170
+ aac: {
170
171
  possible: import("./file-extensions").FileExtension[];
171
172
  default: import("./file-extensions").FileExtension;
172
173
  };
173
- aac: {
174
+ "pcm-16": {
174
175
  possible: import("./file-extensions").FileExtension[];
175
176
  default: import("./file-extensions").FileExtension;
176
177
  };
177
178
  };
178
179
  };
179
- mp3: {
180
+ h265: {
180
181
  default: import("./file-extensions").FileExtension;
181
182
  forAudioCodec: {
182
- "pcm-16": {
183
+ aac: {
183
184
  possible: import("./file-extensions").FileExtension[];
184
185
  default: import("./file-extensions").FileExtension;
185
186
  };
186
- mp3: {
187
+ "pcm-16": {
187
188
  possible: import("./file-extensions").FileExtension[];
188
189
  default: import("./file-extensions").FileExtension;
189
190
  };
190
191
  };
191
192
  };
192
- h264: {
193
+ vp8: {
193
194
  default: import("./file-extensions").FileExtension;
194
195
  forAudioCodec: {
195
196
  "pcm-16": {
196
197
  possible: import("./file-extensions").FileExtension[];
197
198
  default: import("./file-extensions").FileExtension;
198
199
  };
199
- aac: {
200
+ opus: {
200
201
  possible: import("./file-extensions").FileExtension[];
201
202
  default: import("./file-extensions").FileExtension;
202
203
  };
203
204
  };
204
205
  };
205
- h265: {
206
+ vp9: {
206
207
  default: import("./file-extensions").FileExtension;
207
208
  forAudioCodec: {
208
209
  "pcm-16": {
209
210
  possible: import("./file-extensions").FileExtension[];
210
211
  default: import("./file-extensions").FileExtension;
211
212
  };
212
- aac: {
213
+ opus: {
213
214
  possible: import("./file-extensions").FileExtension[];
214
215
  default: import("./file-extensions").FileExtension;
215
216
  };
216
217
  };
217
218
  };
218
- vp8: {
219
+ mp3: {
219
220
  default: import("./file-extensions").FileExtension;
220
221
  forAudioCodec: {
221
- "pcm-16": {
222
+ mp3: {
222
223
  possible: import("./file-extensions").FileExtension[];
223
224
  default: import("./file-extensions").FileExtension;
224
225
  };
225
- opus: {
226
+ "pcm-16": {
226
227
  possible: import("./file-extensions").FileExtension[];
227
228
  default: import("./file-extensions").FileExtension;
228
229
  };
229
230
  };
230
231
  };
231
- vp9: {
232
+ aac: {
232
233
  default: import("./file-extensions").FileExtension;
233
234
  forAudioCodec: {
234
- "pcm-16": {
235
+ aac: {
235
236
  possible: import("./file-extensions").FileExtension[];
236
237
  default: import("./file-extensions").FileExtension;
237
238
  };
238
- opus: {
239
+ "pcm-16": {
239
240
  possible: import("./file-extensions").FileExtension[];
240
241
  default: import("./file-extensions").FileExtension;
241
242
  };
@@ -253,11 +254,11 @@ export declare const RenderInternals: {
253
254
  prores: {
254
255
  default: import("./file-extensions").FileExtension;
255
256
  forAudioCodec: {
256
- "pcm-16": {
257
+ aac: {
257
258
  possible: import("./file-extensions").FileExtension[];
258
259
  default: import("./file-extensions").FileExtension;
259
260
  };
260
- aac: {
261
+ "pcm-16": {
261
262
  possible: import("./file-extensions").FileExtension[];
262
263
  default: import("./file-extensions").FileExtension;
263
264
  };
@@ -289,6 +290,6 @@ export declare const RenderInternals: {
289
290
  readonly vp9: readonly ["opus", "pcm-16"];
290
291
  readonly wav: readonly ["pcm-16"];
291
292
  };
292
- makeFileExtensionMap: () => Record<string, ("aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif")[]>;
293
- defaultCodecsForFileExtension: Record<import("./file-extensions").FileExtension, "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif">;
293
+ makeFileExtensionMap: () => Record<string, ("h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif")[]>;
294
+ defaultCodecsForFileExtension: Record<import("./file-extensions").FileExtension, "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif">;
294
295
  };
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import type { OffthreadVideoImageFormat } from 'remotion';
2
3
  import type { DownloadMap, SpecialVCodecForTransparency } from './assets/download-map';
3
4
  import type { FfmpegExecutable } from './ffmpeg-executable';
@@ -5,7 +5,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.mergeAudioTrack = void 0;
7
7
  const execa_1 = __importDefault(require("execa"));
8
- const fs_1 = require("fs");
9
8
  const path_1 = __importDefault(require("path"));
10
9
  const chunk_1 = require("./chunk");
11
10
  const create_ffmpeg_complex_filter_1 = require("./create-ffmpeg-complex-filter");
@@ -26,10 +25,7 @@ const mergeAudioTrackUnlimited = async ({ ffmpegExecutable, outName, files, numb
26
25
  });
27
26
  return;
28
27
  }
29
- if (files.length === 1) {
30
- (0, fs_1.copyFileSync)(files[0].outName, outName);
31
- return;
32
- }
28
+ // Previously a bug: We cannot optimize for files.length === 1 because we need to pad the audio
33
29
  // In FFMPEG, the total number of left and right tracks that can be merged at one time is limited to 64
34
30
  if (files.length >= 32) {
35
31
  const chunked = (0, chunk_1.chunk)(files, 10);
@@ -0,0 +1,7 @@
1
+ import type React from 'react';
2
+ export declare type RemotionOption = {
3
+ name: string;
4
+ cliFlag: string;
5
+ ssrName: string;
6
+ description: React.ReactNode;
7
+ };
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,7 @@
1
+ import type React from 'react';
2
+ export declare type RemotionOption = {
3
+ name: string;
4
+ cliFlag: string;
5
+ ssrName: string;
6
+ description: React.ReactNode;
7
+ };
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,2 @@
1
+ import type { RemotionOption } from './option';
2
+ export declare const scaleOption: RemotionOption;
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.scaleOption = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ exports.scaleOption = {
6
+ name: 'Scale',
7
+ cliFlag: '--scale',
8
+ description: ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: ["Scales the output by a factor. For example, a 1280x720px frame will become a 1920x1080px frame with a scale factor of ", (0, jsx_runtime_1.jsx)("code", { children: "1.5" }), ". Vector elements like fonts and HTML markups will be rendered with extra details."] })),
9
+ ssrName: 'scale',
10
+ };
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import type { ClipRegion } from 'remotion';
2
3
  import type { Page } from './browser/BrowserPage';
3
4
  import type { ImageFormat } from './image-format';
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import type { ClipRegion } from 'remotion';
2
3
  import type { Page } from './browser/BrowserPage';
3
4
  export declare const screenshot: (options: {
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import type { SmallTCompMetadata } from 'remotion';
2
3
  import type { RenderMediaOnDownload } from './assets/download-and-map-assets-to-file';
3
4
  import type { DownloadMap } from './assets/download-map';
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import type { ClipRegion } from 'remotion';
2
3
  import type { Page } from './browser/BrowserPage';
3
4
  import type { ImageFormat } from './image-format';
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import type { ClipRegion } from 'remotion';
2
3
  import type { Page } from './browser/BrowserPage';
3
4
  import type { StillImageFormat } from './image-format';
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import type { TAsset } from 'remotion';
2
3
  import type { DownloadMap } from './assets/download-map';
3
4
  import type { Page } from './browser/BrowserPage';
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import type { OffthreadVideoImageFormat } from 'remotion';
2
3
  import type { NeedsResize, SpecialVCodecForTransparency } from './assets/download-map';
3
4
  import type { FfmpegExecutable } from './ffmpeg-executable';
@@ -0,0 +1 @@
1
+ export declare const validateFrame: (frame: number, durationInFrames: number) => void;
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.validateFrame = void 0;
4
+ const validateFrame = (frame, durationInFrames) => {
5
+ if (typeof frame === 'undefined') {
6
+ throw new TypeError(`Argument missing for parameter "frame"`);
7
+ }
8
+ if (typeof frame !== 'number') {
9
+ throw new TypeError(`Argument passed for "frame" is not a number: ${frame}`);
10
+ }
11
+ if (!Number.isFinite(frame)) {
12
+ throw new RangeError(`Frame ${frame} is not finite`);
13
+ }
14
+ if (frame % 1 !== 0) {
15
+ throw new RangeError(`Argument for frame must be an integer, but got ${frame}`);
16
+ }
17
+ if (frame < 0 && frame < -durationInFrames) {
18
+ throw new RangeError(`Cannot use frame ${frame}: Duration of composition is ${durationInFrames}, therefore the lowest frame that can be rendered is ${-durationInFrames}`);
19
+ }
20
+ if (frame > durationInFrames - 1) {
21
+ throw new RangeError(`Cannot use frame ${frame}: Duration of composition is ${durationInFrames}, therefore the highest frame that can be rendered is ${durationInFrames - 1}`);
22
+ }
23
+ };
24
+ exports.validateFrame = validateFrame;
@@ -1,5 +1,5 @@
1
1
  import type { AudioCodec } from './audio-codec';
2
- export declare const validateOutputFilename: <T extends "aac" | "mp3" | "h264" | "h265" | "vp8" | "vp9" | "wav" | "prores" | "h264-mkv" | "gif">({ codec, audioCodec, extension, preferLossless, }: {
2
+ export declare const validateOutputFilename: <T extends "h264" | "h265" | "vp8" | "vp9" | "mp3" | "aac" | "wav" | "prores" | "h264-mkv" | "gif">({ codec, audioCodec, extension, preferLossless, }: {
3
3
  codec: T;
4
4
  audioCodec: AudioCodec | null;
5
5
  extension: string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@remotion/renderer",
3
- "version": "3.3.77",
3
+ "version": "3.3.78",
4
4
  "description": "Renderer for Remotion",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -16,7 +16,7 @@
16
16
  "dependencies": {
17
17
  "execa": "5.1.1",
18
18
  "extract-zip": "2.0.1",
19
- "remotion": "3.3.77",
19
+ "remotion": "3.3.78",
20
20
  "source-map": "^0.8.0-beta.0",
21
21
  "ws": "8.7.0"
22
22
  },
@@ -41,13 +41,13 @@
41
41
  "vitest": "0.24.3"
42
42
  },
43
43
  "optionalDependencies": {
44
- "@remotion/compositor-darwin-arm64": "3.3.77",
45
- "@remotion/compositor-darwin-x64": "3.3.77",
46
- "@remotion/compositor-linux-arm64-gnu": "3.3.77",
47
- "@remotion/compositor-linux-arm64-musl": "3.3.77",
48
- "@remotion/compositor-linux-x64-gnu": "3.3.77",
49
- "@remotion/compositor-linux-x64-musl": "3.3.77",
50
- "@remotion/compositor-win32-x64-msvc": "3.3.77"
44
+ "@remotion/compositor-darwin-arm64": "3.3.78",
45
+ "@remotion/compositor-darwin-x64": "3.3.78",
46
+ "@remotion/compositor-linux-arm64-gnu": "3.3.78",
47
+ "@remotion/compositor-linux-arm64-musl": "3.3.78",
48
+ "@remotion/compositor-linux-x64-gnu": "3.3.78",
49
+ "@remotion/compositor-linux-x64-musl": "3.3.78",
50
+ "@remotion/compositor-win32-x64-msvc": "3.3.78"
51
51
  },
52
52
  "keywords": [
53
53
  "remotion",