saveDefaultProps()v4.0.147
Saves the defaultProps for a composition back to the root file.
If you just want to update the default props in the Props Editor (right sidebar in the Studio) without saving them to the root file, use updateDefaultProps().
Examples
Saving {color: 'green'} to Root.tsxtsximport {saveDefaultProps } from "@remotion/studio";awaitsaveDefaultProps ({compositionId : "my-composition",defaultProps : () => {return {color : "green",};},});
Saving {color: 'green'} to Root.tsxtsximport {saveDefaultProps } from "@remotion/studio";awaitsaveDefaultProps ({compositionId : "my-composition",defaultProps : () => {return {color : "green",};},});
You can access the saved default props to only override part of it (reducer-style):
Accessing the saved default propstsximport {saveDefaultProps } from "@remotion/studio";awaitsaveDefaultProps ({compositionId : "my-composition",defaultProps : ({savedDefaultProps }) => {return {...savedDefaultProps ,color : "green",};},});
Accessing the saved default propstsximport {saveDefaultProps } from "@remotion/studio";awaitsaveDefaultProps ({compositionId : "my-composition",defaultProps : ({savedDefaultProps }) => {return {...savedDefaultProps ,color : "green",};},});
If you modified props in the Props Editor (right sidebar in the Studio), you can also access the unsaved props from there, and for example save them:
Save props from the Props Editortsximport {saveDefaultProps } from "@remotion/studio";awaitsaveDefaultProps ({compositionId : "my-composition",defaultProps : ({unsavedDefaultProps }) => {returnunsavedDefaultProps ;},});
Save props from the Props Editortsximport {saveDefaultProps } from "@remotion/studio";awaitsaveDefaultProps ({compositionId : "my-composition",defaultProps : ({unsavedDefaultProps }) => {returnunsavedDefaultProps ;},});
If you have a Zod schema, you can also access its runtime value:
Save props from the Props Editortsximport {saveDefaultProps } from "@remotion/studio";awaitsaveDefaultProps ({compositionId : "my-composition",defaultProps : ({schema ,unsavedDefaultProps }) => {// Do something with the Zod schemareturn {...unsavedDefaultProps ,color : "red",};},});
Save props from the Props Editortsximport {saveDefaultProps } from "@remotion/studio";awaitsaveDefaultProps ({compositionId : "my-composition",defaultProps : ({schema ,unsavedDefaultProps }) => {// Do something with the Zod schemareturn {...unsavedDefaultProps ,color : "red",};},});
Requirements
In order to use this function:
You need to be inside the Remotion Studio.The Studio must be running (no static deployment)
zod needs to be installed.
Otherwise, the function will throw.