remotion 3.3.52 → 3.3.53

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 (194) hide show
  1. package/dist/cjs/version.d.ts +1 -1
  2. package/dist/cjs/version.js +1 -1
  3. package/dist/esm/version.d.ts +1 -1
  4. package/dist/esm/version.js +1 -1
  5. package/dist/tsconfig-cjs.tsbuildinfo +1 -1
  6. package/package.json +2 -2
  7. package/dist/AbsoluteFill.d.ts +0 -6
  8. package/dist/AbsoluteFill.js +0 -28
  9. package/dist/CanUseRemotionHooks.d.ts +0 -5
  10. package/dist/CanUseRemotionHooks.js +0 -10
  11. package/dist/Clipper.d.ts +0 -7
  12. package/dist/Clipper.js +0 -24
  13. package/dist/Composition.d.ts +0 -23
  14. package/dist/Composition.js +0 -113
  15. package/dist/CompositionManager.d.ts +0 -82
  16. package/dist/CompositionManager.js +0 -164
  17. package/dist/Folder.d.ts +0 -15
  18. package/dist/Folder.js +0 -33
  19. package/dist/IFrame.d.ts +0 -2
  20. package/dist/IFrame.js +0 -24
  21. package/dist/Img.d.ts +0 -2
  22. package/dist/Img.js +0 -52
  23. package/dist/NativeLayers.d.ts +0 -13
  24. package/dist/NativeLayers.js +0 -29
  25. package/dist/Null.d.ts +0 -2
  26. package/dist/Null.js +0 -25
  27. package/dist/RemotionRoot.d.ts +0 -5
  28. package/dist/RemotionRoot.js +0 -73
  29. package/dist/Sequence.d.ts +0 -29
  30. package/dist/Sequence.js +0 -131
  31. package/dist/Still.d.ts +0 -2
  32. package/dist/Still.js +0 -9
  33. package/dist/absolute-src.d.ts +0 -1
  34. package/dist/absolute-src.js +0 -7
  35. package/dist/asset-types.d.ts +0 -50
  36. package/dist/asset-types.js +0 -1
  37. package/dist/audio/Audio.d.ts +0 -8
  38. package/dist/audio/Audio.js +0 -52
  39. package/dist/audio/AudioForDevelopment.d.ts +0 -11
  40. package/dist/audio/AudioForDevelopment.js +0 -94
  41. package/dist/audio/AudioForRendering.d.ts +0 -10
  42. package/dist/audio/AudioForRendering.js +0 -111
  43. package/dist/audio/index.d.ts +0 -2
  44. package/dist/audio/index.js +0 -18
  45. package/dist/audio/props.d.ts +0 -12
  46. package/dist/audio/props.js +0 -2
  47. package/dist/audio/shared-audio-tags.d.ts +0 -37
  48. package/dist/audio/shared-audio-tags.js +0 -222
  49. package/dist/audio/use-audio-frame.d.ts +0 -6
  50. package/dist/audio/use-audio-frame.js +0 -23
  51. package/dist/bezier.d.ts +0 -1
  52. package/dist/bezier.js +0 -114
  53. package/dist/cancel-render.d.ts +0 -1
  54. package/dist/cancel-render.js +0 -43
  55. package/dist/config/input-props.d.ts +0 -1
  56. package/dist/config/input-props.js +0 -31
  57. package/dist/config.d.ts +0 -285
  58. package/dist/config.js +0 -21
  59. package/dist/default-css.d.ts +0 -3
  60. package/dist/default-css.js +0 -49
  61. package/dist/delay-render.d.ts +0 -14
  62. package/dist/delay-render.js +0 -77
  63. package/dist/easing.d.ts +0 -19
  64. package/dist/easing.js +0 -77
  65. package/dist/freeze.d.ts +0 -7
  66. package/dist/freeze.js +0 -34
  67. package/dist/get-asset-file-name.d.ts +0 -1
  68. package/dist/get-asset-file-name.js +0 -14
  69. package/dist/get-environment.d.ts +0 -3
  70. package/dist/get-environment.js +0 -34
  71. package/dist/get-preview-dom-element.d.ts +0 -1
  72. package/dist/get-preview-dom-element.js +0 -7
  73. package/dist/get-static-files.d.ts +0 -17
  74. package/dist/get-static-files.js +0 -31
  75. package/dist/get-timeline-clip-name.d.ts +0 -1
  76. package/dist/get-timeline-clip-name.js +0 -25
  77. package/dist/index.d.ts +0 -92
  78. package/dist/index.js +0 -73
  79. package/dist/internals.d.ts +0 -97
  80. package/dist/internals.js +0 -99
  81. package/dist/interpolate-colors.d.ts +0 -5
  82. package/dist/interpolate-colors.js +0 -401
  83. package/dist/interpolate.d.ts +0 -18
  84. package/dist/interpolate.js +0 -123
  85. package/dist/is-approximately-the-same.d.ts +0 -1
  86. package/dist/is-approximately-the-same.js +0 -8
  87. package/dist/is-player.d.ts +0 -3
  88. package/dist/is-player.js +0 -14
  89. package/dist/loading-indicator.d.ts +0 -2
  90. package/dist/loading-indicator.js +0 -35
  91. package/dist/loop/index.d.ts +0 -9
  92. package/dist/loop/index.js +0 -29
  93. package/dist/multiple-versions-warning.d.ts +0 -1
  94. package/dist/multiple-versions-warning.js +0 -32
  95. package/dist/nonce.d.ts +0 -7
  96. package/dist/nonce.js +0 -17
  97. package/dist/play-and-handle-not-allowed-error.d.ts +0 -2
  98. package/dist/play-and-handle-not-allowed-error.js +0 -44
  99. package/dist/portal-node.d.ts +0 -1
  100. package/dist/portal-node.js +0 -23
  101. package/dist/prefetch-state.d.ts +0 -8
  102. package/dist/prefetch-state.js +0 -27
  103. package/dist/prefetch.d.ts +0 -9
  104. package/dist/prefetch.js +0 -108
  105. package/dist/random.d.ts +0 -7
  106. package/dist/random.js +0 -41
  107. package/dist/register-root.d.ts +0 -4
  108. package/dist/register-root.js +0 -33
  109. package/dist/series/flatten-children.d.ts +0 -2
  110. package/dist/series/flatten-children.js +0 -19
  111. package/dist/series/index.d.ts +0 -13
  112. package/dist/series/index.js +0 -60
  113. package/dist/setup-env-variables.d.ts +0 -2
  114. package/dist/setup-env-variables.js +0 -36
  115. package/dist/spring/index.d.ts +0 -27
  116. package/dist/spring/index.js +0 -51
  117. package/dist/spring/measure-spring.d.ts +0 -8
  118. package/dist/spring/measure-spring.js +0 -64
  119. package/dist/spring/spring-utils.d.ts +0 -21
  120. package/dist/spring/spring-utils.js +0 -103
  121. package/dist/static-file.d.ts +0 -5
  122. package/dist/static-file.js +0 -33
  123. package/dist/timeline-position-state.d.ts +0 -29
  124. package/dist/timeline-position-state.js +0 -41
  125. package/dist/truthy.d.ts +0 -3
  126. package/dist/truthy.js +0 -7
  127. package/dist/use-current-frame.d.ts +0 -6
  128. package/dist/use-current-frame.js +0 -28
  129. package/dist/use-lazy-component.d.ts +0 -7
  130. package/dist/use-lazy-component.js +0 -49
  131. package/dist/use-media-in-timeline.d.ts +0 -10
  132. package/dist/use-media-in-timeline.js +0 -129
  133. package/dist/use-media-playback.d.ts +0 -10
  134. package/dist/use-media-playback.js +0 -77
  135. package/dist/use-media-tag-volume.d.ts +0 -2
  136. package/dist/use-media-tag-volume.js +0 -31
  137. package/dist/use-sync-volume-with-media-tag.d.ts +0 -10
  138. package/dist/use-sync-volume-with-media-tag.js +0 -21
  139. package/dist/use-unsafe-video-config.d.ts +0 -2
  140. package/dist/use-unsafe-video-config.js +0 -27
  141. package/dist/use-video-config.d.ts +0 -7
  142. package/dist/use-video-config.js +0 -29
  143. package/dist/use-video.d.ts +0 -12
  144. package/dist/use-video.js +0 -28
  145. package/dist/validate-media-props.d.ts +0 -4
  146. package/dist/validate-media-props.js +0 -24
  147. package/dist/validate-start-from-props.d.ts +0 -1
  148. package/dist/validate-start-from-props.js +0 -31
  149. package/dist/validation/validate-composition-id.d.ts +0 -3
  150. package/dist/validation/validate-composition-id.js +0 -13
  151. package/dist/validation/validate-dimensions.d.ts +0 -1
  152. package/dist/validation/validate-dimensions.js +0 -21
  153. package/dist/validation/validate-duration-in-frames.d.ts +0 -1
  154. package/dist/validation/validate-duration-in-frames.js +0 -15
  155. package/dist/validation/validate-folder-name.d.ts +0 -3
  156. package/dist/validation/validate-folder-name.js +0 -19
  157. package/dist/validation/validate-fps.d.ts +0 -1
  158. package/dist/validation/validate-fps.js +0 -21
  159. package/dist/validation/validate-offthreadvideo-image-format.d.ts +0 -1
  160. package/dist/validation/validate-offthreadvideo-image-format.js +0 -15
  161. package/dist/validation/validation-spring-duration.d.ts +0 -1
  162. package/dist/validation/validation-spring-duration.js +0 -21
  163. package/dist/version.d.ts +0 -1
  164. package/dist/version.js +0 -5
  165. package/dist/video/OffthreadVideo.d.ts +0 -3
  166. package/dist/video/OffthreadVideo.js +0 -33
  167. package/dist/video/OffthreadVideoForRendering.d.ts +0 -3
  168. package/dist/video/OffthreadVideoForRendering.js +0 -104
  169. package/dist/video/Video.d.ts +0 -8
  170. package/dist/video/Video.js +0 -50
  171. package/dist/video/VideoForDevelopment.d.ts +0 -11
  172. package/dist/video/VideoForDevelopment.js +0 -113
  173. package/dist/video/VideoForRendering.d.ts +0 -10
  174. package/dist/video/VideoForRendering.js +0 -203
  175. package/dist/video/duration-state.d.ts +0 -17
  176. package/dist/video/duration-state.js +0 -34
  177. package/dist/video/get-current-time.d.ts +0 -13
  178. package/dist/video/get-current-time.js +0 -31
  179. package/dist/video/index.d.ts +0 -3
  180. package/dist/video/index.js +0 -7
  181. package/dist/video/props.d.ts +0 -25
  182. package/dist/video/props.js +0 -2
  183. package/dist/video/video-fragment.d.ts +0 -12
  184. package/dist/video/video-fragment.js +0 -60
  185. package/dist/video-config.d.ts +0 -8
  186. package/dist/video-config.js +0 -2
  187. package/dist/volume-position-state.d.ts +0 -19
  188. package/dist/volume-position-state.js +0 -32
  189. package/dist/volume-prop.d.ts +0 -7
  190. package/dist/volume-prop.js +0 -24
  191. package/dist/warn-about-non-seekable-media.d.ts +0 -1
  192. package/dist/warn-about-non-seekable-media.js +0 -34
  193. package/dist/wrap-remotion-context.d.ts +0 -18
  194. package/dist/wrap-remotion-context.js +0 -73
@@ -1,401 +0,0 @@
1
- "use strict";
2
- /**
3
- * Copied from:
4
- * https://github.com/software-mansion/react-native-reanimated/blob/master/src/reanimated2/Colors.ts
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.interpolateColors = void 0;
8
- /* eslint no-bitwise: 0 */
9
- const interpolate_1 = require("./interpolate");
10
- // var INTEGER = '[-+]?\\d+';
11
- const NUMBER = '[-+]?\\d*\\.?\\d+';
12
- const PERCENTAGE = NUMBER + '%';
13
- function call(...args) {
14
- return '\\(\\s*(' + args.join(')\\s*,\\s*(') + ')\\s*\\)';
15
- }
16
- function getMatchers() {
17
- const cachedMatchers = {
18
- rgb: undefined,
19
- rgba: undefined,
20
- hsl: undefined,
21
- hsla: undefined,
22
- hex3: undefined,
23
- hex4: undefined,
24
- hex5: undefined,
25
- hex6: undefined,
26
- hex8: undefined,
27
- };
28
- if (cachedMatchers.rgb === undefined) {
29
- cachedMatchers.rgb = new RegExp('rgb' + call(NUMBER, NUMBER, NUMBER));
30
- cachedMatchers.rgba = new RegExp('rgba' + call(NUMBER, NUMBER, NUMBER, NUMBER));
31
- cachedMatchers.hsl = new RegExp('hsl' + call(NUMBER, PERCENTAGE, PERCENTAGE));
32
- cachedMatchers.hsla = new RegExp('hsla' + call(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER));
33
- cachedMatchers.hex3 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;
34
- cachedMatchers.hex4 =
35
- /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;
36
- cachedMatchers.hex6 = /^#([0-9a-fA-F]{6})$/;
37
- cachedMatchers.hex8 = /^#([0-9a-fA-F]{8})$/;
38
- }
39
- return cachedMatchers;
40
- }
41
- function hue2rgb(p, q, t) {
42
- if (t < 0) {
43
- t += 1;
44
- }
45
- if (t > 1) {
46
- t -= 1;
47
- }
48
- if (t < 1 / 6) {
49
- return p + (q - p) * 6 * t;
50
- }
51
- if (t < 1 / 2) {
52
- return q;
53
- }
54
- if (t < 2 / 3) {
55
- return p + (q - p) * (2 / 3 - t) * 6;
56
- }
57
- return p;
58
- }
59
- function hslToRgb(h, s, l) {
60
- const q = l < 0.5 ? l * (1 + s) : l + s - l * s;
61
- const p = 2 * l - q;
62
- const r = hue2rgb(p, q, h + 1 / 3);
63
- const g = hue2rgb(p, q, h);
64
- const b = hue2rgb(p, q, h - 1 / 3);
65
- return ((Math.round(r * 255) << 24) |
66
- (Math.round(g * 255) << 16) |
67
- (Math.round(b * 255) << 8));
68
- }
69
- function parse255(str) {
70
- const int = Number.parseInt(str, 10);
71
- if (int < 0) {
72
- return 0;
73
- }
74
- if (int > 255) {
75
- return 255;
76
- }
77
- return int;
78
- }
79
- function parse360(str) {
80
- const int = Number.parseFloat(str);
81
- return (((int % 360) + 360) % 360) / 360;
82
- }
83
- function parse1(str) {
84
- const num = Number.parseFloat(str);
85
- if (num < 0) {
86
- return 0;
87
- }
88
- if (num > 1) {
89
- return 255;
90
- }
91
- return Math.round(num * 255);
92
- }
93
- function parsePercentage(str) {
94
- // parseFloat conveniently ignores the final %
95
- const int = Number.parseFloat(str);
96
- if (int < 0) {
97
- return 0;
98
- }
99
- if (int > 100) {
100
- return 1;
101
- }
102
- return int / 100;
103
- }
104
- const names = {
105
- transparent: 0x00000000,
106
- // http://www.w3.org/TR/css3-color/#svg-color
107
- aliceblue: 0xf0f8ffff,
108
- antiquewhite: 0xfaebd7ff,
109
- aqua: 0x00ffffff,
110
- aquamarine: 0x7fffd4ff,
111
- azure: 0xf0ffffff,
112
- beige: 0xf5f5dcff,
113
- bisque: 0xffe4c4ff,
114
- black: 0x000000ff,
115
- blanchedalmond: 0xffebcdff,
116
- blue: 0x0000ffff,
117
- blueviolet: 0x8a2be2ff,
118
- brown: 0xa52a2aff,
119
- burlywood: 0xdeb887ff,
120
- burntsienna: 0xea7e5dff,
121
- cadetblue: 0x5f9ea0ff,
122
- chartreuse: 0x7fff00ff,
123
- chocolate: 0xd2691eff,
124
- coral: 0xff7f50ff,
125
- cornflowerblue: 0x6495edff,
126
- cornsilk: 0xfff8dcff,
127
- crimson: 0xdc143cff,
128
- cyan: 0x00ffffff,
129
- darkblue: 0x00008bff,
130
- darkcyan: 0x008b8bff,
131
- darkgoldenrod: 0xb8860bff,
132
- darkgray: 0xa9a9a9ff,
133
- darkgreen: 0x006400ff,
134
- darkgrey: 0xa9a9a9ff,
135
- darkkhaki: 0xbdb76bff,
136
- darkmagenta: 0x8b008bff,
137
- darkolivegreen: 0x556b2fff,
138
- darkorange: 0xff8c00ff,
139
- darkorchid: 0x9932ccff,
140
- darkred: 0x8b0000ff,
141
- darksalmon: 0xe9967aff,
142
- darkseagreen: 0x8fbc8fff,
143
- darkslateblue: 0x483d8bff,
144
- darkslategray: 0x2f4f4fff,
145
- darkslategrey: 0x2f4f4fff,
146
- darkturquoise: 0x00ced1ff,
147
- darkviolet: 0x9400d3ff,
148
- deeppink: 0xff1493ff,
149
- deepskyblue: 0x00bfffff,
150
- dimgray: 0x696969ff,
151
- dimgrey: 0x696969ff,
152
- dodgerblue: 0x1e90ffff,
153
- firebrick: 0xb22222ff,
154
- floralwhite: 0xfffaf0ff,
155
- forestgreen: 0x228b22ff,
156
- fuchsia: 0xff00ffff,
157
- gainsboro: 0xdcdcdcff,
158
- ghostwhite: 0xf8f8ffff,
159
- gold: 0xffd700ff,
160
- goldenrod: 0xdaa520ff,
161
- gray: 0x808080ff,
162
- green: 0x008000ff,
163
- greenyellow: 0xadff2fff,
164
- grey: 0x808080ff,
165
- honeydew: 0xf0fff0ff,
166
- hotpink: 0xff69b4ff,
167
- indianred: 0xcd5c5cff,
168
- indigo: 0x4b0082ff,
169
- ivory: 0xfffff0ff,
170
- khaki: 0xf0e68cff,
171
- lavender: 0xe6e6faff,
172
- lavenderblush: 0xfff0f5ff,
173
- lawngreen: 0x7cfc00ff,
174
- lemonchiffon: 0xfffacdff,
175
- lightblue: 0xadd8e6ff,
176
- lightcoral: 0xf08080ff,
177
- lightcyan: 0xe0ffffff,
178
- lightgoldenrodyellow: 0xfafad2ff,
179
- lightgray: 0xd3d3d3ff,
180
- lightgreen: 0x90ee90ff,
181
- lightgrey: 0xd3d3d3ff,
182
- lightpink: 0xffb6c1ff,
183
- lightsalmon: 0xffa07aff,
184
- lightseagreen: 0x20b2aaff,
185
- lightskyblue: 0x87cefaff,
186
- lightslategray: 0x778899ff,
187
- lightslategrey: 0x778899ff,
188
- lightsteelblue: 0xb0c4deff,
189
- lightyellow: 0xffffe0ff,
190
- lime: 0x00ff00ff,
191
- limegreen: 0x32cd32ff,
192
- linen: 0xfaf0e6ff,
193
- magenta: 0xff00ffff,
194
- maroon: 0x800000ff,
195
- mediumaquamarine: 0x66cdaaff,
196
- mediumblue: 0x0000cdff,
197
- mediumorchid: 0xba55d3ff,
198
- mediumpurple: 0x9370dbff,
199
- mediumseagreen: 0x3cb371ff,
200
- mediumslateblue: 0x7b68eeff,
201
- mediumspringgreen: 0x00fa9aff,
202
- mediumturquoise: 0x48d1ccff,
203
- mediumvioletred: 0xc71585ff,
204
- midnightblue: 0x191970ff,
205
- mintcream: 0xf5fffaff,
206
- mistyrose: 0xffe4e1ff,
207
- moccasin: 0xffe4b5ff,
208
- navajowhite: 0xffdeadff,
209
- navy: 0x000080ff,
210
- oldlace: 0xfdf5e6ff,
211
- olive: 0x808000ff,
212
- olivedrab: 0x6b8e23ff,
213
- orange: 0xffa500ff,
214
- orangered: 0xff4500ff,
215
- orchid: 0xda70d6ff,
216
- palegoldenrod: 0xeee8aaff,
217
- palegreen: 0x98fb98ff,
218
- paleturquoise: 0xafeeeeff,
219
- palevioletred: 0xdb7093ff,
220
- papayawhip: 0xffefd5ff,
221
- peachpuff: 0xffdab9ff,
222
- peru: 0xcd853fff,
223
- pink: 0xffc0cbff,
224
- plum: 0xdda0ddff,
225
- powderblue: 0xb0e0e6ff,
226
- purple: 0x800080ff,
227
- rebeccapurple: 0x663399ff,
228
- red: 0xff0000ff,
229
- rosybrown: 0xbc8f8fff,
230
- royalblue: 0x4169e1ff,
231
- saddlebrown: 0x8b4513ff,
232
- salmon: 0xfa8072ff,
233
- sandybrown: 0xf4a460ff,
234
- seagreen: 0x2e8b57ff,
235
- seashell: 0xfff5eeff,
236
- sienna: 0xa0522dff,
237
- silver: 0xc0c0c0ff,
238
- skyblue: 0x87ceebff,
239
- slateblue: 0x6a5acdff,
240
- slategray: 0x708090ff,
241
- slategrey: 0x708090ff,
242
- snow: 0xfffafaff,
243
- springgreen: 0x00ff7fff,
244
- steelblue: 0x4682b4ff,
245
- tan: 0xd2b48cff,
246
- teal: 0x008080ff,
247
- thistle: 0xd8bfd8ff,
248
- tomato: 0xff6347ff,
249
- turquoise: 0x40e0d0ff,
250
- violet: 0xee82eeff,
251
- wheat: 0xf5deb3ff,
252
- white: 0xffffffff,
253
- whitesmoke: 0xf5f5f5ff,
254
- yellow: 0xffff00ff,
255
- yellowgreen: 0x9acd32ff,
256
- };
257
- function normalizeColor(color) {
258
- const matchers = getMatchers();
259
- let match;
260
- // Ordered based on occurrences on Facebook codebase
261
- if (matchers.hex6) {
262
- if ((match = matchers.hex6.exec(color))) {
263
- return Number.parseInt(match[1] + 'ff', 16) >>> 0;
264
- }
265
- }
266
- if (names[color] !== undefined) {
267
- return names[color];
268
- }
269
- if (matchers.rgb) {
270
- if ((match = matchers.rgb.exec(color))) {
271
- return (
272
- // b
273
- ((parse255(match[1]) << 24) | // r
274
- (parse255(match[2]) << 16) | // g
275
- (parse255(match[3]) << 8) |
276
- 0x000000ff) >>> // a
277
- 0);
278
- }
279
- }
280
- if (matchers.rgba) {
281
- if ((match = matchers.rgba.exec(color))) {
282
- return (
283
- // b
284
- ((parse255(match[1]) << 24) | // r
285
- (parse255(match[2]) << 16) | // g
286
- (parse255(match[3]) << 8) |
287
- parse1(match[4])) >>> // a
288
- 0);
289
- }
290
- }
291
- if (matchers.hex3) {
292
- if ((match = matchers.hex3.exec(color))) {
293
- return (Number.parseInt(match[1] +
294
- match[1] + // r
295
- match[2] +
296
- match[2] + // g
297
- match[3] +
298
- match[3] + // b
299
- 'ff', // a
300
- 16) >>> 0);
301
- }
302
- }
303
- // https://drafts.csswg.org/css-color-4/#hex-notation
304
- if (matchers.hex8) {
305
- if ((match = matchers.hex8.exec(color))) {
306
- return Number.parseInt(match[1], 16) >>> 0;
307
- }
308
- }
309
- if (matchers.hex4) {
310
- if ((match = matchers.hex4.exec(color))) {
311
- return (Number.parseInt(match[1] +
312
- match[1] + // r
313
- match[2] +
314
- match[2] + // g
315
- match[3] +
316
- match[3] + // b
317
- match[4] +
318
- match[4], // a
319
- 16) >>> 0);
320
- }
321
- }
322
- if (matchers.hsl) {
323
- if ((match = matchers.hsl.exec(color))) {
324
- return ((hslToRgb(parse360(match[1]), // h
325
- parsePercentage(match[2]), // s
326
- parsePercentage(match[3]) // l
327
- ) |
328
- 0x000000ff) >>> // a
329
- 0);
330
- }
331
- }
332
- if (matchers.hsla) {
333
- if ((match = matchers.hsla.exec(color))) {
334
- return ((hslToRgb(parse360(match[1]), // h
335
- parsePercentage(match[2]), // s
336
- parsePercentage(match[3]) // l
337
- ) |
338
- parse1(match[4])) >>> // a
339
- 0);
340
- }
341
- }
342
- throw new Error(`invalid color string ${color} provided`);
343
- }
344
- const opacity = (c) => {
345
- return ((c >> 24) & 255) / 255;
346
- };
347
- const red = (c) => {
348
- return (c >> 16) & 255;
349
- };
350
- const green = (c) => {
351
- return (c >> 8) & 255;
352
- };
353
- const blue = (c) => {
354
- return c & 255;
355
- };
356
- const rgbaColor = (r, g, b, alpha) => {
357
- return `rgba(${r}, ${g}, ${b}, ${alpha})`;
358
- };
359
- function processColorInitially(color) {
360
- let normalizedColor = normalizeColor(color);
361
- normalizedColor = ((normalizedColor << 24) | (normalizedColor >>> 8)) >>> 0; // argb
362
- return normalizedColor;
363
- }
364
- function processColor(color) {
365
- const normalizedColor = processColorInitially(color);
366
- return normalizedColor;
367
- }
368
- const interpolateColorsRGB = (value, inputRange, colors) => {
369
- const [r, g, b, a] = [red, green, blue, opacity].map((f) => {
370
- const unrounded = (0, interpolate_1.interpolate)(value, inputRange, colors.map((c) => f(c)), {
371
- extrapolateLeft: 'clamp',
372
- extrapolateRight: 'clamp',
373
- });
374
- if (f === opacity) {
375
- return Number(unrounded.toFixed(3));
376
- }
377
- return Math.round(unrounded);
378
- });
379
- return rgbaColor(r, g, b, a);
380
- };
381
- const interpolateColors = (input, inputRange, outputRange) => {
382
- if (typeof input === 'undefined') {
383
- throw new TypeError('input can not be undefined');
384
- }
385
- if (typeof inputRange === 'undefined') {
386
- throw new TypeError('inputRange can not be undefined');
387
- }
388
- if (typeof outputRange === 'undefined') {
389
- throw new TypeError('outputRange can not be undefined');
390
- }
391
- if (inputRange.length !== outputRange.length) {
392
- throw new TypeError('inputRange (' +
393
- inputRange.length +
394
- ' values provided) and outputRange (' +
395
- outputRange.length +
396
- ' values provided) must have the same length');
397
- }
398
- const processedOutputRange = outputRange.map((c) => processColor(c));
399
- return interpolateColorsRGB(input, inputRange, processedOutputRange);
400
- };
401
- exports.interpolateColors = interpolateColors;
@@ -1,18 +0,0 @@
1
- declare type ExtrapolateType = 'extend' | 'identity' | 'clamp';
2
- /**
3
- * Map a value from an input range to an output range.
4
- * @link https://www.remotion.dev/docs/interpolate
5
- * @param {!number} input value to interpolate
6
- * @param {!number[]} inputRange range of values that you expect the input to assume.
7
- * @param {!number[]} outputRange range of output values that you want the input to map to.
8
- * @param {?object} options
9
- * @param {?Function} options.easing easing function which allows you to customize the input, for example to apply a certain easing function. By default, the input is left unmodified, resulting in a pure linear interpolation {@link https://www.remotion.dev/docs/easing}
10
- * @param {string=} [options.extrapolateLeft="extend"] What should happen if the input value is outside left the input range, default: "extend" {@link https://www.remotion.dev/docs/interpolate#extrapolateleft}
11
- * @param {string=} [options.extrapolateRight="extend"] Same as extrapolateLeft, except for values outside right the input range {@link https://www.remotion.dev/docs/interpolate#extrapolateright}
12
- */
13
- export declare function interpolate(input: number, inputRange: readonly number[], outputRange: readonly number[], options?: {
14
- easing?: (input: number) => number;
15
- extrapolateLeft?: ExtrapolateType;
16
- extrapolateRight?: ExtrapolateType;
17
- }): number;
18
- export {};
@@ -1,123 +0,0 @@
1
- "use strict";
2
- // Taken from https://github.com/facebook/react-native/blob/0b9ea60b4fee8cacc36e7160e31b91fc114dbc0d/Libraries/Animated/src/nodes/AnimatedInterpolation.js
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.interpolate = void 0;
5
- function interpolateFunction(input, inputRange, outputRange, options) {
6
- const { extrapolateLeft, extrapolateRight, easing } = options;
7
- let result = input;
8
- const [inputMin, inputMax] = inputRange;
9
- const [outputMin, outputMax] = outputRange;
10
- if (result < inputMin) {
11
- if (extrapolateLeft === 'identity') {
12
- return result;
13
- }
14
- if (extrapolateLeft === 'clamp') {
15
- result = inputMin;
16
- }
17
- else if (extrapolateLeft === 'extend') {
18
- // noop
19
- }
20
- }
21
- if (result > inputMax) {
22
- if (extrapolateRight === 'identity') {
23
- return result;
24
- }
25
- if (extrapolateRight === 'clamp') {
26
- result = inputMax;
27
- }
28
- else if (extrapolateRight === 'extend') {
29
- // noop
30
- }
31
- }
32
- if (outputMin === outputMax) {
33
- return outputMin;
34
- }
35
- // Input Range
36
- result = (result - inputMin) / (inputMax - inputMin);
37
- // Easing
38
- result = easing(result);
39
- // Output Range
40
- result = result * (outputMax - outputMin) + outputMin;
41
- return result;
42
- }
43
- function findRange(input, inputRange) {
44
- let i;
45
- for (i = 1; i < inputRange.length - 1; ++i) {
46
- if (inputRange[i] >= input) {
47
- break;
48
- }
49
- }
50
- return i - 1;
51
- }
52
- function checkValidInputRange(arr) {
53
- for (let i = 1; i < arr.length; ++i) {
54
- if (!(arr[i] > arr[i - 1])) {
55
- throw new Error(`inputRange must be strictly monotonically non-decreasing but got [${arr.join(',')}]`);
56
- }
57
- }
58
- }
59
- function checkInfiniteRange(name, arr) {
60
- if (arr.length < 2) {
61
- throw new Error(name + ' must have at least 2 elements');
62
- }
63
- for (const index in arr) {
64
- if (typeof arr[index] !== 'number') {
65
- throw new Error(`${name} must contain only numbers`);
66
- }
67
- if (arr[index] === -Infinity || arr[index] === Infinity) {
68
- throw new Error(`${name} must contain only finite numbers, but got [${arr.join(',')}]`);
69
- }
70
- }
71
- }
72
- /**
73
- * Map a value from an input range to an output range.
74
- * @link https://www.remotion.dev/docs/interpolate
75
- * @param {!number} input value to interpolate
76
- * @param {!number[]} inputRange range of values that you expect the input to assume.
77
- * @param {!number[]} outputRange range of output values that you want the input to map to.
78
- * @param {?object} options
79
- * @param {?Function} options.easing easing function which allows you to customize the input, for example to apply a certain easing function. By default, the input is left unmodified, resulting in a pure linear interpolation {@link https://www.remotion.dev/docs/easing}
80
- * @param {string=} [options.extrapolateLeft="extend"] What should happen if the input value is outside left the input range, default: "extend" {@link https://www.remotion.dev/docs/interpolate#extrapolateleft}
81
- * @param {string=} [options.extrapolateRight="extend"] Same as extrapolateLeft, except for values outside right the input range {@link https://www.remotion.dev/docs/interpolate#extrapolateright}
82
- */
83
- function interpolate(input, inputRange, outputRange, options) {
84
- var _a;
85
- if (typeof input === 'undefined') {
86
- throw new Error('input can not be undefined');
87
- }
88
- if (typeof inputRange === 'undefined') {
89
- throw new Error('inputRange can not be undefined');
90
- }
91
- if (typeof outputRange === 'undefined') {
92
- throw new Error('outputRange can not be undefined');
93
- }
94
- if (inputRange.length !== outputRange.length) {
95
- throw new Error('inputRange (' +
96
- inputRange.length +
97
- ') and outputRange (' +
98
- outputRange.length +
99
- ') must have the same length');
100
- }
101
- checkInfiniteRange('inputRange', inputRange);
102
- checkInfiniteRange('outputRange', outputRange);
103
- checkValidInputRange(inputRange);
104
- const easing = (_a = options === null || options === void 0 ? void 0 : options.easing) !== null && _a !== void 0 ? _a : ((num) => num);
105
- let extrapolateLeft = 'extend';
106
- if ((options === null || options === void 0 ? void 0 : options.extrapolateLeft) !== undefined) {
107
- extrapolateLeft = options.extrapolateLeft;
108
- }
109
- let extrapolateRight = 'extend';
110
- if ((options === null || options === void 0 ? void 0 : options.extrapolateRight) !== undefined) {
111
- extrapolateRight = options.extrapolateRight;
112
- }
113
- if (typeof input !== 'number') {
114
- throw new TypeError('Cannot interpolate an input which is not a number');
115
- }
116
- const range = findRange(input, inputRange);
117
- return interpolateFunction(input, [inputRange[range], inputRange[range + 1]], [outputRange[range], outputRange[range + 1]], {
118
- easing,
119
- extrapolateLeft,
120
- extrapolateRight,
121
- });
122
- }
123
- exports.interpolate = interpolate;
@@ -1 +0,0 @@
1
- export declare const isApproximatelyTheSame: (num1: number, num2: number) => boolean;
@@ -1,8 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.isApproximatelyTheSame = void 0;
4
- const FLOATING_POINT_ERROR_THRESHOLD = 0.00001;
5
- const isApproximatelyTheSame = (num1, num2) => {
6
- return Math.abs(num1 - num2) < FLOATING_POINT_ERROR_THRESHOLD;
7
- };
8
- exports.isApproximatelyTheSame = isApproximatelyTheSame;
@@ -1,3 +0,0 @@
1
- import type { PropsWithChildren } from 'react';
2
- export declare const IsPlayerContextProvider: React.FC<PropsWithChildren>;
3
- export declare const useIsPlayer: () => boolean;
package/dist/is-player.js DELETED
@@ -1,14 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.useIsPlayer = exports.IsPlayerContextProvider = void 0;
4
- const jsx_runtime_1 = require("react/jsx-runtime");
5
- const react_1 = require("react");
6
- const IsPlayerContext = (0, react_1.createContext)(false);
7
- const IsPlayerContextProvider = ({ children, }) => {
8
- return (0, jsx_runtime_1.jsx)(IsPlayerContext.Provider, { value: true, children: children });
9
- };
10
- exports.IsPlayerContextProvider = IsPlayerContextProvider;
11
- const useIsPlayer = () => {
12
- return (0, react_1.useContext)(IsPlayerContext);
13
- };
14
- exports.useIsPlayer = useIsPlayer;
@@ -1,2 +0,0 @@
1
- import React from 'react';
2
- export declare const Loading: React.FC;
@@ -1,35 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Loading = void 0;
4
- const jsx_runtime_1 = require("react/jsx-runtime");
5
- const AbsoluteFill_1 = require("./AbsoluteFill");
6
- const rotate = {
7
- transform: `rotate(90deg)`,
8
- };
9
- const ICON_SIZE = 40;
10
- const label = {
11
- color: '#555',
12
- fontSize: 14,
13
- fontFamily: 'sans-serif',
14
- };
15
- const container = {
16
- justifyContent: 'center',
17
- alignItems: 'center',
18
- };
19
- const Loading = () => {
20
- return ((0, jsx_runtime_1.jsxs)(AbsoluteFill_1.AbsoluteFill, { style: container, id: "remotion-comp-loading", children: [(0, jsx_runtime_1.jsx)("style", { type: "text/css", children: `
21
- @keyframes anim {
22
- from {
23
- opacity: 0
24
- }
25
- to {
26
- opacity: 1
27
- }
28
- }
29
- #remotion-comp-loading {
30
- animation: anim 2s;
31
- animation-fill-mode: forwards;
32
- }
33
- ` }), (0, jsx_runtime_1.jsx)("svg", { width: ICON_SIZE, height: ICON_SIZE, viewBox: "-100 -100 400 400", style: rotate, children: (0, jsx_runtime_1.jsx)("path", { fill: "#555", stroke: "#555", strokeWidth: "100", strokeLinejoin: "round", d: "M 2 172 a 196 100 0 0 0 195 5 A 196 240 0 0 0 100 2.259 A 196 240 0 0 0 2 172 z" }) }), (0, jsx_runtime_1.jsx)("p", { style: label, children: "Loading..." })] }));
34
- };
35
- exports.Loading = Loading;
@@ -1,9 +0,0 @@
1
- import React from 'react';
2
- import type { LayoutAndStyle } from '../Sequence';
3
- export declare type LoopProps = {
4
- durationInFrames: number;
5
- times?: number;
6
- name?: string;
7
- children: React.ReactNode;
8
- } & LayoutAndStyle;
9
- export declare const Loop: React.FC<LoopProps>;
@@ -1,29 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Loop = void 0;
4
- const jsx_runtime_1 = require("react/jsx-runtime");
5
- const Sequence_1 = require("../Sequence");
6
- const use_video_config_1 = require("../use-video-config");
7
- const validate_duration_in_frames_1 = require("../validation/validate-duration-in-frames");
8
- const Loop = ({ durationInFrames, times = Infinity, children, name, ...props }) => {
9
- const { durationInFrames: compDuration } = (0, use_video_config_1.useVideoConfig)();
10
- (0, validate_duration_in_frames_1.validateDurationInFrames)(durationInFrames, 'of the <Loop /> component');
11
- if (typeof times !== 'number') {
12
- throw new TypeError(`You passed to "times" an argument of type ${typeof times}, but it must be a number.`);
13
- }
14
- if (times !== Infinity && times % 1 !== 0) {
15
- throw new TypeError(`The "times" prop of a loop must be an integer, but got ${times}.`);
16
- }
17
- if (times < 0) {
18
- throw new TypeError(`The "times" prop of a loop must be at least 0, but got ${times}`);
19
- }
20
- const maxTimes = Math.ceil(compDuration / durationInFrames);
21
- const actualTimes = Math.min(maxTimes, times);
22
- const style = props.layout === 'none' ? undefined : props.style;
23
- return ((0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: new Array(actualTimes).fill(true).map((_, i) => {
24
- return ((0, jsx_runtime_1.jsx)(Sequence_1.Sequence
25
- // eslint-disable-next-line react/no-array-index-key
26
- , { durationInFrames: durationInFrames, from: i * durationInFrames, name: name, showLoopTimesInTimeline: actualTimes, showInTimeline: i === 0, layout: props.layout, style: style, children: children }, `loop-${i}`));
27
- }) }));
28
- };
29
- exports.Loop = Loop;
@@ -1 +0,0 @@
1
- export declare const checkMultipleRemotionVersions: () => void;