import reflex as rxReflex supports a plugin system that allows you to extend the framework's functionality during the compilation process. Plugins can add frontend dependencies, modify build configurations, generate static assets, and perform custom tasks before compilation.
Plugins are configured in your rxconfig.py file using the plugins parameter:
import reflex as rx
config = rx.Config(
app_name="my_app",
plugins=[
rx.plugins.SitemapPlugin(),
rx.plugins.TailwindV4Plugin(),
],
)Reflex comes with several built-in plugins that provide common functionality.
The SitemapPlugin automatically generates a sitemap.xml file for your application, which helps search engines discover and index your pages.
import reflex as rx
config = rx.Config(
app_name="my_app",
plugins=[
rx.plugins.SitemapPlugin(),
],
)The sitemap plugin automatically includes all your app's routes. For dynamic routes or custom configuration, you can add sitemap metadata to individual pages:
@rx.page(
route="/blog/[slug]", context={"sitemap": {"changefreq": "weekly", "priority": 0.8}}
)
def blog_post():
return rx.text("Blog post content")
@rx.page(
route="/about", context={"sitemap": {"changefreq": "monthly", "priority": 0.5}}
)
def about():
return rx.text("About page")The sitemap configuration supports the following options:
loc: Custom URL for the page (required for dynamic routes)lastmod: Last modification date (datetime object)changefreq: How frequently the page changes ("always","hourly","daily","weekly","monthly","yearly","never")priority: Priority of this URL relative to other URLs (0.0 to 1.0)
The TailwindV4Plugin provides support for Tailwind CSS v4, which is the recommended version for new projects and includes performance improvements and new features.
import reflex as rx
# Basic configuration
config = rx.Config(
app_name="my_app",
plugins=[
rx.plugins.TailwindV4Plugin(),
],
)You can customize the Tailwind configuration by passing a config dictionary:
import reflex as rx
tailwind_config = {
"theme": {
"extend": {
"colors": {
"brand": {
"50": "#eff6ff",
"500": "#3b82f6",
"900": "#1e3a8a",
}
}
}
},
"plugins": ["@tailwindcss/typography"],
}
config = rx.Config(
app_name="my_app",
plugins=[
rx.plugins.TailwindV4Plugin(tailwind_config),
],
)The TailwindV3Plugin integrates Tailwind CSS v3 into your Reflex application. While still supported, TailwindV4Plugin is recommended for new projects.
import reflex as rx
# Basic configuration
config = rx.Config(
app_name="my_app",
plugins=[
rx.plugins.TailwindV3Plugin(),
],
)You can customize the Tailwind configuration by passing a config dictionary:
import reflex as rx
tailwind_config = {
"theme": {
"extend": {
"colors": {
"primary": "#3b82f6",
"secondary": "#64748b",
}
}
},
"plugins": ["@tailwindcss/typography", "@tailwindcss/forms"],
}
config = rx.Config(
app_name="my_app",
plugins=[
rx.plugins.TailwindV3Plugin(tailwind_config),
],
)Some plugins are enabled by default. Currently, the SitemapPlugin is enabled automatically. If you want to disable a default plugin, use the disable_plugins parameter:
import reflex as rx
config = rx.Config(
app_name="my_app",
disable_plugins=["reflex.plugins.sitemap.SitemapPlugin"],
)Plugins are executed in the order they appear in the plugins list. This can be important if plugins have dependencies on each other or modify the same files.
import reflex as rx
config = rx.Config(
app_name="my_app",
plugins=[
rx.plugins.TailwindV4Plugin(), # Runs first
rx.plugins.SitemapPlugin(), # Runs second
],
)All plugins inherit from the base Plugin class and can implement several lifecycle methods:
class Plugin:
def get_frontend_development_dependencies(self, **context) -> list[str]:
"""Get NPM packages required by the plugin for development."""
return []
def get_frontend_dependencies(self, **context) -> list[str]:
"""Get NPM packages required by the plugin."""
return []
def get_static_assets(self, **context) -> Sequence[tuple[Path, str | bytes]]:
"""Get static assets required by the plugin."""
return []
def get_stylesheet_paths(self, **context) -> Sequence[str]:
"""Get paths to stylesheets required by the plugin."""
return []
def pre_compile(self, **context) -> None:
"""Called before compilation to perform custom tasks."""
passYou can create custom plugins by inheriting from the base Plugin class:
from reflex.plugins.base import Plugin
from pathlib import Path
class CustomPlugin(Plugin):
def get_frontend_dependencies(self, **context):
return ["my-custom-package@1.0.0"]
def pre_compile(self, **context):
# Custom logic before compilation
print("Running custom plugin logic...")
# Add a custom task
context["add_save_task"](self.create_custom_file)
def create_custom_file(self):
return "public/custom.txt", "Custom content"Then use it in your configuration:
import reflex as rx
from my_plugins import CustomPlugin
config = rx.Config(
app_name="my_app",
plugins=[
CustomPlugin(),
],
)