One of Reflex's most powerful features is the ability to wrap React components and take advantage of the vast ecosystem of React libraries.
If you want a specific component for your app but Reflex doesn't provide it, there's a good chance it's available as a React component. Search for it on npm, and if it's there, you can use it in your Reflex app. You can also create your own local React components and wrap them in Reflex.
Once you wrap your component, you publish it to the Reflex library so that others can use it.
Simple components that don't have any interaction can be wrapped with just a few lines of code.
Below we show how to wrap the Spline library can be used to create 3D scenes and animations.
import reflex as rx
class Spline(rx.Component):
"""Spline component."""
# The name of the npm package.
library = "@splinetool/react-spline"
# Any additional libraries needed to use the component.
lib_dependencies: list[str] = [
"@splinetool/runtime@1.5.5"
]
# The name of the component to use from the package.
tag = "Spline"
# Spline is a default export from the module.
is_default = True
# Any props that the component takes.
scene: rx.Var[str]
# Convenience function to create the Spline component.
spline = Spline.create
# Use the Spline component in your app.
def index():
return spline(
scene="https://prod.spline.design/joLpOOYbGL-10EJ4/scene.splinecode"
)
Similar to the Spline example we start with defining the library and tag. In this case the library is react-colorful
and the tag is HexColorPicker
.
We also have a var color
which is the current color of the color picker.
Since this component has interaction we must specify any event triggers that the component takes. The color picker has a single trigger on_change
to specify when the color changes. This trigger takes in a single argument color
which is the new color.
#db114b
class ColorPicker(rx.Component): library = "react-colorful" tag = "HexColorPicker" color: rx.Var[str] on_change: rx.EventHandler[lambda color: [color]] color_picker = ColorPicker.create class ColorPickerState(rx.State): color: str = "#db114b" def index(): return rx.box( rx.vstack( rx.heading( ColorPickerState.color, color="white" ), color_picker( on_change=ColorPickerState.set_color ), ), background_color=ColorPickerState.color, padding="5em", border_radius="1em", )
In the next page, we will go step by step through a more complex example of wrapping a React component.