@remotion/studio 4.0.478 → 4.0.481

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 (201) hide show
  1. package/dist/components/AssetSelector.js +8 -14
  2. package/dist/components/AudioWaveform.js +19 -11
  3. package/dist/components/Button.d.ts +2 -0
  4. package/dist/components/Button.js +9 -6
  5. package/dist/components/CompactExplanation.d.ts +12 -0
  6. package/dist/components/CompactExplanation.js +52 -0
  7. package/dist/components/CompositionSelector.js +2 -4
  8. package/dist/components/CurrentAsset.d.ts +3 -1
  9. package/dist/components/CurrentAsset.js +42 -34
  10. package/dist/components/CurrentComposition.d.ts +1 -1
  11. package/dist/components/CurrentComposition.js +38 -31
  12. package/dist/components/CurrentCompositionSideEffects.d.ts +0 -3
  13. package/dist/components/CurrentCompositionSideEffects.js +1 -37
  14. package/dist/components/DefaultPropsEditor.d.ts +12 -2
  15. package/dist/components/DefaultPropsEditor.js +2 -2
  16. package/dist/components/Editor.js +2 -5
  17. package/dist/components/EditorContent.js +2 -1
  18. package/dist/components/EffectPickerModal.d.ts +5 -0
  19. package/dist/components/EffectPickerModal.js +179 -0
  20. package/dist/components/ExpandedTracksProvider.d.ts +1 -0
  21. package/dist/components/ExpandedTracksProvider.js +81 -7
  22. package/dist/components/GlobalKeybindings.d.ts +3 -1
  23. package/dist/components/GlobalKeybindings.js +104 -10
  24. package/dist/components/InspectorInfoHeader.d.ts +11 -0
  25. package/dist/components/InspectorInfoHeader.js +55 -0
  26. package/dist/components/InspectorPanel/DefaultInspector.d.ts +8 -0
  27. package/dist/components/InspectorPanel/DefaultInspector.js +93 -0
  28. package/dist/components/InspectorPanel/EasingInspector.d.ts +5 -0
  29. package/dist/components/InspectorPanel/EasingInspector.js +41 -0
  30. package/dist/components/InspectorPanel/GuideInspector.d.ts +7 -0
  31. package/dist/components/InspectorPanel/GuideInspector.js +55 -0
  32. package/dist/components/InspectorPanel/KeyframeInspector.d.ts +7 -0
  33. package/dist/components/InspectorPanel/KeyframeInspector.js +109 -0
  34. package/dist/components/InspectorPanel/SelectedInspector.d.ts +5 -0
  35. package/dist/components/InspectorPanel/SelectedInspector.js +26 -0
  36. package/dist/components/InspectorPanel/SequenceSelectionInspector.d.ts +5 -0
  37. package/dist/components/InspectorPanel/SequenceSelectionInspector.js +117 -0
  38. package/dist/components/InspectorPanel/common.d.ts +15 -0
  39. package/dist/components/InspectorPanel/common.js +18 -0
  40. package/dist/components/InspectorPanel/inspector-selection.d.ts +10 -0
  41. package/dist/components/InspectorPanel/inspector-selection.js +35 -0
  42. package/dist/components/InspectorPanel/styles.d.ts +28 -0
  43. package/dist/components/InspectorPanel/styles.js +196 -0
  44. package/dist/components/InspectorPanel/use-track-for-selection.d.ts +2 -0
  45. package/dist/components/InspectorPanel/use-track-for-selection.js +22 -0
  46. package/dist/components/InspectorPanel.d.ts +8 -0
  47. package/dist/components/InspectorPanel.js +26 -0
  48. package/dist/components/InspectorPanelLayout.d.ts +1 -0
  49. package/dist/components/InspectorPanelLayout.js +4 -0
  50. package/dist/components/InspectorSequenceSection.d.ts +19 -0
  51. package/dist/components/InspectorSequenceSection.js +157 -0
  52. package/dist/components/InspectorSourceLocation.d.ts +7 -0
  53. package/dist/components/InspectorSourceLocation.js +71 -0
  54. package/dist/components/KeyboardShortcutsExplainer.js +10 -2
  55. package/dist/components/Modals.js +3 -3
  56. package/dist/components/NewComposition/InputDragger.js +1 -1
  57. package/dist/components/NewComposition/RemInput.d.ts +1 -0
  58. package/dist/components/NewComposition/RemInput.js +8 -2
  59. package/dist/components/NewComposition/RemTextarea.d.ts +1 -0
  60. package/dist/components/NewComposition/RemTextarea.js +8 -2
  61. package/dist/components/NewComposition/ValidationMessage.d.ts +3 -0
  62. package/dist/components/NewComposition/ValidationMessage.js +16 -5
  63. package/dist/components/OptionsPanel.d.ts +1 -1
  64. package/dist/components/OptionsPanel.js +8 -17
  65. package/dist/components/QuickSwitcher/QuickSwitcherContent.js +2 -7
  66. package/dist/components/QuickSwitcher/QuickSwitcherResult.js +3 -10
  67. package/dist/components/QuickSwitcher/shared.d.ts +4 -0
  68. package/dist/components/QuickSwitcher/shared.js +24 -0
  69. package/dist/components/RenderModal/DataEditor.d.ts +29 -2
  70. package/dist/components/RenderModal/DataEditor.js +107 -56
  71. package/dist/components/RenderModal/RenderModalJSONPropsEditor.d.ts +1 -0
  72. package/dist/components/RenderModal/RenderModalJSONPropsEditor.js +25 -7
  73. package/dist/components/RenderModal/SchemaEditor/Fieldset.d.ts +2 -1
  74. package/dist/components/RenderModal/SchemaEditor/Fieldset.js +10 -5
  75. package/dist/components/RenderModal/SchemaEditor/SchemaEditor.d.ts +4 -0
  76. package/dist/components/RenderModal/SchemaEditor/SchemaEditor.js +27 -4
  77. package/dist/components/RenderModal/SchemaEditor/SchemaErrorMessages.d.ts +12 -4
  78. package/dist/components/RenderModal/SchemaEditor/SchemaErrorMessages.js +23 -9
  79. package/dist/components/RenderModal/SchemaEditor/SchemaLabel.js +3 -3
  80. package/dist/components/RenderModal/SchemaEditor/SchemaSeparationLine.js +8 -1
  81. package/dist/components/RenderModal/SchemaEditor/ZodColorEditor.js +1 -1
  82. package/dist/components/RenderModal/SchemaEditor/ZodDateEditor.js +1 -1
  83. package/dist/components/RenderModal/SchemaEditor/ZodDiscriminatedUnionEditor.js +1 -1
  84. package/dist/components/RenderModal/SchemaEditor/ZodEnumEditor.js +1 -1
  85. package/dist/components/RenderModal/SchemaEditor/ZodErrorMessages.d.ts +1 -0
  86. package/dist/components/RenderModal/SchemaEditor/ZodErrorMessages.js +23 -6
  87. package/dist/components/RenderModal/SchemaEditor/ZodFieldValidation.js +2 -2
  88. package/dist/components/RenderModal/SchemaEditor/ZodNonEditableValue.js +2 -1
  89. package/dist/components/RenderModal/SchemaEditor/ZodNumberEditor.js +1 -1
  90. package/dist/components/RenderModal/SchemaEditor/ZodObjectEditor.js +9 -11
  91. package/dist/components/RenderModal/SchemaEditor/ZodOrNullishEditor.js +1 -1
  92. package/dist/components/RenderModal/SchemaEditor/ZodStaticFileEditor.js +1 -1
  93. package/dist/components/RenderModal/SchemaEditor/ZodStringEditor.js +1 -1
  94. package/dist/components/RenderModal/SchemaEditor/ZodTextareaEditor.js +1 -1
  95. package/dist/components/RenderModal/WarningIndicatorButton.d.ts +1 -0
  96. package/dist/components/RenderModal/WarningIndicatorButton.js +17 -4
  97. package/dist/components/RenderModal/get-render-modal-warnings.d.ts +2 -1
  98. package/dist/components/RenderModal/get-render-modal-warnings.js +6 -3
  99. package/dist/components/RendersTab.js +1 -1
  100. package/dist/components/ResetZoomButton.d.ts +2 -1
  101. package/dist/components/ResetZoomButton.js +5 -1
  102. package/dist/components/SegmentedControl.d.ts +3 -0
  103. package/dist/components/SegmentedControl.js +11 -5
  104. package/dist/components/SelectedOutlineElement.js +96 -24
  105. package/dist/components/SelectedOutlineOverlay.d.ts +1 -1
  106. package/dist/components/SelectedOutlineOverlay.js +44 -30
  107. package/dist/components/SelectedOutlineUvControls.d.ts +9 -0
  108. package/dist/components/SelectedOutlineUvControls.js +64 -10
  109. package/dist/components/Tabs/index.js +4 -4
  110. package/dist/components/Timeline/EasingEditorModal.d.ts +5 -4
  111. package/dist/components/Timeline/EasingEditorModal.js +597 -124
  112. package/dist/components/Timeline/KeyframeSettingsModal.d.ts +2 -2
  113. package/dist/components/Timeline/SubscribeToNodePaths.d.ts +2 -2
  114. package/dist/components/Timeline/Timeline.js +9 -9
  115. package/dist/components/Timeline/TimelineClipboardKeybindings.d.ts +15 -3
  116. package/dist/components/Timeline/TimelineClipboardKeybindings.js +85 -1
  117. package/dist/components/Timeline/TimelineDeleteKeybindings.js +10 -3
  118. package/dist/components/Timeline/TimelineEffectItem.d.ts +2 -2
  119. package/dist/components/Timeline/TimelineEffectItem.js +1 -1
  120. package/dist/components/Timeline/TimelineEffectPropItem.d.ts +8 -0
  121. package/dist/components/Timeline/TimelineEffectPropItem.js +25 -21
  122. package/dist/components/Timeline/TimelineExpandArrowButton.js +42 -2
  123. package/dist/components/Timeline/TimelineExpandedRow.d.ts +5 -2
  124. package/dist/components/Timeline/TimelineExpandedRow.js +6 -6
  125. package/dist/components/Timeline/TimelineExpandedSection.d.ts +1 -1
  126. package/dist/components/Timeline/TimelineExpandedSection.js +10 -25
  127. package/dist/components/Timeline/TimelineKeyframeControls.d.ts +8 -2
  128. package/dist/components/Timeline/TimelineKeyframeControls.js +24 -3
  129. package/dist/components/Timeline/TimelineKeyframeEasingLine.js +2 -47
  130. package/dist/components/Timeline/TimelineKeyframedValue.d.ts +1 -1
  131. package/dist/components/Timeline/TimelineKeyframedValue.js +8 -10
  132. package/dist/components/Timeline/TimelineNumberField.js +5 -11
  133. package/dist/components/Timeline/TimelineRotationField.js +5 -6
  134. package/dist/components/Timeline/TimelineRowChrome.d.ts +2 -0
  135. package/dist/components/Timeline/TimelineRowChrome.js +5 -3
  136. package/dist/components/Timeline/TimelineScaleField.js +4 -8
  137. package/dist/components/Timeline/TimelineSelection.d.ts +28 -2
  138. package/dist/components/Timeline/TimelineSelection.js +342 -61
  139. package/dist/components/Timeline/TimelineSequence.js +19 -3
  140. package/dist/components/Timeline/TimelineSequenceItem.js +68 -64
  141. package/dist/components/Timeline/TimelineSequencePropItem.d.ts +12 -2
  142. package/dist/components/Timeline/TimelineSequencePropItem.js +57 -53
  143. package/dist/components/Timeline/TimelineSequenceRightEdgeDragHandle.js +6 -4
  144. package/dist/components/Timeline/TimelineTransformOriginField.js +4 -5
  145. package/dist/components/Timeline/TimelineTranslateField.js +4 -5
  146. package/dist/components/Timeline/TimelineUvCoordinateField.js +4 -4
  147. package/dist/components/Timeline/call-add-keyframe.d.ts +4 -4
  148. package/dist/components/Timeline/call-delete-keyframe.d.ts +4 -4
  149. package/dist/components/Timeline/call-move-keyframe.d.ts +2 -2
  150. package/dist/components/Timeline/call-update-keyframe-settings.d.ts +3 -3
  151. package/dist/components/Timeline/delete-selected-timeline-item.d.ts +2 -1
  152. package/dist/components/Timeline/delete-selected-timeline-item.js +27 -1
  153. package/dist/components/Timeline/find-track-for-node-path-info.js +2 -2
  154. package/dist/components/Timeline/get-node-keyframes.d.ts +7 -0
  155. package/dist/components/Timeline/get-node-keyframes.js +26 -1
  156. package/dist/components/Timeline/parse-keyframe-field-from-node-path.js +2 -2
  157. package/dist/components/Timeline/reset-selected-timeline-props.d.ts +3 -3
  158. package/dist/components/Timeline/reset-selected-timeline-props.js +34 -7
  159. package/dist/components/Timeline/save-effect-prop.d.ts +2 -2
  160. package/dist/components/Timeline/save-sequence-prop.d.ts +2 -2
  161. package/dist/components/Timeline/sequence-props-subscription-store.d.ts +3 -3
  162. package/dist/components/Timeline/timeline-expanded-filter.d.ts +12 -0
  163. package/dist/components/Timeline/timeline-expanded-filter.js +38 -0
  164. package/dist/components/Timeline/timeline-field-display-utils.d.ts +5 -0
  165. package/dist/components/Timeline/timeline-field-display-utils.js +244 -0
  166. package/dist/components/Timeline/update-selected-easing.d.ts +47 -4
  167. package/dist/components/Timeline/update-selected-easing.js +40 -9
  168. package/dist/components/Timeline/use-expanded-track-keyframe-rows.js +50 -18
  169. package/dist/components/Timeline/use-sequence-freeze-frame-menu-item.d.ts +13 -0
  170. package/dist/components/Timeline/use-sequence-freeze-frame-menu-item.js +73 -0
  171. package/dist/components/Timeline/use-sequence-props-subscription.d.ts +3 -3
  172. package/dist/components/Timeline/use-timeline-expanded-tree.d.ts +12 -0
  173. package/dist/components/Timeline/use-timeline-expanded-tree.js +60 -0
  174. package/dist/components/Timeline/use-timeline-height.js +51 -7
  175. package/dist/components/Timeline/use-timeline-keyframe-drag.js +12 -6
  176. package/dist/components/TopPanel.js +1 -1
  177. package/dist/components/VisualControls/VisualControlsContent.d.ts +1 -1
  178. package/dist/components/VisualControls/VisualControlsContent.js +4 -5
  179. package/dist/components/effect-drag-and-drop.d.ts +10 -0
  180. package/dist/components/effect-drag-and-drop.js +17 -8
  181. package/dist/components/effect-picker-search.d.ts +5 -0
  182. package/dist/components/effect-picker-search.js +77 -0
  183. package/dist/components/selected-outline-drag.d.ts +21 -2
  184. package/dist/components/selected-outline-drag.js +31 -6
  185. package/dist/components/selected-outline-measurement.js +48 -14
  186. package/dist/components/selected-outline-types.d.ts +7 -7
  187. package/dist/components/selected-outline-uv.d.ts +4 -3
  188. package/dist/components/selected-outline-uv.js +6 -2
  189. package/dist/error-overlay/remotion-overlay/ErrorLoader.js +8 -1
  190. package/dist/esm/{chunk-hrw9799x.js → chunk-4rq5gt8c.js} +30557 -26640
  191. package/dist/esm/internals.mjs +30557 -26640
  192. package/dist/esm/previewEntry.mjs +18584 -14665
  193. package/dist/esm/renderEntry.mjs +1 -1
  194. package/dist/helpers/migrate-expanded-tracks-for-subscription-key.js +3 -3
  195. package/dist/helpers/render-codec-label.d.ts +2 -0
  196. package/dist/helpers/render-codec-label.js +49 -0
  197. package/dist/helpers/timeline-layout.d.ts +4 -4
  198. package/dist/helpers/use-media-metadata.d.ts +8 -2
  199. package/dist/helpers/use-media-metadata.js +17 -4
  200. package/dist/state/modals.d.ts +9 -4
  201. package/package.json +12 -12
@@ -0,0 +1,196 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.keyframeEditorValue = exports.keyframeEditorLabel = exports.keyframeEditorRow = exports.detailValue = exports.detailLabel = exports.detailRow = exports.guideDetailsContainer = exports.detailsContainer = exports.centeredMessage = exports.selectedContainer = exports.resolveLinkStyle = exports.defaultPropsWarningMessages = exports.defaultPropsWarningContainer = exports.sectionHeaderEnd = exports.sectionHeaderStart = exports.sectionHeaderTitle = exports.sectionHeaderRow = exports.sequenceHeaderSubtitle = exports.sequenceHeaderTitle = exports.sequenceHeader = exports.sectionHeader = exports.inspectorSectionDivider = exports.compositionSection = exports.visualControlsSection = exports.defaultPropsSection = exports.scrollableContainer = exports.container = void 0;
4
+ const colors_1 = require("../../helpers/colors");
5
+ const InspectorPanelLayout_1 = require("../InspectorPanelLayout");
6
+ exports.container = {
7
+ backgroundColor: colors_1.BACKGROUND,
8
+ color: 'white',
9
+ display: 'flex',
10
+ flex: 1,
11
+ flexDirection: 'column',
12
+ height: '100%',
13
+ minHeight: 0,
14
+ };
15
+ exports.scrollableContainer = {
16
+ ...exports.container,
17
+ overflowY: 'auto',
18
+ };
19
+ exports.defaultPropsSection = {
20
+ display: 'flex',
21
+ flexDirection: 'column',
22
+ };
23
+ exports.visualControlsSection = {
24
+ display: 'flex',
25
+ flexDirection: 'column',
26
+ };
27
+ exports.compositionSection = {
28
+ display: 'flex',
29
+ flexDirection: 'column',
30
+ };
31
+ exports.inspectorSectionDivider = {
32
+ borderBottom: `1px solid ${colors_1.LINE_COLOR}`,
33
+ };
34
+ exports.sectionHeader = {
35
+ color: colors_1.LIGHT_TEXT,
36
+ fontSize: 12,
37
+ fontWeight: 'bold',
38
+ padding: `8px ${InspectorPanelLayout_1.INSPECTOR_PANEL_HORIZONTAL_PADDING}px`,
39
+ };
40
+ exports.sequenceHeader = {
41
+ backgroundColor: colors_1.BACKGROUND,
42
+ display: 'flex',
43
+ flexDirection: 'column',
44
+ minWidth: 0,
45
+ padding: `6px ${InspectorPanelLayout_1.INSPECTOR_PANEL_HORIZONTAL_PADDING}px 4px`,
46
+ };
47
+ exports.sequenceHeaderTitle = {
48
+ alignSelf: 'flex-start',
49
+ backgroundColor: colors_1.BACKGROUND,
50
+ border: 'none',
51
+ color: 'white',
52
+ display: 'inline-flex',
53
+ fontFamily: 'sans-serif',
54
+ fontSize: 12,
55
+ lineHeight: '18px',
56
+ margin: 0,
57
+ maxWidth: '100%',
58
+ minWidth: 0,
59
+ overflow: 'hidden',
60
+ padding: 0,
61
+ textAlign: 'left',
62
+ textOverflow: 'ellipsis',
63
+ whiteSpace: 'nowrap',
64
+ };
65
+ exports.sequenceHeaderSubtitle = {
66
+ alignSelf: 'flex-start',
67
+ backgroundColor: colors_1.BACKGROUND,
68
+ border: 'none',
69
+ color: colors_1.LIGHT_TEXT,
70
+ display: 'inline-flex',
71
+ fontFamily: 'sans-serif',
72
+ fontSize: 12,
73
+ lineHeight: '18px',
74
+ margin: 0,
75
+ maxWidth: '100%',
76
+ minWidth: 0,
77
+ overflow: 'hidden',
78
+ padding: 0,
79
+ textAlign: 'left',
80
+ textOverflow: 'ellipsis',
81
+ whiteSpace: 'nowrap',
82
+ };
83
+ exports.sectionHeaderRow = {
84
+ alignItems: 'center',
85
+ display: 'flex',
86
+ gap: 8,
87
+ justifyContent: 'space-between',
88
+ minWidth: 0,
89
+ };
90
+ exports.sectionHeaderTitle = {
91
+ color: colors_1.LIGHT_TEXT,
92
+ flexShrink: 0,
93
+ fontSize: 12,
94
+ fontWeight: 'bold',
95
+ lineHeight: '16px',
96
+ minWidth: 0,
97
+ overflow: 'hidden',
98
+ textOverflow: 'ellipsis',
99
+ whiteSpace: 'nowrap',
100
+ };
101
+ exports.sectionHeaderStart = {
102
+ alignItems: 'center',
103
+ display: 'flex',
104
+ gap: 8,
105
+ minWidth: 0,
106
+ };
107
+ exports.sectionHeaderEnd = {
108
+ alignItems: 'center',
109
+ display: 'flex',
110
+ flexShrink: 0,
111
+ };
112
+ exports.defaultPropsWarningContainer = {
113
+ alignItems: 'flex-start',
114
+ display: 'flex',
115
+ flexDirection: 'column',
116
+ gap: 8,
117
+ padding: `0 ${InspectorPanelLayout_1.INSPECTOR_PANEL_HORIZONTAL_PADDING}px 8px`,
118
+ };
119
+ exports.defaultPropsWarningMessages = {
120
+ display: 'flex',
121
+ flexDirection: 'column',
122
+ gap: 8,
123
+ };
124
+ exports.resolveLinkStyle = {
125
+ color: colors_1.BLUE,
126
+ fontFamily: 'sans-serif',
127
+ fontSize: 12,
128
+ textDecoration: 'underline',
129
+ whiteSpace: 'nowrap',
130
+ };
131
+ exports.selectedContainer = {
132
+ backgroundColor: colors_1.BACKGROUND,
133
+ flex: 1,
134
+ minHeight: 0,
135
+ overflowY: 'auto',
136
+ };
137
+ exports.centeredMessage = {
138
+ alignItems: 'center',
139
+ color: colors_1.LIGHT_TEXT,
140
+ display: 'flex',
141
+ flex: 1,
142
+ fontSize: 14,
143
+ justifyContent: 'center',
144
+ padding: 24,
145
+ textAlign: 'center',
146
+ };
147
+ exports.detailsContainer = {
148
+ padding: `0 ${InspectorPanelLayout_1.INSPECTOR_PANEL_HORIZONTAL_PADDING}px ${InspectorPanelLayout_1.INSPECTOR_PANEL_HORIZONTAL_PADDING}px`,
149
+ };
150
+ exports.guideDetailsContainer = {
151
+ padding: `0 ${InspectorPanelLayout_1.INSPECTOR_PANEL_HORIZONTAL_PADDING}px ${InspectorPanelLayout_1.INSPECTOR_PANEL_HORIZONTAL_PADDING}px`,
152
+ };
153
+ exports.detailRow = {
154
+ alignItems: 'center',
155
+ display: 'flex',
156
+ gap: 12,
157
+ justifyContent: 'space-between',
158
+ padding: '10px 0',
159
+ };
160
+ exports.detailLabel = {
161
+ color: colors_1.LIGHT_TEXT,
162
+ fontSize: 13,
163
+ };
164
+ exports.detailValue = {
165
+ color: 'white',
166
+ fontSize: 13,
167
+ fontVariantNumeric: 'tabular-nums',
168
+ minWidth: 0,
169
+ textAlign: 'right',
170
+ wordBreak: 'break-word',
171
+ };
172
+ exports.keyframeEditorRow = {
173
+ alignItems: 'flex-start',
174
+ display: 'flex',
175
+ gap: 12,
176
+ justifyContent: 'space-between',
177
+ minWidth: 0,
178
+ padding: '10px 0',
179
+ };
180
+ exports.keyframeEditorLabel = {
181
+ color: colors_1.LIGHT_TEXT,
182
+ fontSize: 13,
183
+ lineHeight: '22px',
184
+ minWidth: 0,
185
+ overflow: 'hidden',
186
+ textOverflow: 'ellipsis',
187
+ whiteSpace: 'nowrap',
188
+ };
189
+ exports.keyframeEditorValue = {
190
+ alignItems: 'center',
191
+ display: 'flex',
192
+ flexShrink: 0,
193
+ justifyContent: 'flex-end',
194
+ minHeight: 22,
195
+ minWidth: 0,
196
+ };
@@ -0,0 +1,2 @@
1
+ import type { TimelineSelection } from '../Timeline/TimelineSelection';
2
+ export declare const useTrackForSelection: (selection: TimelineSelection) => import("../../helpers/get-timeline-sequence-sort-key").TrackWithHash | null;
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useTrackForSelection = void 0;
4
+ const react_1 = require("react");
5
+ const remotion_1 = require("remotion");
6
+ const find_track_for_node_path_info_1 = require("../Timeline/find-track-for-node-path-info");
7
+ const useTrackForSelection = (selection) => {
8
+ const { sequences } = (0, react_1.useContext)(remotion_1.Internals.SequenceManager);
9
+ const { overrideIdToNodePathMappings } = (0, react_1.useContext)(remotion_1.Internals.OverrideIdsToNodePathsGettersContext);
10
+ return (0, react_1.useMemo)(() => {
11
+ var _a;
12
+ if (selection.type === 'guide') {
13
+ return null;
14
+ }
15
+ return ((_a = (0, find_track_for_node_path_info_1.findTrackForNodePathInfo)({
16
+ sequences,
17
+ overrideIdsToNodePaths: overrideIdToNodePathMappings,
18
+ nodePathInfo: selection.nodePathInfo,
19
+ })) !== null && _a !== void 0 ? _a : null);
20
+ }, [overrideIdToNodePathMappings, selection, sequences]);
21
+ };
22
+ exports.useTrackForSelection = useTrackForSelection;
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import type { _InternalTypes } from 'remotion';
3
+ import type { UpdaterFunction } from './RenderModal/SchemaEditor/ZodSwitch';
4
+ export declare const InspectorPanel: React.FC<{
5
+ readonly composition: _InternalTypes['AnyComposition'] | null;
6
+ readonly currentDefaultProps: Record<string, unknown>;
7
+ readonly setDefaultProps: UpdaterFunction<Record<string, unknown>>;
8
+ }>;
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InspectorPanel = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const common_1 = require("./InspectorPanel/common");
7
+ const DefaultInspector_1 = require("./InspectorPanel/DefaultInspector");
8
+ const inspector_selection_1 = require("./InspectorPanel/inspector-selection");
9
+ const SelectedInspector_1 = require("./InspectorPanel/SelectedInspector");
10
+ const styles_1 = require("./InspectorPanel/styles");
11
+ const TimelineSelection_1 = require("./Timeline/TimelineSelection");
12
+ const InspectorPanel = ({ composition, currentDefaultProps, setDefaultProps }) => {
13
+ const { selectedItems } = (0, TimelineSelection_1.useTimelineSelection)();
14
+ const sameSequenceInspectorSelection = (0, react_1.useMemo)(() => (0, inspector_selection_1.getSameSequenceInspectorSelection)(selectedItems), [selectedItems]);
15
+ if (selectedItems.length === 0) {
16
+ return (jsx_runtime_1.jsx(DefaultInspector_1.DefaultInspector, { composition: composition, currentDefaultProps: currentDefaultProps, setDefaultProps: setDefaultProps }));
17
+ }
18
+ if (selectedItems.length > 1) {
19
+ if (sameSequenceInspectorSelection) {
20
+ return (jsx_runtime_1.jsx("div", { style: styles_1.container, children: jsx_runtime_1.jsx(SelectedInspector_1.SelectedInspector, { selection: sameSequenceInspectorSelection }) }));
21
+ }
22
+ return (jsx_runtime_1.jsx("div", { style: styles_1.container, children: jsx_runtime_1.jsxs(common_1.InspectorMessage, { children: [selectedItems.length, " items selected"] }) }));
23
+ }
24
+ return (jsx_runtime_1.jsx("div", { style: styles_1.container, children: jsx_runtime_1.jsx(SelectedInspector_1.SelectedInspector, { selection: selectedItems[0] }) }));
25
+ };
26
+ exports.InspectorPanel = InspectorPanel;
@@ -0,0 +1 @@
1
+ export declare const INSPECTOR_PANEL_HORIZONTAL_PADDING = 12;
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.INSPECTOR_PANEL_HORIZONTAL_PADDING = void 0;
4
+ exports.INSPECTOR_PANEL_HORIZONTAL_PADDING = 12;
@@ -0,0 +1,19 @@
1
+ import React from 'react';
2
+ import type { TSequence } from 'remotion';
3
+ import type { CodePosition } from '../error-overlay/react-overlay/utils/get-source-map';
4
+ import type { SequenceNodePathInfo } from '../helpers/get-timeline-sequence-sort-key';
5
+ import { type FlatTreeRow } from '../helpers/timeline-layout';
6
+ import { type TimelineSelection } from './Timeline/TimelineSelection';
7
+ type SequenceWithControls = TSequence & {
8
+ readonly controls: NonNullable<TSequence['controls']>;
9
+ };
10
+ export declare const getInspectorSelectableItems: (rows: readonly FlatTreeRow[]) => TimelineSelection[];
11
+ export declare const hasSequenceControls: (sequence: TSequence) => sequence is SequenceWithControls;
12
+ export declare const InspectorSequenceSection: React.FC<{
13
+ readonly sequence: SequenceWithControls;
14
+ readonly validatedLocation: CodePosition;
15
+ readonly nodePathInfo: SequenceNodePathInfo;
16
+ readonly keyframeDisplayOffset: number;
17
+ readonly renderSectionHeader: (children: React.ReactNode) => React.ReactNode;
18
+ }>;
19
+ export {};
@@ -0,0 +1,157 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InspectorSequenceSection = exports.hasSequenceControls = exports.getInspectorSelectableItems = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const client_id_1 = require("../helpers/client-id");
7
+ const colors_1 = require("../helpers/colors");
8
+ const timeline_layout_1 = require("../helpers/timeline-layout");
9
+ const plus_1 = require("../icons/plus");
10
+ const modals_1 = require("../state/modals");
11
+ const InlineAction_1 = require("./InlineAction");
12
+ const styles_1 = require("./InspectorPanel/styles");
13
+ const TimelineExpandedRow_1 = require("./Timeline/TimelineExpandedRow");
14
+ const TimelineSelection_1 = require("./Timeline/TimelineSelection");
15
+ const use_timeline_expanded_tree_1 = require("./Timeline/use-timeline-expanded-tree");
16
+ const container = {
17
+ color: 'white',
18
+ display: 'flex',
19
+ flexDirection: 'column',
20
+ fontFamily: 'Arial, Helvetica, sans-serif',
21
+ fontSize: 12,
22
+ };
23
+ const emptyState = {
24
+ color: colors_1.LIGHT_TEXT,
25
+ fontFamily: 'sans-serif',
26
+ fontSize: 12,
27
+ lineHeight: 1.4,
28
+ padding: '0 12px 8px',
29
+ };
30
+ const divider = {
31
+ backgroundColor: colors_1.LINE_COLOR,
32
+ flexShrink: 0,
33
+ height: 1,
34
+ margin: '4px 0',
35
+ };
36
+ const controlsEffectsDivider = {
37
+ ...divider,
38
+ margin: '8px 0 4px',
39
+ };
40
+ const effectsHeaderTitle = {
41
+ ...styles_1.sectionHeaderTitle,
42
+ flexShrink: 1,
43
+ };
44
+ const plusIcon = {
45
+ width: 15,
46
+ height: 15,
47
+ };
48
+ const isEffectsRoot = (node) => {
49
+ if (node.kind !== 'group' || node.effectInfo !== null) {
50
+ return false;
51
+ }
52
+ const { auxiliaryKeys } = node.nodePathInfo;
53
+ return auxiliaryKeys[auxiliaryKeys.length - 1] === 'effects';
54
+ };
55
+ const getInspectorExpansionKey = (nodePathInfo) => {
56
+ return JSON.stringify(nodePathInfo);
57
+ };
58
+ const getInspectorSelectableItems = (rows) => {
59
+ return rows.flatMap(({ node }) => {
60
+ const selection = (0, TimelineSelection_1.getTimelineSelectionFromNodePathInfo)(node.nodePathInfo);
61
+ return selection ? [selection] : [];
62
+ });
63
+ };
64
+ exports.getInspectorSelectableItems = getInspectorSelectableItems;
65
+ const hasSequenceControls = (sequence) => {
66
+ return sequence.controls !== null;
67
+ };
68
+ exports.hasSequenceControls = hasSequenceControls;
69
+ const InspectorSequenceSection = ({ sequence, validatedLocation, nodePathInfo, keyframeDisplayOffset, renderSectionHeader, }) => {
70
+ const { tree } = (0, use_timeline_expanded_tree_1.useTimelineExpandedTree)({
71
+ sequence,
72
+ nodePathInfo,
73
+ });
74
+ const [collapsedKeys, setCollapsedKeys] = (0, react_1.useState)(() => new Set());
75
+ const { previewServerState } = (0, react_1.useContext)(client_id_1.StudioServerConnectionCtx);
76
+ const { setSelectedModal } = (0, react_1.useContext)(modals_1.ModalsContext);
77
+ const getIsExpanded = (0, react_1.useCallback)((candidate) => {
78
+ return !collapsedKeys.has(getInspectorExpansionKey(candidate));
79
+ }, [collapsedKeys]);
80
+ const toggleTrack = (0, react_1.useCallback)((candidate) => {
81
+ setCollapsedKeys((prev) => {
82
+ const key = getInspectorExpansionKey(candidate);
83
+ const next = new Set(prev);
84
+ if (next.has(key)) {
85
+ next.delete(key);
86
+ }
87
+ else {
88
+ next.add(key);
89
+ }
90
+ return next;
91
+ });
92
+ }, []);
93
+ const { controlRows, effectRows } = (0, react_1.useMemo)(() => {
94
+ const controlNodes = [];
95
+ let effectsRoot = null;
96
+ for (const node of tree) {
97
+ if (isEffectsRoot(node)) {
98
+ effectsRoot = node;
99
+ }
100
+ else {
101
+ controlNodes.push(node);
102
+ }
103
+ }
104
+ return {
105
+ controlRows: (0, timeline_layout_1.flattenVisibleTreeNodes)({
106
+ nodes: controlNodes,
107
+ getIsExpanded,
108
+ }),
109
+ effectRows: effectsRoot === null
110
+ ? []
111
+ : (0, timeline_layout_1.flattenVisibleTreeNodes)({
112
+ nodes: effectsRoot.children,
113
+ getIsExpanded,
114
+ }),
115
+ };
116
+ }, [getIsExpanded, tree]);
117
+ const controlSelectableItems = (0, react_1.useMemo)(() => (0, exports.getInspectorSelectableItems)(controlRows), [controlRows]);
118
+ const effectSelectableItems = (0, react_1.useMemo)(() => (0, exports.getInspectorSelectableItems)(effectRows), [effectRows]);
119
+ const { schema } = sequence.controls;
120
+ const showEffectsSection = nodePathInfo.supportsEffects || effectRows.length > 0;
121
+ const showControlsEffectsDivider = controlRows.length > 0 && showEffectsSection;
122
+ const canAddEffect = nodePathInfo.supportsEffects &&
123
+ previewServerState.type === 'connected' &&
124
+ Boolean(validatedLocation.source);
125
+ const onAddEffect = (0, react_1.useCallback)(() => {
126
+ if (!canAddEffect || previewServerState.type !== 'connected') {
127
+ return;
128
+ }
129
+ setSelectedModal({
130
+ type: 'add-effect',
131
+ clientId: previewServerState.clientId,
132
+ fileName: validatedLocation.source,
133
+ nodePath: nodePathInfo.sequenceSubscriptionKey,
134
+ });
135
+ }, [
136
+ canAddEffect,
137
+ nodePathInfo.sequenceSubscriptionKey,
138
+ previewServerState,
139
+ setSelectedModal,
140
+ validatedLocation.source,
141
+ ]);
142
+ const renderEffectsHeader = () => {
143
+ return renderSectionHeader(jsx_runtime_1.jsxs("div", { style: styles_1.sectionHeaderRow, children: [
144
+ jsx_runtime_1.jsx("div", { style: effectsHeaderTitle, children: "Effects" }), jsx_runtime_1.jsx(InlineAction_1.InlineAction, { disabled: !canAddEffect, onClick: onAddEffect, title: canAddEffect ? 'Add effect' : undefined, renderAction: (color) => jsx_runtime_1.jsx(plus_1.Plus, { color: color, style: plusIcon }) })] }));
145
+ };
146
+ const renderRow = ({ node, depth }) => {
147
+ return (jsx_runtime_1.jsx(TimelineExpandedRow_1.TimelineExpandedRow, { node: node, depth: depth, nestedDepth: 0, rowDepthBase: 0, getIsExpanded: getIsExpanded, toggleTrack: toggleTrack, validatedLocation: validatedLocation, nodePath: nodePathInfo.sequenceSubscriptionKey, schema: schema, keyframeDisplayOffset: keyframeDisplayOffset, keyframeControlsMode: "inspector" }, JSON.stringify(node.nodePathInfo)));
148
+ };
149
+ if (controlRows.length === 0 && !showEffectsSection) {
150
+ return (jsx_runtime_1.jsxs("div", { style: container, children: [
151
+ jsx_runtime_1.jsx("div", { style: divider }), jsx_runtime_1.jsx("div", { style: emptyState, children: "No schema" })
152
+ ] }));
153
+ }
154
+ return (jsx_runtime_1.jsxs("div", { style: container, children: [
155
+ jsx_runtime_1.jsx("div", { style: divider }), controlRows.length > 0 ? renderSectionHeader('Controls') : null, jsx_runtime_1.jsx(TimelineSelection_1.TimelineSelectionOrderProvider, { items: controlSelectableItems, children: controlRows.map(renderRow) }), showEffectsSection ? (jsx_runtime_1.jsxs(jsx_runtime_1.Fragment, { children: [showControlsEffectsDivider ? (jsx_runtime_1.jsx("div", { style: controlsEffectsDivider })) : null, renderEffectsHeader(), effectRows.length === 0 ? (jsx_runtime_1.jsx("div", { style: emptyState, children: "None" })) : (jsx_runtime_1.jsx(TimelineSelection_1.TimelineSelectionOrderProvider, { items: effectSelectableItems, children: effectRows.map(renderRow) }))] })) : null] }));
156
+ };
157
+ exports.InspectorSequenceSection = InspectorSequenceSection;
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ import type { OriginalPosition } from '../error-overlay/react-overlay/utils/get-source-map';
3
+ export declare const InspectorSourceLocation: React.FC<{
4
+ readonly location: OriginalPosition | null;
5
+ readonly canOpen: boolean;
6
+ readonly onOpen: () => void;
7
+ }>;
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InspectorSourceLocation = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const colors_1 = require("../helpers/colors");
7
+ const format_file_location_1 = require("../helpers/format-file-location");
8
+ const source_attribution_1 = require("./Timeline/TimelineStack/source-attribution");
9
+ const sourceLocationStyle = {
10
+ alignSelf: 'flex-start',
11
+ appearance: 'none',
12
+ backgroundColor: colors_1.BACKGROUND,
13
+ border: 'none',
14
+ boxSizing: 'border-box',
15
+ display: 'block',
16
+ fontFamily: 'sans-serif',
17
+ fontSize: 12,
18
+ height: 18,
19
+ lineHeight: '18px',
20
+ margin: 0,
21
+ maxWidth: '100%',
22
+ overflow: 'hidden',
23
+ padding: 0,
24
+ textAlign: 'left',
25
+ textDecoration: 'none',
26
+ textOverflow: 'ellipsis',
27
+ whiteSpace: 'nowrap',
28
+ width: 'fit-content',
29
+ };
30
+ const InspectorSourceLocation = ({ location, canOpen, onOpen }) => {
31
+ const [hovered, setHovered] = (0, react_1.useState)(false);
32
+ const validLocation = (0, react_1.useMemo)(() => {
33
+ if (!(location === null || location === void 0 ? void 0 : location.source) || location.line === null) {
34
+ return null;
35
+ }
36
+ return location;
37
+ }, [location]);
38
+ const fileLocation = (0, react_1.useMemo)(() => {
39
+ if (!validLocation) {
40
+ return null;
41
+ }
42
+ return (0, format_file_location_1.formatFileLocation)({
43
+ location: validLocation,
44
+ root: window.remotion_cwd,
45
+ });
46
+ }, [validLocation]);
47
+ const label = (0, react_1.useMemo)(() => {
48
+ if (!validLocation) {
49
+ return null;
50
+ }
51
+ return (0, source_attribution_1.getOriginalSourceAttribution)(validLocation);
52
+ }, [validLocation]);
53
+ const style = (0, react_1.useMemo)(() => {
54
+ return {
55
+ ...sourceLocationStyle,
56
+ color: hovered ? colors_1.LIGHT_COLOR : colors_1.LIGHT_TEXT,
57
+ cursor: canOpen ? 'pointer' : 'default',
58
+ };
59
+ }, [canOpen, hovered]);
60
+ const onClick = (0, react_1.useCallback)(() => {
61
+ if (!canOpen) {
62
+ return;
63
+ }
64
+ onOpen();
65
+ }, [canOpen, onOpen]);
66
+ if (!label) {
67
+ return null;
68
+ }
69
+ return (jsx_runtime_1.jsx("button", { type: "button", style: style, title: fileLocation !== null && fileLocation !== void 0 ? fileLocation : undefined, onClick: onClick, onPointerEnter: () => setHovered(true), onPointerLeave: () => setHovered(false), children: label }));
70
+ };
71
+ exports.InspectorSourceLocation = InspectorSourceLocation;
@@ -109,9 +109,9 @@ const KeyboardShortcutsExplainer = () => {
109
109
  ] }), jsx_runtime_1.jsxs(layout_1.Row, { align: "center", children: [
110
110
  jsx_runtime_1.jsx("div", { style: left, children: jsx_runtime_1.jsx("kbd", { style: key, children: "PageDown" }) }), jsx_runtime_1.jsx("div", { style: right, children: "Next composition" })
111
111
  ] }), jsx_runtime_1.jsxs(layout_1.Row, { align: "center", children: [
112
- jsx_runtime_1.jsx("div", { style: left, children: jsx_runtime_1.jsx("kbd", { style: key, children: "R" }) }), jsx_runtime_1.jsx("div", { style: right, children: "Render composition" })
112
+ jsx_runtime_1.jsx("div", { style: left, children: jsx_runtime_1.jsx("kbd", { style: key, children: "R" }) }), jsx_runtime_1.jsx("div", { style: right, children: "Render, unless a sequence or prop is selected" })
113
113
  ] }), jsx_runtime_1.jsxs(layout_1.Row, { align: "center", children: [
114
- jsx_runtime_1.jsx("div", { style: left, children: jsx_runtime_1.jsx("kbd", { style: key, children: "T" }) }), jsx_runtime_1.jsx("div", { style: right, children: "Toggle checkerboard background" })
114
+ jsx_runtime_1.jsx("div", { style: left, children: jsx_runtime_1.jsx("kbd", { style: key, children: "T" }) }), jsx_runtime_1.jsx("div", { style: right, children: "Checkerboard, unless a sequence or prop is selected" })
115
115
  ] }), jsx_runtime_1.jsxs(layout_1.Row, { align: "center", children: [
116
116
  jsx_runtime_1.jsx("div", { style: left, children: jsx_runtime_1.jsx("kbd", { style: key, children: "?" }) }), jsx_runtime_1.jsx("div", { style: right, children: "Show keyboard shortcuts" })
117
117
  ] }), jsx_runtime_1.jsxs(layout_1.Row, { align: "center", children: [
@@ -146,6 +146,14 @@ const KeyboardShortcutsExplainer = () => {
146
146
  jsx_runtime_1.jsxs("div", { style: left, children: [
147
147
  jsx_runtime_1.jsx("kbd", { style: key, children: ShortcutHint_1.cmdOrCtrlCharacter }), jsx_runtime_1.jsx(layout_1.Spacing, { x: 0.3 }), jsx_runtime_1.jsx("kbd", { style: key, children: "A" })
148
148
  ] }), jsx_runtime_1.jsx("div", { style: right, children: "Select sequence rows" })
149
+ ] }), jsx_runtime_1.jsxs(layout_1.Row, { align: "center", children: [
150
+ jsx_runtime_1.jsx("div", { style: left, children: jsx_runtime_1.jsx("kbd", { style: key, children: "P" }) }), jsx_runtime_1.jsx("div", { style: right, children: "Select translate prop" })
151
+ ] }), jsx_runtime_1.jsxs(layout_1.Row, { align: "center", children: [
152
+ jsx_runtime_1.jsx("div", { style: left, children: jsx_runtime_1.jsx("kbd", { style: key, children: "T" }) }), jsx_runtime_1.jsx("div", { style: right, children: "Select opacity prop" })
153
+ ] }), jsx_runtime_1.jsxs(layout_1.Row, { align: "center", children: [
154
+ jsx_runtime_1.jsx("div", { style: left, children: jsx_runtime_1.jsx("kbd", { style: key, children: "R" }) }), jsx_runtime_1.jsx("div", { style: right, children: "Select rotate prop" })
155
+ ] }), jsx_runtime_1.jsxs(layout_1.Row, { align: "center", children: [
156
+ jsx_runtime_1.jsx("div", { style: left, children: jsx_runtime_1.jsx("kbd", { style: key, children: "S" }) }), jsx_runtime_1.jsx("div", { style: right, children: "Select scale prop" })
149
157
  ] }), jsx_runtime_1.jsxs(layout_1.Row, { align: "center", children: [
150
158
  jsx_runtime_1.jsxs("div", { style: left, children: [
151
159
  jsx_runtime_1.jsx("kbd", { style: key, children: ShortcutHint_1.cmdOrCtrlCharacter }), jsx_runtime_1.jsx(layout_1.Spacing, { x: 0.3 }), jsx_runtime_1.jsx("kbd", { style: key, children: "D" })
@@ -10,6 +10,7 @@ const client_id_1 = require("../helpers/client-id");
10
10
  const modals_1 = require("../state/modals");
11
11
  const AskAiModal_1 = require("./AskAiModal");
12
12
  const ConfirmationDialog_1 = require("./ConfirmationDialog");
13
+ const EffectPickerModal_1 = require("./EffectPickerModal");
13
14
  const InstallPackage_1 = require("./InstallPackage");
14
15
  const DeleteComposition_1 = require("./NewComposition/DeleteComposition");
15
16
  const DeleteFolder_1 = require("./NewComposition/DeleteFolder");
@@ -22,7 +23,6 @@ const QuickSwitcher_1 = __importDefault(require("./QuickSwitcher/QuickSwitcher")
22
23
  const RenderStatusModal_1 = require("./RenderModal/RenderStatusModal");
23
24
  const ServerRenderModal_1 = require("./RenderModal/ServerRenderModal");
24
25
  const WebRenderModal_1 = require("./RenderModal/WebRenderModal");
25
- const EasingEditorModal_1 = require("./Timeline/EasingEditorModal");
26
26
  const KeyframeSettingsModal_1 = require("./Timeline/KeyframeSettingsModal");
27
27
  const UpdateModal_1 = require("./UpdateModal/UpdateModal");
28
28
  const Modals = ({ readOnlyStudio }) => {
@@ -30,8 +30,8 @@ const Modals = ({ readOnlyStudio }) => {
30
30
  const { selectedModal: modalContextType } = (0, react_1.useContext)(modals_1.ModalsContext);
31
31
  const canRender = (0, react_1.useContext)(client_id_1.StudioServerConnectionCtx).previewServerState.type ===
32
32
  'connected';
33
- return (jsx_runtime_1.jsxs(jsx_runtime_1.Fragment, { children: [modalContextType && modalContextType.type === 'duplicate-comp' && (jsx_runtime_1.jsx(DuplicateComposition_1.DuplicateComposition, { compositionType: modalContextType.compositionType, compositionId: modalContextType.compositionId })), modalContextType && modalContextType.type === 'delete-comp' && (jsx_runtime_1.jsx(DeleteComposition_1.DeleteComposition, { compositionId: modalContextType.compositionId })), modalContextType && modalContextType.type === 'rename-comp' && (jsx_runtime_1.jsx(RenameComposition_1.RenameComposition, { compositionId: modalContextType.compositionId })), modalContextType && modalContextType.type === 'delete-folder' && (jsx_runtime_1.jsx(DeleteFolder_1.DeleteFolder, { folderName: modalContextType.folderName, parentName: modalContextType.parentName, stack: modalContextType.stack })), modalContextType && modalContextType.type === 'rename-folder' && (jsx_runtime_1.jsx(RenameFolder_1.RenameFolder, { folderName: modalContextType.folderName, parentName: modalContextType.parentName, stack: modalContextType.stack })), modalContextType && modalContextType.type === 'rename-static-file' && (jsx_runtime_1.jsx(RenameStaticFile_1.RenameStaticFileModal, { relativePath: modalContextType.relativePath })), modalContextType && modalContextType.type === 'input-props-override' && (jsx_runtime_1.jsx(OverrideInputProps_1.OverrideInputPropsModal, {})), modalContextType && modalContextType.type === 'keyframe-settings' && (jsx_runtime_1.jsx(KeyframeSettingsModal_1.KeyframeSettingsModal, { state: modalContextType })), modalContextType && modalContextType.type === 'easing-editor' && (jsx_runtime_1.jsx(EasingEditorModal_1.EasingEditorModal, { state: modalContextType })), modalContextType && modalContextType.type === 'web-render' && (jsx_runtime_1.jsx(WebRenderModal_1.WebRenderModalWithLoader, { ...modalContextType })), modalContextType &&
33
+ return (jsx_runtime_1.jsxs(jsx_runtime_1.Fragment, { children: [modalContextType && modalContextType.type === 'duplicate-comp' && (jsx_runtime_1.jsx(DuplicateComposition_1.DuplicateComposition, { compositionType: modalContextType.compositionType, compositionId: modalContextType.compositionId })), modalContextType && modalContextType.type === 'delete-comp' && (jsx_runtime_1.jsx(DeleteComposition_1.DeleteComposition, { compositionId: modalContextType.compositionId })), modalContextType && modalContextType.type === 'rename-comp' && (jsx_runtime_1.jsx(RenameComposition_1.RenameComposition, { compositionId: modalContextType.compositionId })), modalContextType && modalContextType.type === 'delete-folder' && (jsx_runtime_1.jsx(DeleteFolder_1.DeleteFolder, { folderName: modalContextType.folderName, parentName: modalContextType.parentName, stack: modalContextType.stack })), modalContextType && modalContextType.type === 'rename-folder' && (jsx_runtime_1.jsx(RenameFolder_1.RenameFolder, { folderName: modalContextType.folderName, parentName: modalContextType.parentName, stack: modalContextType.stack })), modalContextType && modalContextType.type === 'rename-static-file' && (jsx_runtime_1.jsx(RenameStaticFile_1.RenameStaticFileModal, { relativePath: modalContextType.relativePath })), modalContextType && modalContextType.type === 'input-props-override' && (jsx_runtime_1.jsx(OverrideInputProps_1.OverrideInputPropsModal, {})), modalContextType && modalContextType.type === 'keyframe-settings' && (jsx_runtime_1.jsx(KeyframeSettingsModal_1.KeyframeSettingsModal, { state: modalContextType })), modalContextType && modalContextType.type === 'web-render' && (jsx_runtime_1.jsx(WebRenderModal_1.WebRenderModalWithLoader, { ...modalContextType })), modalContextType &&
34
34
  modalContextType.type === 'server-render' &&
35
- (canRender || modalContextType.readOnlyStudio) ? (jsx_runtime_1.jsx(ServerRenderModal_1.RenderModalWithLoader, { readOnlyStudio: (_a = modalContextType.readOnlyStudio) !== null && _a !== void 0 ? _a : false, initialFrame: modalContextType.initialFrame, initialDarkMode: modalContextType.initialDarkMode, compositionId: modalContextType.compositionId, initialVideoImageFormat: modalContextType.initialVideoImageFormat, initialJpegQuality: modalContextType.initialJpegQuality, initialScale: modalContextType.initialScale, initialLogLevel: modalContextType.initialLogLevel, initialOffthreadVideoCacheSizeInBytes: modalContextType.initialOffthreadVideoCacheSizeInBytes, initialOffthreadVideoThreads: modalContextType.initialOffthreadVideoThreads, initialMediaCacheSizeInBytes: modalContextType.initialMediaCacheSizeInBytes, initialConcurrency: modalContextType.initialConcurrency, maxConcurrency: modalContextType.maxConcurrency, minConcurrency: modalContextType.minConcurrency, initialStillImageFormat: modalContextType.initialStillImageFormat, initialMuted: modalContextType.initialMuted, initialEnforceAudioTrack: modalContextType.initialEnforceAudioTrack, initialProResProfile: modalContextType.initialProResProfile, initialx264Preset: modalContextType.initialx264Preset, initialGopSize: modalContextType.initialGopSize, initialPixelFormat: modalContextType.initialPixelFormat, initialAudioBitrate: modalContextType.initialAudioBitrate, initialVideoBitrate: modalContextType.initialVideoBitrate, initialEveryNthFrame: modalContextType.initialEveryNthFrame, initialNumberOfGifLoops: modalContextType.initialNumberOfGifLoops, initialDelayRenderTimeout: modalContextType.initialDelayRenderTimeout, initialEnvVariables: modalContextType.initialEnvVariables, initialDisableWebSecurity: modalContextType.initialDisableWebSecurity, initialGl: modalContextType.initialOpenGlRenderer, initialHeadless: modalContextType.initialHeadless, initialIgnoreCertificateErrors: modalContextType.initialIgnoreCertificateErrors, initialEncodingBufferSize: modalContextType.initialEncodingBufferSize, initialEncodingMaxRate: modalContextType.initialEncodingMaxRate, initialUserAgent: modalContextType.initialUserAgent, initialColorSpace: modalContextType.initialColorSpace, initialMultiProcessOnLinux: modalContextType.initialMultiProcessOnLinux, initialRepro: modalContextType.initialRepro, initialBeep: modalContextType.initialBeep, initialForSeamlessAacConcatenation: modalContextType.initialForSeamlessAacConcatenation, defaultProps: modalContextType.defaultProps, inFrameMark: modalContextType.inFrameMark, outFrameMark: modalContextType.outFrameMark, defaultConfigurationAudioCodec: modalContextType.defaultConfigurationAudioCodec, defaultConfigurationVideoCodec: modalContextType.defaultConfigurationVideoCodec, renderTypeOfLastRender: modalContextType.renderTypeOfLastRender, defaultMetadata: modalContextType.defaulMetadata, initialHardwareAcceleration: modalContextType.initialHardwareAcceleration, initialSampleRate: modalContextType.initialSampleRate, initialChromeMode: modalContextType.initialChromeMode, renderDefaults: modalContextType.renderDefaults })) : null, modalContextType && modalContextType.type === 'render-progress' && (jsx_runtime_1.jsx(RenderStatusModal_1.RenderStatusModal, { jobId: modalContextType.jobId })), modalContextType && modalContextType.type === 'update' && (jsx_runtime_1.jsx(UpdateModal_1.UpdateModal, { info: modalContextType.info, knownBugs: modalContextType.knownBugs })), modalContextType && modalContextType.type === 'install-packages' && (jsx_runtime_1.jsx(InstallPackage_1.InstallPackageModal, { packageManager: modalContextType.packageManager })), modalContextType && modalContextType.type === 'quick-switcher' && (jsx_runtime_1.jsx(QuickSwitcher_1.default, { readOnlyStudio: readOnlyStudio, invocationTimestamp: modalContextType.invocationTimestamp, initialMode: modalContextType.mode })), modalContextType && modalContextType.type === 'confirmation-dialog' && (jsx_runtime_1.jsx(ConfirmationDialog_1.ConfirmationDialog, { state: modalContextType })), process.env.ASK_AI_ENABLED && jsx_runtime_1.jsx(AskAiModal_1.AskAiModal, {})] }));
35
+ (canRender || modalContextType.readOnlyStudio) ? (jsx_runtime_1.jsx(ServerRenderModal_1.RenderModalWithLoader, { readOnlyStudio: (_a = modalContextType.readOnlyStudio) !== null && _a !== void 0 ? _a : false, initialFrame: modalContextType.initialFrame, initialDarkMode: modalContextType.initialDarkMode, compositionId: modalContextType.compositionId, initialVideoImageFormat: modalContextType.initialVideoImageFormat, initialJpegQuality: modalContextType.initialJpegQuality, initialScale: modalContextType.initialScale, initialLogLevel: modalContextType.initialLogLevel, initialOffthreadVideoCacheSizeInBytes: modalContextType.initialOffthreadVideoCacheSizeInBytes, initialOffthreadVideoThreads: modalContextType.initialOffthreadVideoThreads, initialMediaCacheSizeInBytes: modalContextType.initialMediaCacheSizeInBytes, initialConcurrency: modalContextType.initialConcurrency, maxConcurrency: modalContextType.maxConcurrency, minConcurrency: modalContextType.minConcurrency, initialStillImageFormat: modalContextType.initialStillImageFormat, initialMuted: modalContextType.initialMuted, initialEnforceAudioTrack: modalContextType.initialEnforceAudioTrack, initialProResProfile: modalContextType.initialProResProfile, initialx264Preset: modalContextType.initialx264Preset, initialGopSize: modalContextType.initialGopSize, initialPixelFormat: modalContextType.initialPixelFormat, initialAudioBitrate: modalContextType.initialAudioBitrate, initialVideoBitrate: modalContextType.initialVideoBitrate, initialEveryNthFrame: modalContextType.initialEveryNthFrame, initialNumberOfGifLoops: modalContextType.initialNumberOfGifLoops, initialDelayRenderTimeout: modalContextType.initialDelayRenderTimeout, initialEnvVariables: modalContextType.initialEnvVariables, initialDisableWebSecurity: modalContextType.initialDisableWebSecurity, initialGl: modalContextType.initialOpenGlRenderer, initialHeadless: modalContextType.initialHeadless, initialIgnoreCertificateErrors: modalContextType.initialIgnoreCertificateErrors, initialEncodingBufferSize: modalContextType.initialEncodingBufferSize, initialEncodingMaxRate: modalContextType.initialEncodingMaxRate, initialUserAgent: modalContextType.initialUserAgent, initialColorSpace: modalContextType.initialColorSpace, initialMultiProcessOnLinux: modalContextType.initialMultiProcessOnLinux, initialRepro: modalContextType.initialRepro, initialBeep: modalContextType.initialBeep, initialForSeamlessAacConcatenation: modalContextType.initialForSeamlessAacConcatenation, defaultProps: modalContextType.defaultProps, inFrameMark: modalContextType.inFrameMark, outFrameMark: modalContextType.outFrameMark, defaultConfigurationAudioCodec: modalContextType.defaultConfigurationAudioCodec, defaultConfigurationVideoCodec: modalContextType.defaultConfigurationVideoCodec, renderTypeOfLastRender: modalContextType.renderTypeOfLastRender, defaultMetadata: modalContextType.defaulMetadata, initialHardwareAcceleration: modalContextType.initialHardwareAcceleration, initialSampleRate: modalContextType.initialSampleRate, initialChromeMode: modalContextType.initialChromeMode, renderDefaults: modalContextType.renderDefaults })) : null, modalContextType && modalContextType.type === 'render-progress' && (jsx_runtime_1.jsx(RenderStatusModal_1.RenderStatusModal, { jobId: modalContextType.jobId })), modalContextType && modalContextType.type === 'update' && (jsx_runtime_1.jsx(UpdateModal_1.UpdateModal, { info: modalContextType.info, knownBugs: modalContextType.knownBugs })), modalContextType && modalContextType.type === 'install-packages' && (jsx_runtime_1.jsx(InstallPackage_1.InstallPackageModal, { packageManager: modalContextType.packageManager })), modalContextType && modalContextType.type === 'quick-switcher' && (jsx_runtime_1.jsx(QuickSwitcher_1.default, { readOnlyStudio: readOnlyStudio, invocationTimestamp: modalContextType.invocationTimestamp, initialMode: modalContextType.mode })), modalContextType && modalContextType.type === 'add-effect' && (jsx_runtime_1.jsx(EffectPickerModal_1.EffectPickerModal, { state: modalContextType })), modalContextType && modalContextType.type === 'confirmation-dialog' && (jsx_runtime_1.jsx(ConfirmationDialog_1.ConfirmationDialog, { state: modalContextType })), process.env.ASK_AI_ENABLED && jsx_runtime_1.jsx(AskAiModal_1.AskAiModal, {})] }));
36
36
  };
37
37
  exports.Modals = Modals;
@@ -207,7 +207,7 @@ const InputDraggerForwardRefFn = ({ onValueChange, onValueChangeEnd, min: _min,
207
207
  });
208
208
  }, [_min, _step, snapToStep]);
209
209
  if (inputFallback) {
210
- return (jsx_runtime_1.jsx(z_index_1.HigherZIndex, { onEscape: onEscape, onOutsideClick: noop_1.noop, children: jsx_runtime_1.jsx(RemInput_1.RemotionInput, { ref: fallbackRef, autoFocus: true, onKeyPress: onKeyPress, onBlur: onBlur, onChange: onInputChange, min: _min, max: _max, step: deriveStep, defaultValue: value, status: status, pattern: '[0-9]*[.]?[0-9]*', rightAlign: rightAlign, ...props, ...(small ? { style: { padding: '4px 6px', fontSize: 12 } } : {}) }) }));
210
+ return (jsx_runtime_1.jsx(z_index_1.HigherZIndex, { onEscape: onEscape, onOutsideClick: noop_1.noop, children: jsx_runtime_1.jsx(RemInput_1.RemotionInput, { ref: fallbackRef, autoFocus: true, onKeyPress: onKeyPress, onBlur: onBlur, onChange: onInputChange, min: _min, max: _max, step: deriveStep, defaultValue: value, status: status, pattern: '[0-9]*[.]?[0-9]*', rightAlign: rightAlign, small: small, ...props }) }));
211
211
  }
212
212
  return (jsx_runtime_1.jsx("button", { ref: ref, type: "button", className: '__remotion_input_dragger', style: style, onClick: onClick, onFocus: onFocus, onPointerDown: onPointerDown, children: jsx_runtime_1.jsx("span", { style: span, children: formatter(value) }) }));
213
213
  };
@@ -4,6 +4,7 @@ export type RemInputStatus = 'error' | 'warning' | 'ok';
4
4
  type Props = React.DetailedHTMLProps<React.InputHTMLAttributes<HTMLInputElement>, HTMLInputElement> & {
5
5
  readonly status: RemInputStatus;
6
6
  readonly rightAlign: boolean;
7
+ readonly small?: boolean;
7
8
  };
8
9
  export declare const INPUT_HORIZONTAL_PADDING = 8;
9
10
  export declare const RightAlignInput: React.FC<PropsWithChildren>;